diff --git a/sdk/network/azure-mgmt-network/CHANGELOG.md b/sdk/network/azure-mgmt-network/CHANGELOG.md index 79e5a45a477f..60a5e08f01f3 100644 --- a/sdk/network/azure-mgmt-network/CHANGELOG.md +++ b/sdk/network/azure-mgmt-network/CHANGELOG.md @@ -1,5 +1,25 @@ # Release History +## 17.1.0 (2021-01-26) + +**Features** + - Model PrivateEndpoint has a new parameter extended_location + - Model VpnGateway has a new parameter nat_rules + - Model ExpressRouteConnection has a new parameter express_route_gateway_bypass + - Model SecurityRule has a new parameter type + - Model PrivateLinkService has a new parameter extended_location + - Model Route has a new parameter type + - Model Route has a new parameter has_bgp_override + - Model RouteTable has a new parameter resource_guid + - Model VpnSiteLinkConnection has a new parameter ingress_nat_rules + - Model VpnSiteLinkConnection has a new parameter vpn_link_connection_mode + - Model VpnSiteLinkConnection has a new parameter egress_nat_rules + - Model BackendAddressPool has a new parameter location + - Model CustomIpPrefix has a new parameter extended_location + - Added operation ExpressRouteGatewaysOperations.begin_update_tags + - Added operation VirtualNetworkGatewayConnectionsOperations.begin_get_ike_sas + - Added operation group NatRulesOperations + ## 17.0.0 (2020-11-25) **Features** diff --git a/sdk/network/azure-mgmt-network/README.md b/sdk/network/azure-mgmt-network/README.md index 3c1405b06b47..6b6c46b44522 100644 --- a/sdk/network/azure-mgmt-network/README.md +++ b/sdk/network/azure-mgmt-network/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-network%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 [Network 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/network/azure-mgmt-network/azure/mgmt/network/_network_management_client.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/_network_management_client.py index 7189cd6f50c1..5f2932fb4ee0 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/_network_management_client.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/_network_management_client.py @@ -46,7 +46,7 @@ class NetworkManagementClient(NetworkManagementClientOperationsMixin, MultiApiCl :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2020-07-01' + DEFAULT_API_VERSION = '2020-08-01' _PROFILE_TAG = "azure.mgmt.network.NetworkManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -115,6 +115,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2020-05-01: :mod:`v2020_05_01.models` * 2020-06-01: :mod:`v2020_06_01.models` * 2020-07-01: :mod:`v2020_07_01.models` + * 2020-08-01: :mod:`v2020_08_01.models` """ if api_version == '2015-06-15': from .v2015_06_15 import models @@ -209,6 +210,9 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2020-07-01': from .v2020_07_01 import models return models + elif api_version == '2020-08-01': + from .v2020_08_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -218,6 +222,7 @@ def application_gateway_private_endpoint_connections(self): * 2020-05-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` * 2020-06-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` * 2020-07-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` + * 2020-08-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` """ api_version = self._get_api_version('application_gateway_private_endpoint_connections') if api_version == '2020-05-01': @@ -226,6 +231,8 @@ def application_gateway_private_endpoint_connections(self): from .v2020_06_01.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateway_private_endpoint_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -237,6 +244,7 @@ def application_gateway_private_link_resources(self): * 2020-05-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` * 2020-06-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` * 2020-07-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` + * 2020-08-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` """ api_version = self._get_api_version('application_gateway_private_link_resources') if api_version == '2020-05-01': @@ -245,6 +253,8 @@ def application_gateway_private_link_resources(self): from .v2020_06_01.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateway_private_link_resources'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -284,6 +294,7 @@ def application_gateways(self): * 2020-05-01: :class:`ApplicationGatewaysOperations` * 2020-06-01: :class:`ApplicationGatewaysOperations` * 2020-07-01: :class:`ApplicationGatewaysOperations` + * 2020-08-01: :class:`ApplicationGatewaysOperations` """ api_version = self._get_api_version('application_gateways') if api_version == '2015-06-15': @@ -348,6 +359,8 @@ def application_gateways(self): from .v2020_06_01.operations import ApplicationGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ApplicationGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ApplicationGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -381,6 +394,7 @@ def application_security_groups(self): * 2020-05-01: :class:`ApplicationSecurityGroupsOperations` * 2020-06-01: :class:`ApplicationSecurityGroupsOperations` * 2020-07-01: :class:`ApplicationSecurityGroupsOperations` + * 2020-08-01: :class:`ApplicationSecurityGroupsOperations` """ api_version = self._get_api_version('application_security_groups') if api_version == '2017-09-01': @@ -433,6 +447,8 @@ def application_security_groups(self): from .v2020_06_01.operations import ApplicationSecurityGroupsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ApplicationSecurityGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ApplicationSecurityGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_security_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -458,6 +474,7 @@ def available_delegations(self): * 2020-05-01: :class:`AvailableDelegationsOperations` * 2020-06-01: :class:`AvailableDelegationsOperations` * 2020-07-01: :class:`AvailableDelegationsOperations` + * 2020-08-01: :class:`AvailableDelegationsOperations` """ api_version = self._get_api_version('available_delegations') if api_version == '2018-08-01': @@ -494,6 +511,8 @@ def available_delegations(self): from .v2020_06_01.operations import AvailableDelegationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AvailableDelegationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AvailableDelegationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_delegations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -529,6 +548,7 @@ def available_endpoint_services(self): * 2020-05-01: :class:`AvailableEndpointServicesOperations` * 2020-06-01: :class:`AvailableEndpointServicesOperations` * 2020-07-01: :class:`AvailableEndpointServicesOperations` + * 2020-08-01: :class:`AvailableEndpointServicesOperations` """ api_version = self._get_api_version('available_endpoint_services') if api_version == '2017-06-01': @@ -585,6 +605,8 @@ def available_endpoint_services(self): from .v2020_06_01.operations import AvailableEndpointServicesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AvailableEndpointServicesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AvailableEndpointServicesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_endpoint_services'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -605,6 +627,7 @@ def available_private_endpoint_types(self): * 2020-05-01: :class:`AvailablePrivateEndpointTypesOperations` * 2020-06-01: :class:`AvailablePrivateEndpointTypesOperations` * 2020-07-01: :class:`AvailablePrivateEndpointTypesOperations` + * 2020-08-01: :class:`AvailablePrivateEndpointTypesOperations` """ api_version = self._get_api_version('available_private_endpoint_types') if api_version == '2019-04-01': @@ -631,6 +654,8 @@ def available_private_endpoint_types(self): from .v2020_06_01.operations import AvailablePrivateEndpointTypesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AvailablePrivateEndpointTypesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AvailablePrivateEndpointTypesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_private_endpoint_types'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -656,6 +681,7 @@ def available_resource_group_delegations(self): * 2020-05-01: :class:`AvailableResourceGroupDelegationsOperations` * 2020-06-01: :class:`AvailableResourceGroupDelegationsOperations` * 2020-07-01: :class:`AvailableResourceGroupDelegationsOperations` + * 2020-08-01: :class:`AvailableResourceGroupDelegationsOperations` """ api_version = self._get_api_version('available_resource_group_delegations') if api_version == '2018-08-01': @@ -692,6 +718,8 @@ def available_resource_group_delegations(self): from .v2020_06_01.operations import AvailableResourceGroupDelegationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AvailableResourceGroupDelegationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AvailableResourceGroupDelegationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_resource_group_delegations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -709,6 +737,7 @@ def available_service_aliases(self): * 2020-05-01: :class:`AvailableServiceAliasesOperations` * 2020-06-01: :class:`AvailableServiceAliasesOperations` * 2020-07-01: :class:`AvailableServiceAliasesOperations` + * 2020-08-01: :class:`AvailableServiceAliasesOperations` """ api_version = self._get_api_version('available_service_aliases') if api_version == '2019-08-01': @@ -729,6 +758,8 @@ def available_service_aliases(self): from .v2020_06_01.operations import AvailableServiceAliasesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AvailableServiceAliasesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AvailableServiceAliasesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_service_aliases'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -754,6 +785,7 @@ def azure_firewall_fqdn_tags(self): * 2020-05-01: :class:`AzureFirewallFqdnTagsOperations` * 2020-06-01: :class:`AzureFirewallFqdnTagsOperations` * 2020-07-01: :class:`AzureFirewallFqdnTagsOperations` + * 2020-08-01: :class:`AzureFirewallFqdnTagsOperations` """ api_version = self._get_api_version('azure_firewall_fqdn_tags') if api_version == '2018-08-01': @@ -790,6 +822,8 @@ def azure_firewall_fqdn_tags(self): from .v2020_06_01.operations import AzureFirewallFqdnTagsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AzureFirewallFqdnTagsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AzureFirewallFqdnTagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'azure_firewall_fqdn_tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -818,6 +852,7 @@ def azure_firewalls(self): * 2020-05-01: :class:`AzureFirewallsOperations` * 2020-06-01: :class:`AzureFirewallsOperations` * 2020-07-01: :class:`AzureFirewallsOperations` + * 2020-08-01: :class:`AzureFirewallsOperations` """ api_version = self._get_api_version('azure_firewalls') if api_version == '2018-04-01': @@ -860,6 +895,8 @@ def azure_firewalls(self): from .v2020_06_01.operations import AzureFirewallsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import AzureFirewallsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import AzureFirewallsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'azure_firewalls'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -880,6 +917,7 @@ def bastion_hosts(self): * 2020-05-01: :class:`BastionHostsOperations` * 2020-06-01: :class:`BastionHostsOperations` * 2020-07-01: :class:`BastionHostsOperations` + * 2020-08-01: :class:`BastionHostsOperations` """ api_version = self._get_api_version('bastion_hosts') if api_version == '2019-04-01': @@ -906,6 +944,8 @@ def bastion_hosts(self): from .v2020_06_01.operations import BastionHostsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import BastionHostsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import BastionHostsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'bastion_hosts'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -943,6 +983,7 @@ def bgp_service_communities(self): * 2020-05-01: :class:`BgpServiceCommunitiesOperations` * 2020-06-01: :class:`BgpServiceCommunitiesOperations` * 2020-07-01: :class:`BgpServiceCommunitiesOperations` + * 2020-08-01: :class:`BgpServiceCommunitiesOperations` """ api_version = self._get_api_version('bgp_service_communities') if api_version == '2016-12-01': @@ -1003,6 +1044,8 @@ def bgp_service_communities(self): from .v2020_06_01.operations import BgpServiceCommunitiesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import BgpServiceCommunitiesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import BgpServiceCommunitiesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'bgp_service_communities'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1035,6 +1078,7 @@ def connection_monitors(self): * 2020-05-01: :class:`ConnectionMonitorsOperations` * 2020-06-01: :class:`ConnectionMonitorsOperations` * 2020-07-01: :class:`ConnectionMonitorsOperations` + * 2020-08-01: :class:`ConnectionMonitorsOperations` """ api_version = self._get_api_version('connection_monitors') if api_version == '2017-10-01': @@ -1085,6 +1129,8 @@ def connection_monitors(self): from .v2020_06_01.operations import ConnectionMonitorsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ConnectionMonitorsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ConnectionMonitorsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'connection_monitors'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1095,12 +1141,15 @@ def custom_ip_prefixes(self): * 2020-06-01: :class:`CustomIPPrefixesOperations` * 2020-07-01: :class:`CustomIPPrefixesOperations` + * 2020-08-01: :class:`CustomIPPrefixesOperations` """ api_version = self._get_api_version('custom_ip_prefixes') if api_version == '2020-06-01': from .v2020_06_01.operations import CustomIPPrefixesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import CustomIPPrefixesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import CustomIPPrefixesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'custom_ip_prefixes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1124,6 +1173,7 @@ def ddos_custom_policies(self): * 2020-05-01: :class:`DdosCustomPoliciesOperations` * 2020-06-01: :class:`DdosCustomPoliciesOperations` * 2020-07-01: :class:`DdosCustomPoliciesOperations` + * 2020-08-01: :class:`DdosCustomPoliciesOperations` """ api_version = self._get_api_version('ddos_custom_policies') if api_version == '2018-11-01': @@ -1156,6 +1206,8 @@ def ddos_custom_policies(self): from .v2020_06_01.operations import DdosCustomPoliciesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import DdosCustomPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import DdosCustomPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ddos_custom_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1185,6 +1237,7 @@ def ddos_protection_plans(self): * 2020-05-01: :class:`DdosProtectionPlansOperations` * 2020-06-01: :class:`DdosProtectionPlansOperations` * 2020-07-01: :class:`DdosProtectionPlansOperations` + * 2020-08-01: :class:`DdosProtectionPlansOperations` """ api_version = self._get_api_version('ddos_protection_plans') if api_version == '2018-02-01': @@ -1229,6 +1282,8 @@ def ddos_protection_plans(self): from .v2020_06_01.operations import DdosProtectionPlansOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import DdosProtectionPlansOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import DdosProtectionPlansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ddos_protection_plans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1264,6 +1319,7 @@ def default_security_rules(self): * 2020-05-01: :class:`DefaultSecurityRulesOperations` * 2020-06-01: :class:`DefaultSecurityRulesOperations` * 2020-07-01: :class:`DefaultSecurityRulesOperations` + * 2020-08-01: :class:`DefaultSecurityRulesOperations` """ api_version = self._get_api_version('default_security_rules') if api_version == '2017-06-01': @@ -1320,6 +1376,8 @@ def default_security_rules(self): from .v2020_06_01.operations import DefaultSecurityRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import DefaultSecurityRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import DefaultSecurityRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'default_security_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1330,12 +1388,15 @@ def dscp_configuration(self): * 2020-06-01: :class:`DscpConfigurationOperations` * 2020-07-01: :class:`DscpConfigurationOperations` + * 2020-08-01: :class:`DscpConfigurationOperations` """ api_version = self._get_api_version('dscp_configuration') if api_version == '2020-06-01': from .v2020_06_01.operations import DscpConfigurationOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import DscpConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import DscpConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'dscp_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1375,6 +1436,7 @@ def express_route_circuit_authorizations(self): * 2020-05-01: :class:`ExpressRouteCircuitAuthorizationsOperations` * 2020-06-01: :class:`ExpressRouteCircuitAuthorizationsOperations` * 2020-07-01: :class:`ExpressRouteCircuitAuthorizationsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitAuthorizationsOperations` """ api_version = self._get_api_version('express_route_circuit_authorizations') if api_version == '2015-06-15': @@ -1439,6 +1501,8 @@ def express_route_circuit_authorizations(self): from .v2020_06_01.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_authorizations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1468,6 +1532,7 @@ def express_route_circuit_connections(self): * 2020-05-01: :class:`ExpressRouteCircuitConnectionsOperations` * 2020-06-01: :class:`ExpressRouteCircuitConnectionsOperations` * 2020-07-01: :class:`ExpressRouteCircuitConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitConnectionsOperations` """ api_version = self._get_api_version('express_route_circuit_connections') if api_version == '2018-02-01': @@ -1512,6 +1577,8 @@ def express_route_circuit_connections(self): from .v2020_06_01.operations import ExpressRouteCircuitConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCircuitConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCircuitConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1551,6 +1618,7 @@ def express_route_circuit_peerings(self): * 2020-05-01: :class:`ExpressRouteCircuitPeeringsOperations` * 2020-06-01: :class:`ExpressRouteCircuitPeeringsOperations` * 2020-07-01: :class:`ExpressRouteCircuitPeeringsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitPeeringsOperations` """ api_version = self._get_api_version('express_route_circuit_peerings') if api_version == '2015-06-15': @@ -1615,6 +1683,8 @@ def express_route_circuit_peerings(self): from .v2020_06_01.operations import ExpressRouteCircuitPeeringsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCircuitPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCircuitPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1654,6 +1724,7 @@ def express_route_circuits(self): * 2020-05-01: :class:`ExpressRouteCircuitsOperations` * 2020-06-01: :class:`ExpressRouteCircuitsOperations` * 2020-07-01: :class:`ExpressRouteCircuitsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitsOperations` """ api_version = self._get_api_version('express_route_circuits') if api_version == '2015-06-15': @@ -1718,6 +1789,8 @@ def express_route_circuits(self): from .v2020_06_01.operations import ExpressRouteCircuitsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCircuitsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCircuitsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuits'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1743,6 +1816,7 @@ def express_route_connections(self): * 2020-05-01: :class:`ExpressRouteConnectionsOperations` * 2020-06-01: :class:`ExpressRouteConnectionsOperations` * 2020-07-01: :class:`ExpressRouteConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteConnectionsOperations` """ api_version = self._get_api_version('express_route_connections') if api_version == '2018-08-01': @@ -1779,6 +1853,8 @@ def express_route_connections(self): from .v2020_06_01.operations import ExpressRouteConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1808,6 +1884,7 @@ def express_route_cross_connection_peerings(self): * 2020-05-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` * 2020-06-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` * 2020-07-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` + * 2020-08-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` """ api_version = self._get_api_version('express_route_cross_connection_peerings') if api_version == '2018-02-01': @@ -1852,6 +1929,8 @@ def express_route_cross_connection_peerings(self): from .v2020_06_01.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_cross_connection_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1881,6 +1960,7 @@ def express_route_cross_connections(self): * 2020-05-01: :class:`ExpressRouteCrossConnectionsOperations` * 2020-06-01: :class:`ExpressRouteCrossConnectionsOperations` * 2020-07-01: :class:`ExpressRouteCrossConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteCrossConnectionsOperations` """ api_version = self._get_api_version('express_route_cross_connections') if api_version == '2018-02-01': @@ -1925,6 +2005,8 @@ def express_route_cross_connections(self): from .v2020_06_01.operations import ExpressRouteCrossConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteCrossConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteCrossConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_cross_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1950,6 +2032,7 @@ def express_route_gateways(self): * 2020-05-01: :class:`ExpressRouteGatewaysOperations` * 2020-06-01: :class:`ExpressRouteGatewaysOperations` * 2020-07-01: :class:`ExpressRouteGatewaysOperations` + * 2020-08-01: :class:`ExpressRouteGatewaysOperations` """ api_version = self._get_api_version('express_route_gateways') if api_version == '2018-08-01': @@ -1986,6 +2069,8 @@ def express_route_gateways(self): from .v2020_06_01.operations import ExpressRouteGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2011,6 +2096,7 @@ def express_route_links(self): * 2020-05-01: :class:`ExpressRouteLinksOperations` * 2020-06-01: :class:`ExpressRouteLinksOperations` * 2020-07-01: :class:`ExpressRouteLinksOperations` + * 2020-08-01: :class:`ExpressRouteLinksOperations` """ api_version = self._get_api_version('express_route_links') if api_version == '2018-08-01': @@ -2047,6 +2133,8 @@ def express_route_links(self): from .v2020_06_01.operations import ExpressRouteLinksOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteLinksOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2072,6 +2160,7 @@ def express_route_ports(self): * 2020-05-01: :class:`ExpressRoutePortsOperations` * 2020-06-01: :class:`ExpressRoutePortsOperations` * 2020-07-01: :class:`ExpressRoutePortsOperations` + * 2020-08-01: :class:`ExpressRoutePortsOperations` """ api_version = self._get_api_version('express_route_ports') if api_version == '2018-08-01': @@ -2108,6 +2197,8 @@ def express_route_ports(self): from .v2020_06_01.operations import ExpressRoutePortsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRoutePortsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRoutePortsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_ports'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2133,6 +2224,7 @@ def express_route_ports_locations(self): * 2020-05-01: :class:`ExpressRoutePortsLocationsOperations` * 2020-06-01: :class:`ExpressRoutePortsLocationsOperations` * 2020-07-01: :class:`ExpressRoutePortsLocationsOperations` + * 2020-08-01: :class:`ExpressRoutePortsLocationsOperations` """ api_version = self._get_api_version('express_route_ports_locations') if api_version == '2018-08-01': @@ -2169,6 +2261,8 @@ def express_route_ports_locations(self): from .v2020_06_01.operations import ExpressRoutePortsLocationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRoutePortsLocationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRoutePortsLocationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_ports_locations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2208,6 +2302,7 @@ def express_route_service_providers(self): * 2020-05-01: :class:`ExpressRouteServiceProvidersOperations` * 2020-06-01: :class:`ExpressRouteServiceProvidersOperations` * 2020-07-01: :class:`ExpressRouteServiceProvidersOperations` + * 2020-08-01: :class:`ExpressRouteServiceProvidersOperations` """ api_version = self._get_api_version('express_route_service_providers') if api_version == '2015-06-15': @@ -2272,6 +2367,8 @@ def express_route_service_providers(self): from .v2020_06_01.operations import ExpressRouteServiceProvidersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ExpressRouteServiceProvidersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ExpressRouteServiceProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_service_providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2291,6 +2388,7 @@ def firewall_policies(self): * 2020-05-01: :class:`FirewallPoliciesOperations` * 2020-06-01: :class:`FirewallPoliciesOperations` * 2020-07-01: :class:`FirewallPoliciesOperations` + * 2020-08-01: :class:`FirewallPoliciesOperations` """ api_version = self._get_api_version('firewall_policies') if api_version == '2019-06-01': @@ -2315,6 +2413,8 @@ def firewall_policies(self): from .v2020_06_01.operations import FirewallPoliciesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import FirewallPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import FirewallPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'firewall_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2326,6 +2426,7 @@ def firewall_policy_rule_collection_groups(self): * 2020-05-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` * 2020-06-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` * 2020-07-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` + * 2020-08-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` """ api_version = self._get_api_version('firewall_policy_rule_collection_groups') if api_version == '2020-05-01': @@ -2334,6 +2435,8 @@ def firewall_policy_rule_collection_groups(self): from .v2020_06_01.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'firewall_policy_rule_collection_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2383,6 +2486,7 @@ def flow_logs(self): * 2020-05-01: :class:`FlowLogsOperations` * 2020-06-01: :class:`FlowLogsOperations` * 2020-07-01: :class:`FlowLogsOperations` + * 2020-08-01: :class:`FlowLogsOperations` """ api_version = self._get_api_version('flow_logs') if api_version == '2019-11-01': @@ -2399,6 +2503,8 @@ def flow_logs(self): from .v2020_06_01.operations import FlowLogsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import FlowLogsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import FlowLogsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'flow_logs'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2411,6 +2517,7 @@ def hub_route_tables(self): * 2020-05-01: :class:`HubRouteTablesOperations` * 2020-06-01: :class:`HubRouteTablesOperations` * 2020-07-01: :class:`HubRouteTablesOperations` + * 2020-08-01: :class:`HubRouteTablesOperations` """ api_version = self._get_api_version('hub_route_tables') if api_version == '2020-04-01': @@ -2421,6 +2528,8 @@ def hub_route_tables(self): from .v2020_06_01.operations import HubRouteTablesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import HubRouteTablesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import HubRouteTablesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'hub_route_tables'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2449,6 +2558,7 @@ def hub_virtual_network_connections(self): * 2020-05-01: :class:`HubVirtualNetworkConnectionsOperations` * 2020-06-01: :class:`HubVirtualNetworkConnectionsOperations` * 2020-07-01: :class:`HubVirtualNetworkConnectionsOperations` + * 2020-08-01: :class:`HubVirtualNetworkConnectionsOperations` """ api_version = self._get_api_version('hub_virtual_network_connections') if api_version == '2018-04-01': @@ -2491,6 +2601,8 @@ def hub_virtual_network_connections(self): from .v2020_06_01.operations import HubVirtualNetworkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import HubVirtualNetworkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import HubVirtualNetworkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'hub_virtual_network_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2526,6 +2638,7 @@ def inbound_nat_rules(self): * 2020-05-01: :class:`InboundNatRulesOperations` * 2020-06-01: :class:`InboundNatRulesOperations` * 2020-07-01: :class:`InboundNatRulesOperations` + * 2020-08-01: :class:`InboundNatRulesOperations` """ api_version = self._get_api_version('inbound_nat_rules') if api_version == '2017-06-01': @@ -2582,6 +2695,8 @@ def inbound_nat_rules(self): from .v2020_06_01.operations import InboundNatRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import InboundNatRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import InboundNatRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'inbound_nat_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2592,12 +2707,15 @@ def inbound_security_rule(self): * 2020-06-01: :class:`InboundSecurityRuleOperations` * 2020-07-01: :class:`InboundSecurityRuleOperations` + * 2020-08-01: :class:`InboundSecurityRuleOperations` """ api_version = self._get_api_version('inbound_security_rule') if api_version == '2020-06-01': from .v2020_06_01.operations import InboundSecurityRuleOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import InboundSecurityRuleOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import InboundSecurityRuleOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'inbound_security_rule'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2636,6 +2754,7 @@ def ip_allocations(self): * 2020-05-01: :class:`IpAllocationsOperations` * 2020-06-01: :class:`IpAllocationsOperations` * 2020-07-01: :class:`IpAllocationsOperations` + * 2020-08-01: :class:`IpAllocationsOperations` """ api_version = self._get_api_version('ip_allocations') if api_version == '2020-03-01': @@ -2648,6 +2767,8 @@ def ip_allocations(self): from .v2020_06_01.operations import IpAllocationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import IpAllocationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import IpAllocationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ip_allocations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2664,6 +2785,7 @@ def ip_groups(self): * 2020-05-01: :class:`IpGroupsOperations` * 2020-06-01: :class:`IpGroupsOperations` * 2020-07-01: :class:`IpGroupsOperations` + * 2020-08-01: :class:`IpGroupsOperations` """ api_version = self._get_api_version('ip_groups') if api_version == '2019-09-01': @@ -2682,6 +2804,8 @@ def ip_groups(self): from .v2020_06_01.operations import IpGroupsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import IpGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import IpGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ip_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2717,6 +2841,7 @@ def load_balancer_backend_address_pools(self): * 2020-05-01: :class:`LoadBalancerBackendAddressPoolsOperations` * 2020-06-01: :class:`LoadBalancerBackendAddressPoolsOperations` * 2020-07-01: :class:`LoadBalancerBackendAddressPoolsOperations` + * 2020-08-01: :class:`LoadBalancerBackendAddressPoolsOperations` """ api_version = self._get_api_version('load_balancer_backend_address_pools') if api_version == '2017-06-01': @@ -2773,6 +2898,8 @@ def load_balancer_backend_address_pools(self): from .v2020_06_01.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_backend_address_pools'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2808,6 +2935,7 @@ def load_balancer_frontend_ip_configurations(self): * 2020-05-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` * 2020-06-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` * 2020-07-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` + * 2020-08-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` """ api_version = self._get_api_version('load_balancer_frontend_ip_configurations') if api_version == '2017-06-01': @@ -2864,6 +2992,8 @@ def load_balancer_frontend_ip_configurations(self): from .v2020_06_01.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_frontend_ip_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2899,6 +3029,7 @@ def load_balancer_load_balancing_rules(self): * 2020-05-01: :class:`LoadBalancerLoadBalancingRulesOperations` * 2020-06-01: :class:`LoadBalancerLoadBalancingRulesOperations` * 2020-07-01: :class:`LoadBalancerLoadBalancingRulesOperations` + * 2020-08-01: :class:`LoadBalancerLoadBalancingRulesOperations` """ api_version = self._get_api_version('load_balancer_load_balancing_rules') if api_version == '2017-06-01': @@ -2955,6 +3086,8 @@ def load_balancer_load_balancing_rules(self): from .v2020_06_01.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_load_balancing_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2990,6 +3123,7 @@ def load_balancer_network_interfaces(self): * 2020-05-01: :class:`LoadBalancerNetworkInterfacesOperations` * 2020-06-01: :class:`LoadBalancerNetworkInterfacesOperations` * 2020-07-01: :class:`LoadBalancerNetworkInterfacesOperations` + * 2020-08-01: :class:`LoadBalancerNetworkInterfacesOperations` """ api_version = self._get_api_version('load_balancer_network_interfaces') if api_version == '2017-06-01': @@ -3046,6 +3180,8 @@ def load_balancer_network_interfaces(self): from .v2020_06_01.operations import LoadBalancerNetworkInterfacesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerNetworkInterfacesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerNetworkInterfacesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_network_interfaces'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3071,6 +3207,7 @@ def load_balancer_outbound_rules(self): * 2020-05-01: :class:`LoadBalancerOutboundRulesOperations` * 2020-06-01: :class:`LoadBalancerOutboundRulesOperations` * 2020-07-01: :class:`LoadBalancerOutboundRulesOperations` + * 2020-08-01: :class:`LoadBalancerOutboundRulesOperations` """ api_version = self._get_api_version('load_balancer_outbound_rules') if api_version == '2018-08-01': @@ -3107,6 +3244,8 @@ def load_balancer_outbound_rules(self): from .v2020_06_01.operations import LoadBalancerOutboundRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerOutboundRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerOutboundRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_outbound_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3142,6 +3281,7 @@ def load_balancer_probes(self): * 2020-05-01: :class:`LoadBalancerProbesOperations` * 2020-06-01: :class:`LoadBalancerProbesOperations` * 2020-07-01: :class:`LoadBalancerProbesOperations` + * 2020-08-01: :class:`LoadBalancerProbesOperations` """ api_version = self._get_api_version('load_balancer_probes') if api_version == '2017-06-01': @@ -3198,6 +3338,8 @@ def load_balancer_probes(self): from .v2020_06_01.operations import LoadBalancerProbesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancerProbesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancerProbesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_probes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3237,6 +3379,7 @@ def load_balancers(self): * 2020-05-01: :class:`LoadBalancersOperations` * 2020-06-01: :class:`LoadBalancersOperations` * 2020-07-01: :class:`LoadBalancersOperations` + * 2020-08-01: :class:`LoadBalancersOperations` """ api_version = self._get_api_version('load_balancers') if api_version == '2015-06-15': @@ -3301,6 +3444,8 @@ def load_balancers(self): from .v2020_06_01.operations import LoadBalancersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LoadBalancersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LoadBalancersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3340,6 +3485,7 @@ def local_network_gateways(self): * 2020-05-01: :class:`LocalNetworkGatewaysOperations` * 2020-06-01: :class:`LocalNetworkGatewaysOperations` * 2020-07-01: :class:`LocalNetworkGatewaysOperations` + * 2020-08-01: :class:`LocalNetworkGatewaysOperations` """ api_version = self._get_api_version('local_network_gateways') if api_version == '2015-06-15': @@ -3404,6 +3550,8 @@ def local_network_gateways(self): from .v2020_06_01.operations import LocalNetworkGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import LocalNetworkGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import LocalNetworkGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'local_network_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3425,6 +3573,7 @@ def nat_gateways(self): * 2020-05-01: :class:`NatGatewaysOperations` * 2020-06-01: :class:`NatGatewaysOperations` * 2020-07-01: :class:`NatGatewaysOperations` + * 2020-08-01: :class:`NatGatewaysOperations` """ api_version = self._get_api_version('nat_gateways') if api_version == '2019-02-01': @@ -3453,10 +3602,25 @@ def nat_gateways(self): from .v2020_06_01.operations import NatGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NatGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NatGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'nat_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def nat_rules(self): + """Instance depends on the API version: + + * 2020-08-01: :class:`NatRulesOperations` + """ + api_version = self._get_api_version('nat_rules') + if api_version == '2020-08-01': + from .v2020_08_01.operations import NatRulesOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'nat_rules'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def network_interface_ip_configurations(self): """Instance depends on the API version: @@ -3488,6 +3652,7 @@ def network_interface_ip_configurations(self): * 2020-05-01: :class:`NetworkInterfaceIPConfigurationsOperations` * 2020-06-01: :class:`NetworkInterfaceIPConfigurationsOperations` * 2020-07-01: :class:`NetworkInterfaceIPConfigurationsOperations` + * 2020-08-01: :class:`NetworkInterfaceIPConfigurationsOperations` """ api_version = self._get_api_version('network_interface_ip_configurations') if api_version == '2017-06-01': @@ -3544,6 +3709,8 @@ def network_interface_ip_configurations(self): from .v2020_06_01.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_ip_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3579,6 +3746,7 @@ def network_interface_load_balancers(self): * 2020-05-01: :class:`NetworkInterfaceLoadBalancersOperations` * 2020-06-01: :class:`NetworkInterfaceLoadBalancersOperations` * 2020-07-01: :class:`NetworkInterfaceLoadBalancersOperations` + * 2020-08-01: :class:`NetworkInterfaceLoadBalancersOperations` """ api_version = self._get_api_version('network_interface_load_balancers') if api_version == '2017-06-01': @@ -3635,6 +3803,8 @@ def network_interface_load_balancers(self): from .v2020_06_01.operations import NetworkInterfaceLoadBalancersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkInterfaceLoadBalancersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkInterfaceLoadBalancersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_load_balancers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3660,6 +3830,7 @@ def network_interface_tap_configurations(self): * 2020-05-01: :class:`NetworkInterfaceTapConfigurationsOperations` * 2020-06-01: :class:`NetworkInterfaceTapConfigurationsOperations` * 2020-07-01: :class:`NetworkInterfaceTapConfigurationsOperations` + * 2020-08-01: :class:`NetworkInterfaceTapConfigurationsOperations` """ api_version = self._get_api_version('network_interface_tap_configurations') if api_version == '2018-08-01': @@ -3696,6 +3867,8 @@ def network_interface_tap_configurations(self): from .v2020_06_01.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_tap_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3735,6 +3908,7 @@ def network_interfaces(self): * 2020-05-01: :class:`NetworkInterfacesOperations` * 2020-06-01: :class:`NetworkInterfacesOperations` * 2020-07-01: :class:`NetworkInterfacesOperations` + * 2020-08-01: :class:`NetworkInterfacesOperations` """ api_version = self._get_api_version('network_interfaces') if api_version == '2015-06-15': @@ -3799,6 +3973,8 @@ def network_interfaces(self): from .v2020_06_01.operations import NetworkInterfacesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkInterfacesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkInterfacesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interfaces'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3824,6 +4000,7 @@ def network_profiles(self): * 2020-05-01: :class:`NetworkProfilesOperations` * 2020-06-01: :class:`NetworkProfilesOperations` * 2020-07-01: :class:`NetworkProfilesOperations` + * 2020-08-01: :class:`NetworkProfilesOperations` """ api_version = self._get_api_version('network_profiles') if api_version == '2018-08-01': @@ -3860,6 +4037,8 @@ def network_profiles(self): from .v2020_06_01.operations import NetworkProfilesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkProfilesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkProfilesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_profiles'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3899,6 +4078,7 @@ def network_security_groups(self): * 2020-05-01: :class:`NetworkSecurityGroupsOperations` * 2020-06-01: :class:`NetworkSecurityGroupsOperations` * 2020-07-01: :class:`NetworkSecurityGroupsOperations` + * 2020-08-01: :class:`NetworkSecurityGroupsOperations` """ api_version = self._get_api_version('network_security_groups') if api_version == '2015-06-15': @@ -3963,6 +4143,8 @@ def network_security_groups(self): from .v2020_06_01.operations import NetworkSecurityGroupsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkSecurityGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkSecurityGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_security_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3977,6 +4159,7 @@ def network_virtual_appliances(self): * 2020-05-01: :class:`NetworkVirtualAppliancesOperations` * 2020-06-01: :class:`NetworkVirtualAppliancesOperations` * 2020-07-01: :class:`NetworkVirtualAppliancesOperations` + * 2020-08-01: :class:`NetworkVirtualAppliancesOperations` """ api_version = self._get_api_version('network_virtual_appliances') if api_version == '2019-12-01': @@ -3991,6 +4174,8 @@ def network_virtual_appliances(self): from .v2020_06_01.operations import NetworkVirtualAppliancesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkVirtualAppliancesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkVirtualAppliancesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_virtual_appliances'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4029,6 +4214,7 @@ def network_watchers(self): * 2020-05-01: :class:`NetworkWatchersOperations` * 2020-06-01: :class:`NetworkWatchersOperations` * 2020-07-01: :class:`NetworkWatchersOperations` + * 2020-08-01: :class:`NetworkWatchersOperations` """ api_version = self._get_api_version('network_watchers') if api_version == '2016-09-01': @@ -4091,6 +4277,8 @@ def network_watchers(self): from .v2020_06_01.operations import NetworkWatchersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkWatchersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkWatchersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_watchers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4124,6 +4312,7 @@ def operations(self): * 2020-05-01: :class:`Operations` * 2020-06-01: :class:`Operations` * 2020-07-01: :class:`Operations` + * 2020-08-01: :class:`Operations` """ api_version = self._get_api_version('operations') if api_version == '2017-09-01': @@ -4176,6 +4365,8 @@ def operations(self): from .v2020_06_01.operations import Operations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import Operations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_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))) @@ -4201,6 +4392,7 @@ def p2_svpn_gateways(self): * 2020-05-01: :class:`P2SVpnGatewaysOperations` * 2020-06-01: :class:`P2SVpnGatewaysOperations` * 2020-07-01: :class:`P2SVpnGatewaysOperations` + * 2020-08-01: :class:`P2SVpnGatewaysOperations` """ api_version = self._get_api_version('p2_svpn_gateways') if api_version == '2018-08-01': @@ -4237,6 +4429,8 @@ def p2_svpn_gateways(self): from .v2020_06_01.operations import P2SVpnGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import P2SVpnGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import P2SVpnGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'p2_svpn_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4309,6 +4503,7 @@ def packet_captures(self): * 2020-05-01: :class:`PacketCapturesOperations` * 2020-06-01: :class:`PacketCapturesOperations` * 2020-07-01: :class:`PacketCapturesOperations` + * 2020-08-01: :class:`PacketCapturesOperations` """ api_version = self._get_api_version('packet_captures') if api_version == '2016-09-01': @@ -4371,6 +4566,8 @@ def packet_captures(self): from .v2020_06_01.operations import PacketCapturesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PacketCapturesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PacketCapturesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'packet_captures'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4393,6 +4590,7 @@ def peer_express_route_circuit_connections(self): * 2020-05-01: :class:`PeerExpressRouteCircuitConnectionsOperations` * 2020-06-01: :class:`PeerExpressRouteCircuitConnectionsOperations` * 2020-07-01: :class:`PeerExpressRouteCircuitConnectionsOperations` + * 2020-08-01: :class:`PeerExpressRouteCircuitConnectionsOperations` """ api_version = self._get_api_version('peer_express_route_circuit_connections') if api_version == '2018-12-01': @@ -4423,6 +4621,8 @@ def peer_express_route_circuit_connections(self): from .v2020_06_01.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'peer_express_route_circuit_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4436,6 +4636,7 @@ def private_dns_zone_groups(self): * 2020-05-01: :class:`PrivateDnsZoneGroupsOperations` * 2020-06-01: :class:`PrivateDnsZoneGroupsOperations` * 2020-07-01: :class:`PrivateDnsZoneGroupsOperations` + * 2020-08-01: :class:`PrivateDnsZoneGroupsOperations` """ api_version = self._get_api_version('private_dns_zone_groups') if api_version == '2020-03-01': @@ -4448,6 +4649,8 @@ def private_dns_zone_groups(self): from .v2020_06_01.operations import PrivateDnsZoneGroupsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PrivateDnsZoneGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PrivateDnsZoneGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_dns_zone_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4468,6 +4671,7 @@ def private_endpoints(self): * 2020-05-01: :class:`PrivateEndpointsOperations` * 2020-06-01: :class:`PrivateEndpointsOperations` * 2020-07-01: :class:`PrivateEndpointsOperations` + * 2020-08-01: :class:`PrivateEndpointsOperations` """ api_version = self._get_api_version('private_endpoints') if api_version == '2019-04-01': @@ -4494,6 +4698,8 @@ def private_endpoints(self): from .v2020_06_01.operations import PrivateEndpointsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PrivateEndpointsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PrivateEndpointsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_endpoints'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4514,6 +4720,7 @@ def private_link_services(self): * 2020-05-01: :class:`PrivateLinkServicesOperations` * 2020-06-01: :class:`PrivateLinkServicesOperations` * 2020-07-01: :class:`PrivateLinkServicesOperations` + * 2020-08-01: :class:`PrivateLinkServicesOperations` """ api_version = self._get_api_version('private_link_services') if api_version == '2019-04-01': @@ -4540,6 +4747,8 @@ def private_link_services(self): from .v2020_06_01.operations import PrivateLinkServicesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PrivateLinkServicesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PrivateLinkServicesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_link_services'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4579,6 +4788,7 @@ def public_ip_addresses(self): * 2020-05-01: :class:`PublicIPAddressesOperations` * 2020-06-01: :class:`PublicIPAddressesOperations` * 2020-07-01: :class:`PublicIPAddressesOperations` + * 2020-08-01: :class:`PublicIPAddressesOperations` """ api_version = self._get_api_version('public_ip_addresses') if api_version == '2015-06-15': @@ -4643,6 +4853,8 @@ def public_ip_addresses(self): from .v2020_06_01.operations import PublicIPAddressesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PublicIPAddressesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PublicIPAddressesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'public_ip_addresses'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4669,6 +4881,7 @@ def public_ip_prefixes(self): * 2020-05-01: :class:`PublicIPPrefixesOperations` * 2020-06-01: :class:`PublicIPPrefixesOperations` * 2020-07-01: :class:`PublicIPPrefixesOperations` + * 2020-08-01: :class:`PublicIPPrefixesOperations` """ api_version = self._get_api_version('public_ip_prefixes') if api_version == '2018-07-01': @@ -4707,6 +4920,8 @@ def public_ip_prefixes(self): from .v2020_06_01.operations import PublicIPPrefixesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import PublicIPPrefixesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import PublicIPPrefixesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'public_ip_prefixes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4728,6 +4943,7 @@ def resource_navigation_links(self): * 2020-05-01: :class:`ResourceNavigationLinksOperations` * 2020-06-01: :class:`ResourceNavigationLinksOperations` * 2020-07-01: :class:`ResourceNavigationLinksOperations` + * 2020-08-01: :class:`ResourceNavigationLinksOperations` """ api_version = self._get_api_version('resource_navigation_links') if api_version == '2019-02-01': @@ -4756,6 +4972,8 @@ def resource_navigation_links(self): from .v2020_06_01.operations import ResourceNavigationLinksOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ResourceNavigationLinksOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ResourceNavigationLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_navigation_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4793,6 +5011,7 @@ def route_filter_rules(self): * 2020-05-01: :class:`RouteFilterRulesOperations` * 2020-06-01: :class:`RouteFilterRulesOperations` * 2020-07-01: :class:`RouteFilterRulesOperations` + * 2020-08-01: :class:`RouteFilterRulesOperations` """ api_version = self._get_api_version('route_filter_rules') if api_version == '2016-12-01': @@ -4853,6 +5072,8 @@ def route_filter_rules(self): from .v2020_06_01.operations import RouteFilterRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import RouteFilterRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import RouteFilterRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_filter_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4890,6 +5111,7 @@ def route_filters(self): * 2020-05-01: :class:`RouteFiltersOperations` * 2020-06-01: :class:`RouteFiltersOperations` * 2020-07-01: :class:`RouteFiltersOperations` + * 2020-08-01: :class:`RouteFiltersOperations` """ api_version = self._get_api_version('route_filters') if api_version == '2016-12-01': @@ -4950,6 +5172,8 @@ def route_filters(self): from .v2020_06_01.operations import RouteFiltersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import RouteFiltersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import RouteFiltersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_filters'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4989,6 +5213,7 @@ def route_tables(self): * 2020-05-01: :class:`RouteTablesOperations` * 2020-06-01: :class:`RouteTablesOperations` * 2020-07-01: :class:`RouteTablesOperations` + * 2020-08-01: :class:`RouteTablesOperations` """ api_version = self._get_api_version('route_tables') if api_version == '2015-06-15': @@ -5053,6 +5278,8 @@ def route_tables(self): from .v2020_06_01.operations import RouteTablesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import RouteTablesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import RouteTablesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_tables'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5092,6 +5319,7 @@ def routes(self): * 2020-05-01: :class:`RoutesOperations` * 2020-06-01: :class:`RoutesOperations` * 2020-07-01: :class:`RoutesOperations` + * 2020-08-01: :class:`RoutesOperations` """ api_version = self._get_api_version('routes') if api_version == '2015-06-15': @@ -5156,6 +5384,8 @@ def routes(self): from .v2020_06_01.operations import RoutesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import RoutesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import RoutesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'routes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5169,6 +5399,7 @@ def security_partner_providers(self): * 2020-05-01: :class:`SecurityPartnerProvidersOperations` * 2020-06-01: :class:`SecurityPartnerProvidersOperations` * 2020-07-01: :class:`SecurityPartnerProvidersOperations` + * 2020-08-01: :class:`SecurityPartnerProvidersOperations` """ api_version = self._get_api_version('security_partner_providers') if api_version == '2020-03-01': @@ -5181,6 +5412,8 @@ def security_partner_providers(self): from .v2020_06_01.operations import SecurityPartnerProvidersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import SecurityPartnerProvidersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import SecurityPartnerProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'security_partner_providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5220,6 +5453,7 @@ def security_rules(self): * 2020-05-01: :class:`SecurityRulesOperations` * 2020-06-01: :class:`SecurityRulesOperations` * 2020-07-01: :class:`SecurityRulesOperations` + * 2020-08-01: :class:`SecurityRulesOperations` """ api_version = self._get_api_version('security_rules') if api_version == '2015-06-15': @@ -5284,6 +5518,8 @@ def security_rules(self): from .v2020_06_01.operations import SecurityRulesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import SecurityRulesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import SecurityRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'security_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5305,6 +5541,7 @@ def service_association_links(self): * 2020-05-01: :class:`ServiceAssociationLinksOperations` * 2020-06-01: :class:`ServiceAssociationLinksOperations` * 2020-07-01: :class:`ServiceAssociationLinksOperations` + * 2020-08-01: :class:`ServiceAssociationLinksOperations` """ api_version = self._get_api_version('service_association_links') if api_version == '2019-02-01': @@ -5333,6 +5570,8 @@ def service_association_links(self): from .v2020_06_01.operations import ServiceAssociationLinksOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ServiceAssociationLinksOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ServiceAssociationLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_association_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5359,6 +5598,7 @@ def service_endpoint_policies(self): * 2020-05-01: :class:`ServiceEndpointPoliciesOperations` * 2020-06-01: :class:`ServiceEndpointPoliciesOperations` * 2020-07-01: :class:`ServiceEndpointPoliciesOperations` + * 2020-08-01: :class:`ServiceEndpointPoliciesOperations` """ api_version = self._get_api_version('service_endpoint_policies') if api_version == '2018-07-01': @@ -5397,6 +5637,8 @@ def service_endpoint_policies(self): from .v2020_06_01.operations import ServiceEndpointPoliciesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ServiceEndpointPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ServiceEndpointPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_endpoint_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5423,6 +5665,7 @@ def service_endpoint_policy_definitions(self): * 2020-05-01: :class:`ServiceEndpointPolicyDefinitionsOperations` * 2020-06-01: :class:`ServiceEndpointPolicyDefinitionsOperations` * 2020-07-01: :class:`ServiceEndpointPolicyDefinitionsOperations` + * 2020-08-01: :class:`ServiceEndpointPolicyDefinitionsOperations` """ api_version = self._get_api_version('service_endpoint_policy_definitions') if api_version == '2018-07-01': @@ -5461,6 +5704,8 @@ def service_endpoint_policy_definitions(self): from .v2020_06_01.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_endpoint_policy_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5481,6 +5726,7 @@ def service_tags(self): * 2020-05-01: :class:`ServiceTagsOperations` * 2020-06-01: :class:`ServiceTagsOperations` * 2020-07-01: :class:`ServiceTagsOperations` + * 2020-08-01: :class:`ServiceTagsOperations` """ api_version = self._get_api_version('service_tags') if api_version == '2019-04-01': @@ -5507,6 +5753,8 @@ def service_tags(self): from .v2020_06_01.operations import ServiceTagsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import ServiceTagsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import ServiceTagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5546,6 +5794,7 @@ def subnets(self): * 2020-05-01: :class:`SubnetsOperations` * 2020-06-01: :class:`SubnetsOperations` * 2020-07-01: :class:`SubnetsOperations` + * 2020-08-01: :class:`SubnetsOperations` """ api_version = self._get_api_version('subnets') if api_version == '2015-06-15': @@ -5610,6 +5859,8 @@ def subnets(self): from .v2020_06_01.operations import SubnetsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import SubnetsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import SubnetsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'subnets'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5649,6 +5900,7 @@ def usages(self): * 2020-05-01: :class:`UsagesOperations` * 2020-06-01: :class:`UsagesOperations` * 2020-07-01: :class:`UsagesOperations` + * 2020-08-01: :class:`UsagesOperations` """ api_version = self._get_api_version('usages') if api_version == '2015-06-15': @@ -5713,6 +5965,8 @@ def usages(self): from .v2020_06_01.operations import UsagesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import UsagesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import UsagesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'usages'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5724,6 +5978,7 @@ def virtual_appliance_sites(self): * 2020-05-01: :class:`VirtualApplianceSitesOperations` * 2020-06-01: :class:`VirtualApplianceSitesOperations` * 2020-07-01: :class:`VirtualApplianceSitesOperations` + * 2020-08-01: :class:`VirtualApplianceSitesOperations` """ api_version = self._get_api_version('virtual_appliance_sites') if api_version == '2020-05-01': @@ -5732,6 +5987,8 @@ def virtual_appliance_sites(self): from .v2020_06_01.operations import VirtualApplianceSitesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualApplianceSitesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualApplianceSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_appliance_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5743,6 +6000,7 @@ def virtual_appliance_skus(self): * 2020-05-01: :class:`VirtualApplianceSkusOperations` * 2020-06-01: :class:`VirtualApplianceSkusOperations` * 2020-07-01: :class:`VirtualApplianceSkusOperations` + * 2020-08-01: :class:`VirtualApplianceSkusOperations` """ api_version = self._get_api_version('virtual_appliance_skus') if api_version == '2020-05-01': @@ -5751,6 +6009,8 @@ def virtual_appliance_skus(self): from .v2020_06_01.operations import VirtualApplianceSkusOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualApplianceSkusOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualApplianceSkusOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_appliance_skus'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5762,6 +6022,7 @@ def virtual_hub_bgp_connection(self): * 2020-05-01: :class:`VirtualHubBgpConnectionOperations` * 2020-06-01: :class:`VirtualHubBgpConnectionOperations` * 2020-07-01: :class:`VirtualHubBgpConnectionOperations` + * 2020-08-01: :class:`VirtualHubBgpConnectionOperations` """ api_version = self._get_api_version('virtual_hub_bgp_connection') if api_version == '2020-05-01': @@ -5770,6 +6031,8 @@ def virtual_hub_bgp_connection(self): from .v2020_06_01.operations import VirtualHubBgpConnectionOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualHubBgpConnectionOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualHubBgpConnectionOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_bgp_connection'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5781,6 +6044,7 @@ def virtual_hub_bgp_connections(self): * 2020-05-01: :class:`VirtualHubBgpConnectionsOperations` * 2020-06-01: :class:`VirtualHubBgpConnectionsOperations` * 2020-07-01: :class:`VirtualHubBgpConnectionsOperations` + * 2020-08-01: :class:`VirtualHubBgpConnectionsOperations` """ api_version = self._get_api_version('virtual_hub_bgp_connections') if api_version == '2020-05-01': @@ -5789,6 +6053,8 @@ def virtual_hub_bgp_connections(self): from .v2020_06_01.operations import VirtualHubBgpConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualHubBgpConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualHubBgpConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_bgp_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5800,6 +6066,7 @@ def virtual_hub_ip_configuration(self): * 2020-05-01: :class:`VirtualHubIpConfigurationOperations` * 2020-06-01: :class:`VirtualHubIpConfigurationOperations` * 2020-07-01: :class:`VirtualHubIpConfigurationOperations` + * 2020-08-01: :class:`VirtualHubIpConfigurationOperations` """ api_version = self._get_api_version('virtual_hub_ip_configuration') if api_version == '2020-05-01': @@ -5808,6 +6075,8 @@ def virtual_hub_ip_configuration(self): from .v2020_06_01.operations import VirtualHubIpConfigurationOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualHubIpConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualHubIpConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_ip_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5824,6 +6093,7 @@ def virtual_hub_route_table_v2_s(self): * 2020-05-01: :class:`VirtualHubRouteTableV2SOperations` * 2020-06-01: :class:`VirtualHubRouteTableV2SOperations` * 2020-07-01: :class:`VirtualHubRouteTableV2SOperations` + * 2020-08-01: :class:`VirtualHubRouteTableV2SOperations` """ api_version = self._get_api_version('virtual_hub_route_table_v2_s') if api_version == '2019-09-01': @@ -5842,6 +6112,8 @@ def virtual_hub_route_table_v2_s(self): from .v2020_06_01.operations import VirtualHubRouteTableV2SOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualHubRouteTableV2SOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualHubRouteTableV2SOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_route_table_v2_s'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5870,6 +6142,7 @@ def virtual_hubs(self): * 2020-05-01: :class:`VirtualHubsOperations` * 2020-06-01: :class:`VirtualHubsOperations` * 2020-07-01: :class:`VirtualHubsOperations` + * 2020-08-01: :class:`VirtualHubsOperations` """ api_version = self._get_api_version('virtual_hubs') if api_version == '2018-04-01': @@ -5912,6 +6185,8 @@ def virtual_hubs(self): from .v2020_06_01.operations import VirtualHubsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualHubsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualHubsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hubs'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5951,6 +6226,7 @@ def virtual_network_gateway_connections(self): * 2020-05-01: :class:`VirtualNetworkGatewayConnectionsOperations` * 2020-06-01: :class:`VirtualNetworkGatewayConnectionsOperations` * 2020-07-01: :class:`VirtualNetworkGatewayConnectionsOperations` + * 2020-08-01: :class:`VirtualNetworkGatewayConnectionsOperations` """ api_version = self._get_api_version('virtual_network_gateway_connections') if api_version == '2015-06-15': @@ -6015,6 +6291,8 @@ def virtual_network_gateway_connections(self): from .v2020_06_01.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_gateway_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6054,6 +6332,7 @@ def virtual_network_gateways(self): * 2020-05-01: :class:`VirtualNetworkGatewaysOperations` * 2020-06-01: :class:`VirtualNetworkGatewaysOperations` * 2020-07-01: :class:`VirtualNetworkGatewaysOperations` + * 2020-08-01: :class:`VirtualNetworkGatewaysOperations` """ api_version = self._get_api_version('virtual_network_gateways') if api_version == '2015-06-15': @@ -6118,6 +6397,8 @@ def virtual_network_gateways(self): from .v2020_06_01.operations import VirtualNetworkGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualNetworkGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualNetworkGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6156,6 +6437,7 @@ def virtual_network_peerings(self): * 2020-05-01: :class:`VirtualNetworkPeeringsOperations` * 2020-06-01: :class:`VirtualNetworkPeeringsOperations` * 2020-07-01: :class:`VirtualNetworkPeeringsOperations` + * 2020-08-01: :class:`VirtualNetworkPeeringsOperations` """ api_version = self._get_api_version('virtual_network_peerings') if api_version == '2016-09-01': @@ -6218,6 +6500,8 @@ def virtual_network_peerings(self): from .v2020_06_01.operations import VirtualNetworkPeeringsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualNetworkPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualNetworkPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6243,6 +6527,7 @@ def virtual_network_taps(self): * 2020-05-01: :class:`VirtualNetworkTapsOperations` * 2020-06-01: :class:`VirtualNetworkTapsOperations` * 2020-07-01: :class:`VirtualNetworkTapsOperations` + * 2020-08-01: :class:`VirtualNetworkTapsOperations` """ api_version = self._get_api_version('virtual_network_taps') if api_version == '2018-08-01': @@ -6279,6 +6564,8 @@ def virtual_network_taps(self): from .v2020_06_01.operations import VirtualNetworkTapsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualNetworkTapsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualNetworkTapsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_taps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6318,6 +6605,7 @@ def virtual_networks(self): * 2020-05-01: :class:`VirtualNetworksOperations` * 2020-06-01: :class:`VirtualNetworksOperations` * 2020-07-01: :class:`VirtualNetworksOperations` + * 2020-08-01: :class:`VirtualNetworksOperations` """ api_version = self._get_api_version('virtual_networks') if api_version == '2015-06-15': @@ -6382,6 +6670,8 @@ def virtual_networks(self): from .v2020_06_01.operations import VirtualNetworksOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualNetworksOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualNetworksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_networks'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6400,6 +6690,7 @@ def virtual_router_peerings(self): * 2020-05-01: :class:`VirtualRouterPeeringsOperations` * 2020-06-01: :class:`VirtualRouterPeeringsOperations` * 2020-07-01: :class:`VirtualRouterPeeringsOperations` + * 2020-08-01: :class:`VirtualRouterPeeringsOperations` """ api_version = self._get_api_version('virtual_router_peerings') if api_version == '2019-07-01': @@ -6422,6 +6713,8 @@ def virtual_router_peerings(self): from .v2020_06_01.operations import VirtualRouterPeeringsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualRouterPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualRouterPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_router_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6440,6 +6733,7 @@ def virtual_routers(self): * 2020-05-01: :class:`VirtualRoutersOperations` * 2020-06-01: :class:`VirtualRoutersOperations` * 2020-07-01: :class:`VirtualRoutersOperations` + * 2020-08-01: :class:`VirtualRoutersOperations` """ api_version = self._get_api_version('virtual_routers') if api_version == '2019-07-01': @@ -6462,6 +6756,8 @@ def virtual_routers(self): from .v2020_06_01.operations import VirtualRoutersOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualRoutersOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualRoutersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_routers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6490,6 +6786,7 @@ def virtual_wans(self): * 2020-05-01: :class:`VirtualWansOperations` * 2020-06-01: :class:`VirtualWansOperations` * 2020-07-01: :class:`VirtualWansOperations` + * 2020-08-01: :class:`VirtualWansOperations` """ api_version = self._get_api_version('virtual_wans') if api_version == '2018-04-01': @@ -6532,6 +6829,8 @@ def virtual_wans(self): from .v2020_06_01.operations import VirtualWansOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VirtualWansOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VirtualWansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_wans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6560,6 +6859,7 @@ def vpn_connections(self): * 2020-05-01: :class:`VpnConnectionsOperations` * 2020-06-01: :class:`VpnConnectionsOperations` * 2020-07-01: :class:`VpnConnectionsOperations` + * 2020-08-01: :class:`VpnConnectionsOperations` """ api_version = self._get_api_version('vpn_connections') if api_version == '2018-04-01': @@ -6602,6 +6902,8 @@ def vpn_connections(self): from .v2020_06_01.operations import VpnConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6630,6 +6932,7 @@ def vpn_gateways(self): * 2020-05-01: :class:`VpnGatewaysOperations` * 2020-06-01: :class:`VpnGatewaysOperations` * 2020-07-01: :class:`VpnGatewaysOperations` + * 2020-08-01: :class:`VpnGatewaysOperations` """ api_version = self._get_api_version('vpn_gateways') if api_version == '2018-04-01': @@ -6672,6 +6975,8 @@ def vpn_gateways(self): from .v2020_06_01.operations import VpnGatewaysOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6691,6 +6996,7 @@ def vpn_link_connections(self): * 2020-05-01: :class:`VpnLinkConnectionsOperations` * 2020-06-01: :class:`VpnLinkConnectionsOperations` * 2020-07-01: :class:`VpnLinkConnectionsOperations` + * 2020-08-01: :class:`VpnLinkConnectionsOperations` """ api_version = self._get_api_version('vpn_link_connections') if api_version == '2019-06-01': @@ -6715,6 +7021,8 @@ def vpn_link_connections(self): from .v2020_06_01.operations import VpnLinkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnLinkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnLinkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_link_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6732,6 +7040,7 @@ def vpn_server_configurations(self): * 2020-05-01: :class:`VpnServerConfigurationsOperations` * 2020-06-01: :class:`VpnServerConfigurationsOperations` * 2020-07-01: :class:`VpnServerConfigurationsOperations` + * 2020-08-01: :class:`VpnServerConfigurationsOperations` """ api_version = self._get_api_version('vpn_server_configurations') if api_version == '2019-08-01': @@ -6752,6 +7061,8 @@ def vpn_server_configurations(self): from .v2020_06_01.operations import VpnServerConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnServerConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnServerConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_server_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6769,6 +7080,7 @@ def vpn_server_configurations_associated_with_virtual_wan(self): * 2020-05-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` * 2020-06-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` * 2020-07-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` + * 2020-08-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` """ api_version = self._get_api_version('vpn_server_configurations_associated_with_virtual_wan') if api_version == '2019-08-01': @@ -6789,6 +7101,8 @@ def vpn_server_configurations_associated_with_virtual_wan(self): from .v2020_06_01.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_server_configurations_associated_with_virtual_wan'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6808,6 +7122,7 @@ def vpn_site_link_connections(self): * 2020-05-01: :class:`VpnSiteLinkConnectionsOperations` * 2020-06-01: :class:`VpnSiteLinkConnectionsOperations` * 2020-07-01: :class:`VpnSiteLinkConnectionsOperations` + * 2020-08-01: :class:`VpnSiteLinkConnectionsOperations` """ api_version = self._get_api_version('vpn_site_link_connections') if api_version == '2019-06-01': @@ -6832,6 +7147,8 @@ def vpn_site_link_connections(self): from .v2020_06_01.operations import VpnSiteLinkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnSiteLinkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnSiteLinkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_site_link_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6851,6 +7168,7 @@ def vpn_site_links(self): * 2020-05-01: :class:`VpnSiteLinksOperations` * 2020-06-01: :class:`VpnSiteLinksOperations` * 2020-07-01: :class:`VpnSiteLinksOperations` + * 2020-08-01: :class:`VpnSiteLinksOperations` """ api_version = self._get_api_version('vpn_site_links') if api_version == '2019-06-01': @@ -6875,6 +7193,8 @@ def vpn_site_links(self): from .v2020_06_01.operations import VpnSiteLinksOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnSiteLinksOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnSiteLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_site_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6903,6 +7223,7 @@ def vpn_sites(self): * 2020-05-01: :class:`VpnSitesOperations` * 2020-06-01: :class:`VpnSitesOperations` * 2020-07-01: :class:`VpnSitesOperations` + * 2020-08-01: :class:`VpnSitesOperations` """ api_version = self._get_api_version('vpn_sites') if api_version == '2018-04-01': @@ -6945,6 +7266,8 @@ def vpn_sites(self): from .v2020_06_01.operations import VpnSitesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnSitesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6973,6 +7296,7 @@ def vpn_sites_configuration(self): * 2020-05-01: :class:`VpnSitesConfigurationOperations` * 2020-06-01: :class:`VpnSitesConfigurationOperations` * 2020-07-01: :class:`VpnSitesConfigurationOperations` + * 2020-08-01: :class:`VpnSitesConfigurationOperations` """ api_version = self._get_api_version('vpn_sites_configuration') if api_version == '2018-04-01': @@ -7015,6 +7339,8 @@ def vpn_sites_configuration(self): from .v2020_06_01.operations import VpnSitesConfigurationOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import VpnSitesConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import VpnSitesConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_sites_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -7037,6 +7363,7 @@ def web_application_firewall_policies(self): * 2020-05-01: :class:`WebApplicationFirewallPoliciesOperations` * 2020-06-01: :class:`WebApplicationFirewallPoliciesOperations` * 2020-07-01: :class:`WebApplicationFirewallPoliciesOperations` + * 2020-08-01: :class:`WebApplicationFirewallPoliciesOperations` """ api_version = self._get_api_version('web_application_firewall_policies') if api_version == '2018-12-01': @@ -7067,6 +7394,8 @@ def web_application_firewall_policies(self): from .v2020_06_01.operations import WebApplicationFirewallPoliciesOperations as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import WebApplicationFirewallPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import WebApplicationFirewallPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_application_firewall_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -7076,10 +7405,13 @@ def web_categories(self): """Instance depends on the API version: * 2020-07-01: :class:`WebCategoriesOperations` + * 2020-08-01: :class:`WebCategoriesOperations` """ api_version = self._get_api_version('web_categories') if api_version == '2020-07-01': from .v2020_07_01.operations import WebCategoriesOperations as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import WebCategoriesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_categories'".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/network/azure-mgmt-network/azure/mgmt/network/_operations_mixin.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/_operations_mixin.py index 5862e74a3b08..e562f28b3ff0 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/_operations_mixin.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/_operations_mixin.py @@ -41,7 +41,7 @@ def begin_delete_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -69,6 +69,8 @@ def begin_delete_bastion_shareable_link( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_delete_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -95,7 +97,7 @@ def begin_generatevirtualwanvpnserverconfigurationvpnprofile( :type virtual_wan_name: str :param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation operation. - :type vpn_client_params: ~azure.mgmt.network.v2020_07_01.models.VirtualWanVpnProfileParameters + :type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -103,7 +105,7 @@ def begin_generatevirtualwanvpnserverconfigurationvpnprofile( :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 VpnProfileResponse or the result of cls(response) - :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_07_01.models.VpnProfileResponse] + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_generatevirtualwanvpnserverconfigurationvpnprofile') @@ -125,6 +127,8 @@ def begin_generatevirtualwanvpnserverconfigurationvpnprofile( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_generatevirtualwanvpnserverconfigurationvpnprofile'".format(api_version)) mixin_instance = OperationClass() @@ -153,7 +157,7 @@ def begin_get_active_sessions( :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 BastionActiveSessionListResult or the result of cls(response) - :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionActiveSessionListResult]] + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_get_active_sessions') @@ -173,6 +177,8 @@ def begin_get_active_sessions( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_get_active_sessions'".format(api_version)) mixin_instance = OperationClass() @@ -196,7 +202,7 @@ def begin_put_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -204,7 +210,7 @@ def begin_put_bastion_shareable_link( :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 BastionShareableLinkListResult or the result of cls(response) - :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListResult]] + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_put_bastion_shareable_link') @@ -224,6 +230,8 @@ def begin_put_bastion_shareable_link( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_put_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -248,7 +256,7 @@ def check_dns_name_availability( :type domain_name_label: str :keyword callable cls: A custom type or function that will be passed the direct response :return: DnsNameAvailabilityResult, or the result of cls(response) - :rtype: ~azure.mgmt.network.v2020_07_01.models.DnsNameAvailabilityResult + :rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('check_dns_name_availability') @@ -314,6 +322,8 @@ def check_dns_name_availability( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'check_dns_name_availability'".format(api_version)) mixin_instance = OperationClass() @@ -337,10 +347,10 @@ def disconnect_active_sessions( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param session_ids: The list of sessionids to disconnect. - :type session_ids: ~azure.mgmt.network.v2020_07_01.models.SessionIds + :type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionSessionDeleteResult] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('disconnect_active_sessions') @@ -360,6 +370,8 @@ def disconnect_active_sessions( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'disconnect_active_sessions'".format(api_version)) mixin_instance = OperationClass() @@ -383,10 +395,10 @@ def get_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListResult] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_bastion_shareable_link') @@ -406,6 +418,8 @@ def get_bastion_shareable_link( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -430,7 +444,7 @@ def supported_security_providers( :type virtual_wan_name: str :keyword callable cls: A custom type or function that will be passed the direct response :return: VirtualWanSecurityProviders, or the result of cls(response) - :rtype: ~azure.mgmt.network.v2020_07_01.models.VirtualWanSecurityProviders + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('supported_security_providers') @@ -468,6 +482,8 @@ def supported_security_providers( from .v2020_06_01.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from .v2020_07_01.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from .v2020_08_01.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'supported_security_providers'".format(api_version)) mixin_instance = OperationClass() diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/_version.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/_version.py index b039214e161b..653cbbf320da 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/_version.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "17.0.0" \ No newline at end of file +VERSION = "17.1.0" diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_network_management_client.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_network_management_client.py index 462307ac1184..e7983a20856b 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_network_management_client.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_network_management_client.py @@ -46,7 +46,7 @@ class NetworkManagementClient(NetworkManagementClientOperationsMixin, MultiApiCl :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2020-07-01' + DEFAULT_API_VERSION = '2020-08-01' _PROFILE_TAG = "azure.mgmt.network.NetworkManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -115,6 +115,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2020-05-01: :mod:`v2020_05_01.models` * 2020-06-01: :mod:`v2020_06_01.models` * 2020-07-01: :mod:`v2020_07_01.models` + * 2020-08-01: :mod:`v2020_08_01.models` """ if api_version == '2015-06-15': from ..v2015_06_15 import models @@ -209,6 +210,9 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2020-07-01': from ..v2020_07_01 import models return models + elif api_version == '2020-08-01': + from ..v2020_08_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -218,6 +222,7 @@ def application_gateway_private_endpoint_connections(self): * 2020-05-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` * 2020-06-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` * 2020-07-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` + * 2020-08-01: :class:`ApplicationGatewayPrivateEndpointConnectionsOperations` """ api_version = self._get_api_version('application_gateway_private_endpoint_connections') if api_version == '2020-05-01': @@ -226,6 +231,8 @@ def application_gateway_private_endpoint_connections(self): from ..v2020_06_01.aio.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ApplicationGatewayPrivateEndpointConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateway_private_endpoint_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -237,6 +244,7 @@ def application_gateway_private_link_resources(self): * 2020-05-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` * 2020-06-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` * 2020-07-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` + * 2020-08-01: :class:`ApplicationGatewayPrivateLinkResourcesOperations` """ api_version = self._get_api_version('application_gateway_private_link_resources') if api_version == '2020-05-01': @@ -245,6 +253,8 @@ def application_gateway_private_link_resources(self): from ..v2020_06_01.aio.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ApplicationGatewayPrivateLinkResourcesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateway_private_link_resources'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -284,6 +294,7 @@ def application_gateways(self): * 2020-05-01: :class:`ApplicationGatewaysOperations` * 2020-06-01: :class:`ApplicationGatewaysOperations` * 2020-07-01: :class:`ApplicationGatewaysOperations` + * 2020-08-01: :class:`ApplicationGatewaysOperations` """ api_version = self._get_api_version('application_gateways') if api_version == '2015-06-15': @@ -348,6 +359,8 @@ def application_gateways(self): from ..v2020_06_01.aio.operations import ApplicationGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ApplicationGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ApplicationGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -381,6 +394,7 @@ def application_security_groups(self): * 2020-05-01: :class:`ApplicationSecurityGroupsOperations` * 2020-06-01: :class:`ApplicationSecurityGroupsOperations` * 2020-07-01: :class:`ApplicationSecurityGroupsOperations` + * 2020-08-01: :class:`ApplicationSecurityGroupsOperations` """ api_version = self._get_api_version('application_security_groups') if api_version == '2017-09-01': @@ -433,6 +447,8 @@ def application_security_groups(self): from ..v2020_06_01.aio.operations import ApplicationSecurityGroupsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ApplicationSecurityGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ApplicationSecurityGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'application_security_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -458,6 +474,7 @@ def available_delegations(self): * 2020-05-01: :class:`AvailableDelegationsOperations` * 2020-06-01: :class:`AvailableDelegationsOperations` * 2020-07-01: :class:`AvailableDelegationsOperations` + * 2020-08-01: :class:`AvailableDelegationsOperations` """ api_version = self._get_api_version('available_delegations') if api_version == '2018-08-01': @@ -494,6 +511,8 @@ def available_delegations(self): from ..v2020_06_01.aio.operations import AvailableDelegationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AvailableDelegationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AvailableDelegationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_delegations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -529,6 +548,7 @@ def available_endpoint_services(self): * 2020-05-01: :class:`AvailableEndpointServicesOperations` * 2020-06-01: :class:`AvailableEndpointServicesOperations` * 2020-07-01: :class:`AvailableEndpointServicesOperations` + * 2020-08-01: :class:`AvailableEndpointServicesOperations` """ api_version = self._get_api_version('available_endpoint_services') if api_version == '2017-06-01': @@ -585,6 +605,8 @@ def available_endpoint_services(self): from ..v2020_06_01.aio.operations import AvailableEndpointServicesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AvailableEndpointServicesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AvailableEndpointServicesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_endpoint_services'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -605,6 +627,7 @@ def available_private_endpoint_types(self): * 2020-05-01: :class:`AvailablePrivateEndpointTypesOperations` * 2020-06-01: :class:`AvailablePrivateEndpointTypesOperations` * 2020-07-01: :class:`AvailablePrivateEndpointTypesOperations` + * 2020-08-01: :class:`AvailablePrivateEndpointTypesOperations` """ api_version = self._get_api_version('available_private_endpoint_types') if api_version == '2019-04-01': @@ -631,6 +654,8 @@ def available_private_endpoint_types(self): from ..v2020_06_01.aio.operations import AvailablePrivateEndpointTypesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AvailablePrivateEndpointTypesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AvailablePrivateEndpointTypesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_private_endpoint_types'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -656,6 +681,7 @@ def available_resource_group_delegations(self): * 2020-05-01: :class:`AvailableResourceGroupDelegationsOperations` * 2020-06-01: :class:`AvailableResourceGroupDelegationsOperations` * 2020-07-01: :class:`AvailableResourceGroupDelegationsOperations` + * 2020-08-01: :class:`AvailableResourceGroupDelegationsOperations` """ api_version = self._get_api_version('available_resource_group_delegations') if api_version == '2018-08-01': @@ -692,6 +718,8 @@ def available_resource_group_delegations(self): from ..v2020_06_01.aio.operations import AvailableResourceGroupDelegationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AvailableResourceGroupDelegationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AvailableResourceGroupDelegationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_resource_group_delegations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -709,6 +737,7 @@ def available_service_aliases(self): * 2020-05-01: :class:`AvailableServiceAliasesOperations` * 2020-06-01: :class:`AvailableServiceAliasesOperations` * 2020-07-01: :class:`AvailableServiceAliasesOperations` + * 2020-08-01: :class:`AvailableServiceAliasesOperations` """ api_version = self._get_api_version('available_service_aliases') if api_version == '2019-08-01': @@ -729,6 +758,8 @@ def available_service_aliases(self): from ..v2020_06_01.aio.operations import AvailableServiceAliasesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AvailableServiceAliasesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AvailableServiceAliasesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'available_service_aliases'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -754,6 +785,7 @@ def azure_firewall_fqdn_tags(self): * 2020-05-01: :class:`AzureFirewallFqdnTagsOperations` * 2020-06-01: :class:`AzureFirewallFqdnTagsOperations` * 2020-07-01: :class:`AzureFirewallFqdnTagsOperations` + * 2020-08-01: :class:`AzureFirewallFqdnTagsOperations` """ api_version = self._get_api_version('azure_firewall_fqdn_tags') if api_version == '2018-08-01': @@ -790,6 +822,8 @@ def azure_firewall_fqdn_tags(self): from ..v2020_06_01.aio.operations import AzureFirewallFqdnTagsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AzureFirewallFqdnTagsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AzureFirewallFqdnTagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'azure_firewall_fqdn_tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -818,6 +852,7 @@ def azure_firewalls(self): * 2020-05-01: :class:`AzureFirewallsOperations` * 2020-06-01: :class:`AzureFirewallsOperations` * 2020-07-01: :class:`AzureFirewallsOperations` + * 2020-08-01: :class:`AzureFirewallsOperations` """ api_version = self._get_api_version('azure_firewalls') if api_version == '2018-04-01': @@ -860,6 +895,8 @@ def azure_firewalls(self): from ..v2020_06_01.aio.operations import AzureFirewallsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import AzureFirewallsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import AzureFirewallsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'azure_firewalls'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -880,6 +917,7 @@ def bastion_hosts(self): * 2020-05-01: :class:`BastionHostsOperations` * 2020-06-01: :class:`BastionHostsOperations` * 2020-07-01: :class:`BastionHostsOperations` + * 2020-08-01: :class:`BastionHostsOperations` """ api_version = self._get_api_version('bastion_hosts') if api_version == '2019-04-01': @@ -906,6 +944,8 @@ def bastion_hosts(self): from ..v2020_06_01.aio.operations import BastionHostsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import BastionHostsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import BastionHostsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'bastion_hosts'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -943,6 +983,7 @@ def bgp_service_communities(self): * 2020-05-01: :class:`BgpServiceCommunitiesOperations` * 2020-06-01: :class:`BgpServiceCommunitiesOperations` * 2020-07-01: :class:`BgpServiceCommunitiesOperations` + * 2020-08-01: :class:`BgpServiceCommunitiesOperations` """ api_version = self._get_api_version('bgp_service_communities') if api_version == '2016-12-01': @@ -1003,6 +1044,8 @@ def bgp_service_communities(self): from ..v2020_06_01.aio.operations import BgpServiceCommunitiesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import BgpServiceCommunitiesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import BgpServiceCommunitiesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'bgp_service_communities'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1035,6 +1078,7 @@ def connection_monitors(self): * 2020-05-01: :class:`ConnectionMonitorsOperations` * 2020-06-01: :class:`ConnectionMonitorsOperations` * 2020-07-01: :class:`ConnectionMonitorsOperations` + * 2020-08-01: :class:`ConnectionMonitorsOperations` """ api_version = self._get_api_version('connection_monitors') if api_version == '2017-10-01': @@ -1085,6 +1129,8 @@ def connection_monitors(self): from ..v2020_06_01.aio.operations import ConnectionMonitorsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ConnectionMonitorsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ConnectionMonitorsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'connection_monitors'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1095,12 +1141,15 @@ def custom_ip_prefixes(self): * 2020-06-01: :class:`CustomIPPrefixesOperations` * 2020-07-01: :class:`CustomIPPrefixesOperations` + * 2020-08-01: :class:`CustomIPPrefixesOperations` """ api_version = self._get_api_version('custom_ip_prefixes') if api_version == '2020-06-01': from ..v2020_06_01.aio.operations import CustomIPPrefixesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import CustomIPPrefixesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import CustomIPPrefixesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'custom_ip_prefixes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1124,6 +1173,7 @@ def ddos_custom_policies(self): * 2020-05-01: :class:`DdosCustomPoliciesOperations` * 2020-06-01: :class:`DdosCustomPoliciesOperations` * 2020-07-01: :class:`DdosCustomPoliciesOperations` + * 2020-08-01: :class:`DdosCustomPoliciesOperations` """ api_version = self._get_api_version('ddos_custom_policies') if api_version == '2018-11-01': @@ -1156,6 +1206,8 @@ def ddos_custom_policies(self): from ..v2020_06_01.aio.operations import DdosCustomPoliciesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import DdosCustomPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import DdosCustomPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ddos_custom_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1185,6 +1237,7 @@ def ddos_protection_plans(self): * 2020-05-01: :class:`DdosProtectionPlansOperations` * 2020-06-01: :class:`DdosProtectionPlansOperations` * 2020-07-01: :class:`DdosProtectionPlansOperations` + * 2020-08-01: :class:`DdosProtectionPlansOperations` """ api_version = self._get_api_version('ddos_protection_plans') if api_version == '2018-02-01': @@ -1229,6 +1282,8 @@ def ddos_protection_plans(self): from ..v2020_06_01.aio.operations import DdosProtectionPlansOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import DdosProtectionPlansOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import DdosProtectionPlansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ddos_protection_plans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1264,6 +1319,7 @@ def default_security_rules(self): * 2020-05-01: :class:`DefaultSecurityRulesOperations` * 2020-06-01: :class:`DefaultSecurityRulesOperations` * 2020-07-01: :class:`DefaultSecurityRulesOperations` + * 2020-08-01: :class:`DefaultSecurityRulesOperations` """ api_version = self._get_api_version('default_security_rules') if api_version == '2017-06-01': @@ -1320,6 +1376,8 @@ def default_security_rules(self): from ..v2020_06_01.aio.operations import DefaultSecurityRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import DefaultSecurityRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import DefaultSecurityRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'default_security_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1330,12 +1388,15 @@ def dscp_configuration(self): * 2020-06-01: :class:`DscpConfigurationOperations` * 2020-07-01: :class:`DscpConfigurationOperations` + * 2020-08-01: :class:`DscpConfigurationOperations` """ api_version = self._get_api_version('dscp_configuration') if api_version == '2020-06-01': from ..v2020_06_01.aio.operations import DscpConfigurationOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import DscpConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import DscpConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'dscp_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1375,6 +1436,7 @@ def express_route_circuit_authorizations(self): * 2020-05-01: :class:`ExpressRouteCircuitAuthorizationsOperations` * 2020-06-01: :class:`ExpressRouteCircuitAuthorizationsOperations` * 2020-07-01: :class:`ExpressRouteCircuitAuthorizationsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitAuthorizationsOperations` """ api_version = self._get_api_version('express_route_circuit_authorizations') if api_version == '2015-06-15': @@ -1439,6 +1501,8 @@ def express_route_circuit_authorizations(self): from ..v2020_06_01.aio.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCircuitAuthorizationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_authorizations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1468,6 +1532,7 @@ def express_route_circuit_connections(self): * 2020-05-01: :class:`ExpressRouteCircuitConnectionsOperations` * 2020-06-01: :class:`ExpressRouteCircuitConnectionsOperations` * 2020-07-01: :class:`ExpressRouteCircuitConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitConnectionsOperations` """ api_version = self._get_api_version('express_route_circuit_connections') if api_version == '2018-02-01': @@ -1512,6 +1577,8 @@ def express_route_circuit_connections(self): from ..v2020_06_01.aio.operations import ExpressRouteCircuitConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCircuitConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCircuitConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1551,6 +1618,7 @@ def express_route_circuit_peerings(self): * 2020-05-01: :class:`ExpressRouteCircuitPeeringsOperations` * 2020-06-01: :class:`ExpressRouteCircuitPeeringsOperations` * 2020-07-01: :class:`ExpressRouteCircuitPeeringsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitPeeringsOperations` """ api_version = self._get_api_version('express_route_circuit_peerings') if api_version == '2015-06-15': @@ -1615,6 +1683,8 @@ def express_route_circuit_peerings(self): from ..v2020_06_01.aio.operations import ExpressRouteCircuitPeeringsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCircuitPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCircuitPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuit_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1654,6 +1724,7 @@ def express_route_circuits(self): * 2020-05-01: :class:`ExpressRouteCircuitsOperations` * 2020-06-01: :class:`ExpressRouteCircuitsOperations` * 2020-07-01: :class:`ExpressRouteCircuitsOperations` + * 2020-08-01: :class:`ExpressRouteCircuitsOperations` """ api_version = self._get_api_version('express_route_circuits') if api_version == '2015-06-15': @@ -1718,6 +1789,8 @@ def express_route_circuits(self): from ..v2020_06_01.aio.operations import ExpressRouteCircuitsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCircuitsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCircuitsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_circuits'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1743,6 +1816,7 @@ def express_route_connections(self): * 2020-05-01: :class:`ExpressRouteConnectionsOperations` * 2020-06-01: :class:`ExpressRouteConnectionsOperations` * 2020-07-01: :class:`ExpressRouteConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteConnectionsOperations` """ api_version = self._get_api_version('express_route_connections') if api_version == '2018-08-01': @@ -1779,6 +1853,8 @@ def express_route_connections(self): from ..v2020_06_01.aio.operations import ExpressRouteConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1808,6 +1884,7 @@ def express_route_cross_connection_peerings(self): * 2020-05-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` * 2020-06-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` * 2020-07-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` + * 2020-08-01: :class:`ExpressRouteCrossConnectionPeeringsOperations` """ api_version = self._get_api_version('express_route_cross_connection_peerings') if api_version == '2018-02-01': @@ -1852,6 +1929,8 @@ def express_route_cross_connection_peerings(self): from ..v2020_06_01.aio.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCrossConnectionPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_cross_connection_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1881,6 +1960,7 @@ def express_route_cross_connections(self): * 2020-05-01: :class:`ExpressRouteCrossConnectionsOperations` * 2020-06-01: :class:`ExpressRouteCrossConnectionsOperations` * 2020-07-01: :class:`ExpressRouteCrossConnectionsOperations` + * 2020-08-01: :class:`ExpressRouteCrossConnectionsOperations` """ api_version = self._get_api_version('express_route_cross_connections') if api_version == '2018-02-01': @@ -1925,6 +2005,8 @@ def express_route_cross_connections(self): from ..v2020_06_01.aio.operations import ExpressRouteCrossConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteCrossConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteCrossConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_cross_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -1950,6 +2032,7 @@ def express_route_gateways(self): * 2020-05-01: :class:`ExpressRouteGatewaysOperations` * 2020-06-01: :class:`ExpressRouteGatewaysOperations` * 2020-07-01: :class:`ExpressRouteGatewaysOperations` + * 2020-08-01: :class:`ExpressRouteGatewaysOperations` """ api_version = self._get_api_version('express_route_gateways') if api_version == '2018-08-01': @@ -1986,6 +2069,8 @@ def express_route_gateways(self): from ..v2020_06_01.aio.operations import ExpressRouteGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2011,6 +2096,7 @@ def express_route_links(self): * 2020-05-01: :class:`ExpressRouteLinksOperations` * 2020-06-01: :class:`ExpressRouteLinksOperations` * 2020-07-01: :class:`ExpressRouteLinksOperations` + * 2020-08-01: :class:`ExpressRouteLinksOperations` """ api_version = self._get_api_version('express_route_links') if api_version == '2018-08-01': @@ -2047,6 +2133,8 @@ def express_route_links(self): from ..v2020_06_01.aio.operations import ExpressRouteLinksOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteLinksOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2072,6 +2160,7 @@ def express_route_ports(self): * 2020-05-01: :class:`ExpressRoutePortsOperations` * 2020-06-01: :class:`ExpressRoutePortsOperations` * 2020-07-01: :class:`ExpressRoutePortsOperations` + * 2020-08-01: :class:`ExpressRoutePortsOperations` """ api_version = self._get_api_version('express_route_ports') if api_version == '2018-08-01': @@ -2108,6 +2197,8 @@ def express_route_ports(self): from ..v2020_06_01.aio.operations import ExpressRoutePortsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRoutePortsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRoutePortsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_ports'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2133,6 +2224,7 @@ def express_route_ports_locations(self): * 2020-05-01: :class:`ExpressRoutePortsLocationsOperations` * 2020-06-01: :class:`ExpressRoutePortsLocationsOperations` * 2020-07-01: :class:`ExpressRoutePortsLocationsOperations` + * 2020-08-01: :class:`ExpressRoutePortsLocationsOperations` """ api_version = self._get_api_version('express_route_ports_locations') if api_version == '2018-08-01': @@ -2169,6 +2261,8 @@ def express_route_ports_locations(self): from ..v2020_06_01.aio.operations import ExpressRoutePortsLocationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRoutePortsLocationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRoutePortsLocationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_ports_locations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2208,6 +2302,7 @@ def express_route_service_providers(self): * 2020-05-01: :class:`ExpressRouteServiceProvidersOperations` * 2020-06-01: :class:`ExpressRouteServiceProvidersOperations` * 2020-07-01: :class:`ExpressRouteServiceProvidersOperations` + * 2020-08-01: :class:`ExpressRouteServiceProvidersOperations` """ api_version = self._get_api_version('express_route_service_providers') if api_version == '2015-06-15': @@ -2272,6 +2367,8 @@ def express_route_service_providers(self): from ..v2020_06_01.aio.operations import ExpressRouteServiceProvidersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ExpressRouteServiceProvidersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ExpressRouteServiceProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'express_route_service_providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2291,6 +2388,7 @@ def firewall_policies(self): * 2020-05-01: :class:`FirewallPoliciesOperations` * 2020-06-01: :class:`FirewallPoliciesOperations` * 2020-07-01: :class:`FirewallPoliciesOperations` + * 2020-08-01: :class:`FirewallPoliciesOperations` """ api_version = self._get_api_version('firewall_policies') if api_version == '2019-06-01': @@ -2315,6 +2413,8 @@ def firewall_policies(self): from ..v2020_06_01.aio.operations import FirewallPoliciesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import FirewallPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import FirewallPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'firewall_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2326,6 +2426,7 @@ def firewall_policy_rule_collection_groups(self): * 2020-05-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` * 2020-06-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` * 2020-07-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` + * 2020-08-01: :class:`FirewallPolicyRuleCollectionGroupsOperations` """ api_version = self._get_api_version('firewall_policy_rule_collection_groups') if api_version == '2020-05-01': @@ -2334,6 +2435,8 @@ def firewall_policy_rule_collection_groups(self): from ..v2020_06_01.aio.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import FirewallPolicyRuleCollectionGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'firewall_policy_rule_collection_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2383,6 +2486,7 @@ def flow_logs(self): * 2020-05-01: :class:`FlowLogsOperations` * 2020-06-01: :class:`FlowLogsOperations` * 2020-07-01: :class:`FlowLogsOperations` + * 2020-08-01: :class:`FlowLogsOperations` """ api_version = self._get_api_version('flow_logs') if api_version == '2019-11-01': @@ -2399,6 +2503,8 @@ def flow_logs(self): from ..v2020_06_01.aio.operations import FlowLogsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import FlowLogsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import FlowLogsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'flow_logs'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2411,6 +2517,7 @@ def hub_route_tables(self): * 2020-05-01: :class:`HubRouteTablesOperations` * 2020-06-01: :class:`HubRouteTablesOperations` * 2020-07-01: :class:`HubRouteTablesOperations` + * 2020-08-01: :class:`HubRouteTablesOperations` """ api_version = self._get_api_version('hub_route_tables') if api_version == '2020-04-01': @@ -2421,6 +2528,8 @@ def hub_route_tables(self): from ..v2020_06_01.aio.operations import HubRouteTablesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import HubRouteTablesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import HubRouteTablesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'hub_route_tables'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2449,6 +2558,7 @@ def hub_virtual_network_connections(self): * 2020-05-01: :class:`HubVirtualNetworkConnectionsOperations` * 2020-06-01: :class:`HubVirtualNetworkConnectionsOperations` * 2020-07-01: :class:`HubVirtualNetworkConnectionsOperations` + * 2020-08-01: :class:`HubVirtualNetworkConnectionsOperations` """ api_version = self._get_api_version('hub_virtual_network_connections') if api_version == '2018-04-01': @@ -2491,6 +2601,8 @@ def hub_virtual_network_connections(self): from ..v2020_06_01.aio.operations import HubVirtualNetworkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import HubVirtualNetworkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import HubVirtualNetworkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'hub_virtual_network_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2526,6 +2638,7 @@ def inbound_nat_rules(self): * 2020-05-01: :class:`InboundNatRulesOperations` * 2020-06-01: :class:`InboundNatRulesOperations` * 2020-07-01: :class:`InboundNatRulesOperations` + * 2020-08-01: :class:`InboundNatRulesOperations` """ api_version = self._get_api_version('inbound_nat_rules') if api_version == '2017-06-01': @@ -2582,6 +2695,8 @@ def inbound_nat_rules(self): from ..v2020_06_01.aio.operations import InboundNatRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import InboundNatRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import InboundNatRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'inbound_nat_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2592,12 +2707,15 @@ def inbound_security_rule(self): * 2020-06-01: :class:`InboundSecurityRuleOperations` * 2020-07-01: :class:`InboundSecurityRuleOperations` + * 2020-08-01: :class:`InboundSecurityRuleOperations` """ api_version = self._get_api_version('inbound_security_rule') if api_version == '2020-06-01': from ..v2020_06_01.aio.operations import InboundSecurityRuleOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import InboundSecurityRuleOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import InboundSecurityRuleOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'inbound_security_rule'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2636,6 +2754,7 @@ def ip_allocations(self): * 2020-05-01: :class:`IpAllocationsOperations` * 2020-06-01: :class:`IpAllocationsOperations` * 2020-07-01: :class:`IpAllocationsOperations` + * 2020-08-01: :class:`IpAllocationsOperations` """ api_version = self._get_api_version('ip_allocations') if api_version == '2020-03-01': @@ -2648,6 +2767,8 @@ def ip_allocations(self): from ..v2020_06_01.aio.operations import IpAllocationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import IpAllocationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import IpAllocationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ip_allocations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2664,6 +2785,7 @@ def ip_groups(self): * 2020-05-01: :class:`IpGroupsOperations` * 2020-06-01: :class:`IpGroupsOperations` * 2020-07-01: :class:`IpGroupsOperations` + * 2020-08-01: :class:`IpGroupsOperations` """ api_version = self._get_api_version('ip_groups') if api_version == '2019-09-01': @@ -2682,6 +2804,8 @@ def ip_groups(self): from ..v2020_06_01.aio.operations import IpGroupsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import IpGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import IpGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'ip_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2717,6 +2841,7 @@ def load_balancer_backend_address_pools(self): * 2020-05-01: :class:`LoadBalancerBackendAddressPoolsOperations` * 2020-06-01: :class:`LoadBalancerBackendAddressPoolsOperations` * 2020-07-01: :class:`LoadBalancerBackendAddressPoolsOperations` + * 2020-08-01: :class:`LoadBalancerBackendAddressPoolsOperations` """ api_version = self._get_api_version('load_balancer_backend_address_pools') if api_version == '2017-06-01': @@ -2773,6 +2898,8 @@ def load_balancer_backend_address_pools(self): from ..v2020_06_01.aio.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerBackendAddressPoolsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_backend_address_pools'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2808,6 +2935,7 @@ def load_balancer_frontend_ip_configurations(self): * 2020-05-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` * 2020-06-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` * 2020-07-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` + * 2020-08-01: :class:`LoadBalancerFrontendIPConfigurationsOperations` """ api_version = self._get_api_version('load_balancer_frontend_ip_configurations') if api_version == '2017-06-01': @@ -2864,6 +2992,8 @@ def load_balancer_frontend_ip_configurations(self): from ..v2020_06_01.aio.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerFrontendIPConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_frontend_ip_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2899,6 +3029,7 @@ def load_balancer_load_balancing_rules(self): * 2020-05-01: :class:`LoadBalancerLoadBalancingRulesOperations` * 2020-06-01: :class:`LoadBalancerLoadBalancingRulesOperations` * 2020-07-01: :class:`LoadBalancerLoadBalancingRulesOperations` + * 2020-08-01: :class:`LoadBalancerLoadBalancingRulesOperations` """ api_version = self._get_api_version('load_balancer_load_balancing_rules') if api_version == '2017-06-01': @@ -2955,6 +3086,8 @@ def load_balancer_load_balancing_rules(self): from ..v2020_06_01.aio.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerLoadBalancingRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_load_balancing_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -2990,6 +3123,7 @@ def load_balancer_network_interfaces(self): * 2020-05-01: :class:`LoadBalancerNetworkInterfacesOperations` * 2020-06-01: :class:`LoadBalancerNetworkInterfacesOperations` * 2020-07-01: :class:`LoadBalancerNetworkInterfacesOperations` + * 2020-08-01: :class:`LoadBalancerNetworkInterfacesOperations` """ api_version = self._get_api_version('load_balancer_network_interfaces') if api_version == '2017-06-01': @@ -3046,6 +3180,8 @@ def load_balancer_network_interfaces(self): from ..v2020_06_01.aio.operations import LoadBalancerNetworkInterfacesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerNetworkInterfacesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerNetworkInterfacesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_network_interfaces'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3071,6 +3207,7 @@ def load_balancer_outbound_rules(self): * 2020-05-01: :class:`LoadBalancerOutboundRulesOperations` * 2020-06-01: :class:`LoadBalancerOutboundRulesOperations` * 2020-07-01: :class:`LoadBalancerOutboundRulesOperations` + * 2020-08-01: :class:`LoadBalancerOutboundRulesOperations` """ api_version = self._get_api_version('load_balancer_outbound_rules') if api_version == '2018-08-01': @@ -3107,6 +3244,8 @@ def load_balancer_outbound_rules(self): from ..v2020_06_01.aio.operations import LoadBalancerOutboundRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerOutboundRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerOutboundRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_outbound_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3142,6 +3281,7 @@ def load_balancer_probes(self): * 2020-05-01: :class:`LoadBalancerProbesOperations` * 2020-06-01: :class:`LoadBalancerProbesOperations` * 2020-07-01: :class:`LoadBalancerProbesOperations` + * 2020-08-01: :class:`LoadBalancerProbesOperations` """ api_version = self._get_api_version('load_balancer_probes') if api_version == '2017-06-01': @@ -3198,6 +3338,8 @@ def load_balancer_probes(self): from ..v2020_06_01.aio.operations import LoadBalancerProbesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancerProbesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancerProbesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancer_probes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3237,6 +3379,7 @@ def load_balancers(self): * 2020-05-01: :class:`LoadBalancersOperations` * 2020-06-01: :class:`LoadBalancersOperations` * 2020-07-01: :class:`LoadBalancersOperations` + * 2020-08-01: :class:`LoadBalancersOperations` """ api_version = self._get_api_version('load_balancers') if api_version == '2015-06-15': @@ -3301,6 +3444,8 @@ def load_balancers(self): from ..v2020_06_01.aio.operations import LoadBalancersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LoadBalancersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LoadBalancersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'load_balancers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3340,6 +3485,7 @@ def local_network_gateways(self): * 2020-05-01: :class:`LocalNetworkGatewaysOperations` * 2020-06-01: :class:`LocalNetworkGatewaysOperations` * 2020-07-01: :class:`LocalNetworkGatewaysOperations` + * 2020-08-01: :class:`LocalNetworkGatewaysOperations` """ api_version = self._get_api_version('local_network_gateways') if api_version == '2015-06-15': @@ -3404,6 +3550,8 @@ def local_network_gateways(self): from ..v2020_06_01.aio.operations import LocalNetworkGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import LocalNetworkGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import LocalNetworkGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'local_network_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3425,6 +3573,7 @@ def nat_gateways(self): * 2020-05-01: :class:`NatGatewaysOperations` * 2020-06-01: :class:`NatGatewaysOperations` * 2020-07-01: :class:`NatGatewaysOperations` + * 2020-08-01: :class:`NatGatewaysOperations` """ api_version = self._get_api_version('nat_gateways') if api_version == '2019-02-01': @@ -3453,10 +3602,25 @@ def nat_gateways(self): from ..v2020_06_01.aio.operations import NatGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NatGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NatGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'nat_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def nat_rules(self): + """Instance depends on the API version: + + * 2020-08-01: :class:`NatRulesOperations` + """ + api_version = self._get_api_version('nat_rules') + if api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NatRulesOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'nat_rules'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def network_interface_ip_configurations(self): """Instance depends on the API version: @@ -3488,6 +3652,7 @@ def network_interface_ip_configurations(self): * 2020-05-01: :class:`NetworkInterfaceIPConfigurationsOperations` * 2020-06-01: :class:`NetworkInterfaceIPConfigurationsOperations` * 2020-07-01: :class:`NetworkInterfaceIPConfigurationsOperations` + * 2020-08-01: :class:`NetworkInterfaceIPConfigurationsOperations` """ api_version = self._get_api_version('network_interface_ip_configurations') if api_version == '2017-06-01': @@ -3544,6 +3709,8 @@ def network_interface_ip_configurations(self): from ..v2020_06_01.aio.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkInterfaceIPConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_ip_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3579,6 +3746,7 @@ def network_interface_load_balancers(self): * 2020-05-01: :class:`NetworkInterfaceLoadBalancersOperations` * 2020-06-01: :class:`NetworkInterfaceLoadBalancersOperations` * 2020-07-01: :class:`NetworkInterfaceLoadBalancersOperations` + * 2020-08-01: :class:`NetworkInterfaceLoadBalancersOperations` """ api_version = self._get_api_version('network_interface_load_balancers') if api_version == '2017-06-01': @@ -3635,6 +3803,8 @@ def network_interface_load_balancers(self): from ..v2020_06_01.aio.operations import NetworkInterfaceLoadBalancersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkInterfaceLoadBalancersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkInterfaceLoadBalancersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_load_balancers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3660,6 +3830,7 @@ def network_interface_tap_configurations(self): * 2020-05-01: :class:`NetworkInterfaceTapConfigurationsOperations` * 2020-06-01: :class:`NetworkInterfaceTapConfigurationsOperations` * 2020-07-01: :class:`NetworkInterfaceTapConfigurationsOperations` + * 2020-08-01: :class:`NetworkInterfaceTapConfigurationsOperations` """ api_version = self._get_api_version('network_interface_tap_configurations') if api_version == '2018-08-01': @@ -3696,6 +3867,8 @@ def network_interface_tap_configurations(self): from ..v2020_06_01.aio.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkInterfaceTapConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interface_tap_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3735,6 +3908,7 @@ def network_interfaces(self): * 2020-05-01: :class:`NetworkInterfacesOperations` * 2020-06-01: :class:`NetworkInterfacesOperations` * 2020-07-01: :class:`NetworkInterfacesOperations` + * 2020-08-01: :class:`NetworkInterfacesOperations` """ api_version = self._get_api_version('network_interfaces') if api_version == '2015-06-15': @@ -3799,6 +3973,8 @@ def network_interfaces(self): from ..v2020_06_01.aio.operations import NetworkInterfacesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkInterfacesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkInterfacesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_interfaces'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3824,6 +4000,7 @@ def network_profiles(self): * 2020-05-01: :class:`NetworkProfilesOperations` * 2020-06-01: :class:`NetworkProfilesOperations` * 2020-07-01: :class:`NetworkProfilesOperations` + * 2020-08-01: :class:`NetworkProfilesOperations` """ api_version = self._get_api_version('network_profiles') if api_version == '2018-08-01': @@ -3860,6 +4037,8 @@ def network_profiles(self): from ..v2020_06_01.aio.operations import NetworkProfilesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkProfilesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkProfilesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_profiles'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3899,6 +4078,7 @@ def network_security_groups(self): * 2020-05-01: :class:`NetworkSecurityGroupsOperations` * 2020-06-01: :class:`NetworkSecurityGroupsOperations` * 2020-07-01: :class:`NetworkSecurityGroupsOperations` + * 2020-08-01: :class:`NetworkSecurityGroupsOperations` """ api_version = self._get_api_version('network_security_groups') if api_version == '2015-06-15': @@ -3963,6 +4143,8 @@ def network_security_groups(self): from ..v2020_06_01.aio.operations import NetworkSecurityGroupsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkSecurityGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkSecurityGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_security_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -3977,6 +4159,7 @@ def network_virtual_appliances(self): * 2020-05-01: :class:`NetworkVirtualAppliancesOperations` * 2020-06-01: :class:`NetworkVirtualAppliancesOperations` * 2020-07-01: :class:`NetworkVirtualAppliancesOperations` + * 2020-08-01: :class:`NetworkVirtualAppliancesOperations` """ api_version = self._get_api_version('network_virtual_appliances') if api_version == '2019-12-01': @@ -3991,6 +4174,8 @@ def network_virtual_appliances(self): from ..v2020_06_01.aio.operations import NetworkVirtualAppliancesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkVirtualAppliancesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkVirtualAppliancesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_virtual_appliances'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4029,6 +4214,7 @@ def network_watchers(self): * 2020-05-01: :class:`NetworkWatchersOperations` * 2020-06-01: :class:`NetworkWatchersOperations` * 2020-07-01: :class:`NetworkWatchersOperations` + * 2020-08-01: :class:`NetworkWatchersOperations` """ api_version = self._get_api_version('network_watchers') if api_version == '2016-09-01': @@ -4091,6 +4277,8 @@ def network_watchers(self): from ..v2020_06_01.aio.operations import NetworkWatchersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkWatchersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkWatchersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'network_watchers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4124,6 +4312,7 @@ def operations(self): * 2020-05-01: :class:`Operations` * 2020-06-01: :class:`Operations` * 2020-07-01: :class:`Operations` + * 2020-08-01: :class:`Operations` """ api_version = self._get_api_version('operations') if api_version == '2017-09-01': @@ -4176,6 +4365,8 @@ def operations(self): from ..v2020_06_01.aio.operations import Operations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import Operations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_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))) @@ -4201,6 +4392,7 @@ def p2_svpn_gateways(self): * 2020-05-01: :class:`P2SVpnGatewaysOperations` * 2020-06-01: :class:`P2SVpnGatewaysOperations` * 2020-07-01: :class:`P2SVpnGatewaysOperations` + * 2020-08-01: :class:`P2SVpnGatewaysOperations` """ api_version = self._get_api_version('p2_svpn_gateways') if api_version == '2018-08-01': @@ -4237,6 +4429,8 @@ def p2_svpn_gateways(self): from ..v2020_06_01.aio.operations import P2SVpnGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import P2SVpnGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import P2SVpnGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'p2_svpn_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4309,6 +4503,7 @@ def packet_captures(self): * 2020-05-01: :class:`PacketCapturesOperations` * 2020-06-01: :class:`PacketCapturesOperations` * 2020-07-01: :class:`PacketCapturesOperations` + * 2020-08-01: :class:`PacketCapturesOperations` """ api_version = self._get_api_version('packet_captures') if api_version == '2016-09-01': @@ -4371,6 +4566,8 @@ def packet_captures(self): from ..v2020_06_01.aio.operations import PacketCapturesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PacketCapturesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PacketCapturesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'packet_captures'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4393,6 +4590,7 @@ def peer_express_route_circuit_connections(self): * 2020-05-01: :class:`PeerExpressRouteCircuitConnectionsOperations` * 2020-06-01: :class:`PeerExpressRouteCircuitConnectionsOperations` * 2020-07-01: :class:`PeerExpressRouteCircuitConnectionsOperations` + * 2020-08-01: :class:`PeerExpressRouteCircuitConnectionsOperations` """ api_version = self._get_api_version('peer_express_route_circuit_connections') if api_version == '2018-12-01': @@ -4423,6 +4621,8 @@ def peer_express_route_circuit_connections(self): from ..v2020_06_01.aio.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PeerExpressRouteCircuitConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'peer_express_route_circuit_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4436,6 +4636,7 @@ def private_dns_zone_groups(self): * 2020-05-01: :class:`PrivateDnsZoneGroupsOperations` * 2020-06-01: :class:`PrivateDnsZoneGroupsOperations` * 2020-07-01: :class:`PrivateDnsZoneGroupsOperations` + * 2020-08-01: :class:`PrivateDnsZoneGroupsOperations` """ api_version = self._get_api_version('private_dns_zone_groups') if api_version == '2020-03-01': @@ -4448,6 +4649,8 @@ def private_dns_zone_groups(self): from ..v2020_06_01.aio.operations import PrivateDnsZoneGroupsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PrivateDnsZoneGroupsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PrivateDnsZoneGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_dns_zone_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4468,6 +4671,7 @@ def private_endpoints(self): * 2020-05-01: :class:`PrivateEndpointsOperations` * 2020-06-01: :class:`PrivateEndpointsOperations` * 2020-07-01: :class:`PrivateEndpointsOperations` + * 2020-08-01: :class:`PrivateEndpointsOperations` """ api_version = self._get_api_version('private_endpoints') if api_version == '2019-04-01': @@ -4494,6 +4698,8 @@ def private_endpoints(self): from ..v2020_06_01.aio.operations import PrivateEndpointsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PrivateEndpointsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PrivateEndpointsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_endpoints'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4514,6 +4720,7 @@ def private_link_services(self): * 2020-05-01: :class:`PrivateLinkServicesOperations` * 2020-06-01: :class:`PrivateLinkServicesOperations` * 2020-07-01: :class:`PrivateLinkServicesOperations` + * 2020-08-01: :class:`PrivateLinkServicesOperations` """ api_version = self._get_api_version('private_link_services') if api_version == '2019-04-01': @@ -4540,6 +4747,8 @@ def private_link_services(self): from ..v2020_06_01.aio.operations import PrivateLinkServicesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PrivateLinkServicesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PrivateLinkServicesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'private_link_services'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4579,6 +4788,7 @@ def public_ip_addresses(self): * 2020-05-01: :class:`PublicIPAddressesOperations` * 2020-06-01: :class:`PublicIPAddressesOperations` * 2020-07-01: :class:`PublicIPAddressesOperations` + * 2020-08-01: :class:`PublicIPAddressesOperations` """ api_version = self._get_api_version('public_ip_addresses') if api_version == '2015-06-15': @@ -4643,6 +4853,8 @@ def public_ip_addresses(self): from ..v2020_06_01.aio.operations import PublicIPAddressesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PublicIPAddressesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PublicIPAddressesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'public_ip_addresses'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4669,6 +4881,7 @@ def public_ip_prefixes(self): * 2020-05-01: :class:`PublicIPPrefixesOperations` * 2020-06-01: :class:`PublicIPPrefixesOperations` * 2020-07-01: :class:`PublicIPPrefixesOperations` + * 2020-08-01: :class:`PublicIPPrefixesOperations` """ api_version = self._get_api_version('public_ip_prefixes') if api_version == '2018-07-01': @@ -4707,6 +4920,8 @@ def public_ip_prefixes(self): from ..v2020_06_01.aio.operations import PublicIPPrefixesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import PublicIPPrefixesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import PublicIPPrefixesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'public_ip_prefixes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4728,6 +4943,7 @@ def resource_navigation_links(self): * 2020-05-01: :class:`ResourceNavigationLinksOperations` * 2020-06-01: :class:`ResourceNavigationLinksOperations` * 2020-07-01: :class:`ResourceNavigationLinksOperations` + * 2020-08-01: :class:`ResourceNavigationLinksOperations` """ api_version = self._get_api_version('resource_navigation_links') if api_version == '2019-02-01': @@ -4756,6 +4972,8 @@ def resource_navigation_links(self): from ..v2020_06_01.aio.operations import ResourceNavigationLinksOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ResourceNavigationLinksOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ResourceNavigationLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_navigation_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4793,6 +5011,7 @@ def route_filter_rules(self): * 2020-05-01: :class:`RouteFilterRulesOperations` * 2020-06-01: :class:`RouteFilterRulesOperations` * 2020-07-01: :class:`RouteFilterRulesOperations` + * 2020-08-01: :class:`RouteFilterRulesOperations` """ api_version = self._get_api_version('route_filter_rules') if api_version == '2016-12-01': @@ -4853,6 +5072,8 @@ def route_filter_rules(self): from ..v2020_06_01.aio.operations import RouteFilterRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import RouteFilterRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import RouteFilterRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_filter_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4890,6 +5111,7 @@ def route_filters(self): * 2020-05-01: :class:`RouteFiltersOperations` * 2020-06-01: :class:`RouteFiltersOperations` * 2020-07-01: :class:`RouteFiltersOperations` + * 2020-08-01: :class:`RouteFiltersOperations` """ api_version = self._get_api_version('route_filters') if api_version == '2016-12-01': @@ -4950,6 +5172,8 @@ def route_filters(self): from ..v2020_06_01.aio.operations import RouteFiltersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import RouteFiltersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import RouteFiltersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_filters'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -4989,6 +5213,7 @@ def route_tables(self): * 2020-05-01: :class:`RouteTablesOperations` * 2020-06-01: :class:`RouteTablesOperations` * 2020-07-01: :class:`RouteTablesOperations` + * 2020-08-01: :class:`RouteTablesOperations` """ api_version = self._get_api_version('route_tables') if api_version == '2015-06-15': @@ -5053,6 +5278,8 @@ def route_tables(self): from ..v2020_06_01.aio.operations import RouteTablesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import RouteTablesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import RouteTablesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'route_tables'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5092,6 +5319,7 @@ def routes(self): * 2020-05-01: :class:`RoutesOperations` * 2020-06-01: :class:`RoutesOperations` * 2020-07-01: :class:`RoutesOperations` + * 2020-08-01: :class:`RoutesOperations` """ api_version = self._get_api_version('routes') if api_version == '2015-06-15': @@ -5156,6 +5384,8 @@ def routes(self): from ..v2020_06_01.aio.operations import RoutesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import RoutesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import RoutesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'routes'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5169,6 +5399,7 @@ def security_partner_providers(self): * 2020-05-01: :class:`SecurityPartnerProvidersOperations` * 2020-06-01: :class:`SecurityPartnerProvidersOperations` * 2020-07-01: :class:`SecurityPartnerProvidersOperations` + * 2020-08-01: :class:`SecurityPartnerProvidersOperations` """ api_version = self._get_api_version('security_partner_providers') if api_version == '2020-03-01': @@ -5181,6 +5412,8 @@ def security_partner_providers(self): from ..v2020_06_01.aio.operations import SecurityPartnerProvidersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import SecurityPartnerProvidersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import SecurityPartnerProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'security_partner_providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5220,6 +5453,7 @@ def security_rules(self): * 2020-05-01: :class:`SecurityRulesOperations` * 2020-06-01: :class:`SecurityRulesOperations` * 2020-07-01: :class:`SecurityRulesOperations` + * 2020-08-01: :class:`SecurityRulesOperations` """ api_version = self._get_api_version('security_rules') if api_version == '2015-06-15': @@ -5284,6 +5518,8 @@ def security_rules(self): from ..v2020_06_01.aio.operations import SecurityRulesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import SecurityRulesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import SecurityRulesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'security_rules'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5305,6 +5541,7 @@ def service_association_links(self): * 2020-05-01: :class:`ServiceAssociationLinksOperations` * 2020-06-01: :class:`ServiceAssociationLinksOperations` * 2020-07-01: :class:`ServiceAssociationLinksOperations` + * 2020-08-01: :class:`ServiceAssociationLinksOperations` """ api_version = self._get_api_version('service_association_links') if api_version == '2019-02-01': @@ -5333,6 +5570,8 @@ def service_association_links(self): from ..v2020_06_01.aio.operations import ServiceAssociationLinksOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ServiceAssociationLinksOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ServiceAssociationLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_association_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5359,6 +5598,7 @@ def service_endpoint_policies(self): * 2020-05-01: :class:`ServiceEndpointPoliciesOperations` * 2020-06-01: :class:`ServiceEndpointPoliciesOperations` * 2020-07-01: :class:`ServiceEndpointPoliciesOperations` + * 2020-08-01: :class:`ServiceEndpointPoliciesOperations` """ api_version = self._get_api_version('service_endpoint_policies') if api_version == '2018-07-01': @@ -5397,6 +5637,8 @@ def service_endpoint_policies(self): from ..v2020_06_01.aio.operations import ServiceEndpointPoliciesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ServiceEndpointPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ServiceEndpointPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_endpoint_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5423,6 +5665,7 @@ def service_endpoint_policy_definitions(self): * 2020-05-01: :class:`ServiceEndpointPolicyDefinitionsOperations` * 2020-06-01: :class:`ServiceEndpointPolicyDefinitionsOperations` * 2020-07-01: :class:`ServiceEndpointPolicyDefinitionsOperations` + * 2020-08-01: :class:`ServiceEndpointPolicyDefinitionsOperations` """ api_version = self._get_api_version('service_endpoint_policy_definitions') if api_version == '2018-07-01': @@ -5461,6 +5704,8 @@ def service_endpoint_policy_definitions(self): from ..v2020_06_01.aio.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ServiceEndpointPolicyDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_endpoint_policy_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5481,6 +5726,7 @@ def service_tags(self): * 2020-05-01: :class:`ServiceTagsOperations` * 2020-06-01: :class:`ServiceTagsOperations` * 2020-07-01: :class:`ServiceTagsOperations` + * 2020-08-01: :class:`ServiceTagsOperations` """ api_version = self._get_api_version('service_tags') if api_version == '2019-04-01': @@ -5507,6 +5753,8 @@ def service_tags(self): from ..v2020_06_01.aio.operations import ServiceTagsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import ServiceTagsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import ServiceTagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'service_tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5546,6 +5794,7 @@ def subnets(self): * 2020-05-01: :class:`SubnetsOperations` * 2020-06-01: :class:`SubnetsOperations` * 2020-07-01: :class:`SubnetsOperations` + * 2020-08-01: :class:`SubnetsOperations` """ api_version = self._get_api_version('subnets') if api_version == '2015-06-15': @@ -5610,6 +5859,8 @@ def subnets(self): from ..v2020_06_01.aio.operations import SubnetsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import SubnetsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import SubnetsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'subnets'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5649,6 +5900,7 @@ def usages(self): * 2020-05-01: :class:`UsagesOperations` * 2020-06-01: :class:`UsagesOperations` * 2020-07-01: :class:`UsagesOperations` + * 2020-08-01: :class:`UsagesOperations` """ api_version = self._get_api_version('usages') if api_version == '2015-06-15': @@ -5713,6 +5965,8 @@ def usages(self): from ..v2020_06_01.aio.operations import UsagesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import UsagesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import UsagesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'usages'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5724,6 +5978,7 @@ def virtual_appliance_sites(self): * 2020-05-01: :class:`VirtualApplianceSitesOperations` * 2020-06-01: :class:`VirtualApplianceSitesOperations` * 2020-07-01: :class:`VirtualApplianceSitesOperations` + * 2020-08-01: :class:`VirtualApplianceSitesOperations` """ api_version = self._get_api_version('virtual_appliance_sites') if api_version == '2020-05-01': @@ -5732,6 +5987,8 @@ def virtual_appliance_sites(self): from ..v2020_06_01.aio.operations import VirtualApplianceSitesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualApplianceSitesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualApplianceSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_appliance_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5743,6 +6000,7 @@ def virtual_appliance_skus(self): * 2020-05-01: :class:`VirtualApplianceSkusOperations` * 2020-06-01: :class:`VirtualApplianceSkusOperations` * 2020-07-01: :class:`VirtualApplianceSkusOperations` + * 2020-08-01: :class:`VirtualApplianceSkusOperations` """ api_version = self._get_api_version('virtual_appliance_skus') if api_version == '2020-05-01': @@ -5751,6 +6009,8 @@ def virtual_appliance_skus(self): from ..v2020_06_01.aio.operations import VirtualApplianceSkusOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualApplianceSkusOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualApplianceSkusOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_appliance_skus'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5762,6 +6022,7 @@ def virtual_hub_bgp_connection(self): * 2020-05-01: :class:`VirtualHubBgpConnectionOperations` * 2020-06-01: :class:`VirtualHubBgpConnectionOperations` * 2020-07-01: :class:`VirtualHubBgpConnectionOperations` + * 2020-08-01: :class:`VirtualHubBgpConnectionOperations` """ api_version = self._get_api_version('virtual_hub_bgp_connection') if api_version == '2020-05-01': @@ -5770,6 +6031,8 @@ def virtual_hub_bgp_connection(self): from ..v2020_06_01.aio.operations import VirtualHubBgpConnectionOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualHubBgpConnectionOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualHubBgpConnectionOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_bgp_connection'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5781,6 +6044,7 @@ def virtual_hub_bgp_connections(self): * 2020-05-01: :class:`VirtualHubBgpConnectionsOperations` * 2020-06-01: :class:`VirtualHubBgpConnectionsOperations` * 2020-07-01: :class:`VirtualHubBgpConnectionsOperations` + * 2020-08-01: :class:`VirtualHubBgpConnectionsOperations` """ api_version = self._get_api_version('virtual_hub_bgp_connections') if api_version == '2020-05-01': @@ -5789,6 +6053,8 @@ def virtual_hub_bgp_connections(self): from ..v2020_06_01.aio.operations import VirtualHubBgpConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualHubBgpConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualHubBgpConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_bgp_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5800,6 +6066,7 @@ def virtual_hub_ip_configuration(self): * 2020-05-01: :class:`VirtualHubIpConfigurationOperations` * 2020-06-01: :class:`VirtualHubIpConfigurationOperations` * 2020-07-01: :class:`VirtualHubIpConfigurationOperations` + * 2020-08-01: :class:`VirtualHubIpConfigurationOperations` """ api_version = self._get_api_version('virtual_hub_ip_configuration') if api_version == '2020-05-01': @@ -5808,6 +6075,8 @@ def virtual_hub_ip_configuration(self): from ..v2020_06_01.aio.operations import VirtualHubIpConfigurationOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualHubIpConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualHubIpConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_ip_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5824,6 +6093,7 @@ def virtual_hub_route_table_v2_s(self): * 2020-05-01: :class:`VirtualHubRouteTableV2SOperations` * 2020-06-01: :class:`VirtualHubRouteTableV2SOperations` * 2020-07-01: :class:`VirtualHubRouteTableV2SOperations` + * 2020-08-01: :class:`VirtualHubRouteTableV2SOperations` """ api_version = self._get_api_version('virtual_hub_route_table_v2_s') if api_version == '2019-09-01': @@ -5842,6 +6112,8 @@ def virtual_hub_route_table_v2_s(self): from ..v2020_06_01.aio.operations import VirtualHubRouteTableV2SOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualHubRouteTableV2SOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualHubRouteTableV2SOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hub_route_table_v2_s'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5870,6 +6142,7 @@ def virtual_hubs(self): * 2020-05-01: :class:`VirtualHubsOperations` * 2020-06-01: :class:`VirtualHubsOperations` * 2020-07-01: :class:`VirtualHubsOperations` + * 2020-08-01: :class:`VirtualHubsOperations` """ api_version = self._get_api_version('virtual_hubs') if api_version == '2018-04-01': @@ -5912,6 +6185,8 @@ def virtual_hubs(self): from ..v2020_06_01.aio.operations import VirtualHubsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualHubsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualHubsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_hubs'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -5951,6 +6226,7 @@ def virtual_network_gateway_connections(self): * 2020-05-01: :class:`VirtualNetworkGatewayConnectionsOperations` * 2020-06-01: :class:`VirtualNetworkGatewayConnectionsOperations` * 2020-07-01: :class:`VirtualNetworkGatewayConnectionsOperations` + * 2020-08-01: :class:`VirtualNetworkGatewayConnectionsOperations` """ api_version = self._get_api_version('virtual_network_gateway_connections') if api_version == '2015-06-15': @@ -6015,6 +6291,8 @@ def virtual_network_gateway_connections(self): from ..v2020_06_01.aio.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualNetworkGatewayConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_gateway_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6054,6 +6332,7 @@ def virtual_network_gateways(self): * 2020-05-01: :class:`VirtualNetworkGatewaysOperations` * 2020-06-01: :class:`VirtualNetworkGatewaysOperations` * 2020-07-01: :class:`VirtualNetworkGatewaysOperations` + * 2020-08-01: :class:`VirtualNetworkGatewaysOperations` """ api_version = self._get_api_version('virtual_network_gateways') if api_version == '2015-06-15': @@ -6118,6 +6397,8 @@ def virtual_network_gateways(self): from ..v2020_06_01.aio.operations import VirtualNetworkGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualNetworkGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualNetworkGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6156,6 +6437,7 @@ def virtual_network_peerings(self): * 2020-05-01: :class:`VirtualNetworkPeeringsOperations` * 2020-06-01: :class:`VirtualNetworkPeeringsOperations` * 2020-07-01: :class:`VirtualNetworkPeeringsOperations` + * 2020-08-01: :class:`VirtualNetworkPeeringsOperations` """ api_version = self._get_api_version('virtual_network_peerings') if api_version == '2016-09-01': @@ -6218,6 +6500,8 @@ def virtual_network_peerings(self): from ..v2020_06_01.aio.operations import VirtualNetworkPeeringsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualNetworkPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualNetworkPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6243,6 +6527,7 @@ def virtual_network_taps(self): * 2020-05-01: :class:`VirtualNetworkTapsOperations` * 2020-06-01: :class:`VirtualNetworkTapsOperations` * 2020-07-01: :class:`VirtualNetworkTapsOperations` + * 2020-08-01: :class:`VirtualNetworkTapsOperations` """ api_version = self._get_api_version('virtual_network_taps') if api_version == '2018-08-01': @@ -6279,6 +6564,8 @@ def virtual_network_taps(self): from ..v2020_06_01.aio.operations import VirtualNetworkTapsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualNetworkTapsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualNetworkTapsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_network_taps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6318,6 +6605,7 @@ def virtual_networks(self): * 2020-05-01: :class:`VirtualNetworksOperations` * 2020-06-01: :class:`VirtualNetworksOperations` * 2020-07-01: :class:`VirtualNetworksOperations` + * 2020-08-01: :class:`VirtualNetworksOperations` """ api_version = self._get_api_version('virtual_networks') if api_version == '2015-06-15': @@ -6382,6 +6670,8 @@ def virtual_networks(self): from ..v2020_06_01.aio.operations import VirtualNetworksOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualNetworksOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualNetworksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_networks'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6400,6 +6690,7 @@ def virtual_router_peerings(self): * 2020-05-01: :class:`VirtualRouterPeeringsOperations` * 2020-06-01: :class:`VirtualRouterPeeringsOperations` * 2020-07-01: :class:`VirtualRouterPeeringsOperations` + * 2020-08-01: :class:`VirtualRouterPeeringsOperations` """ api_version = self._get_api_version('virtual_router_peerings') if api_version == '2019-07-01': @@ -6422,6 +6713,8 @@ def virtual_router_peerings(self): from ..v2020_06_01.aio.operations import VirtualRouterPeeringsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualRouterPeeringsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualRouterPeeringsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_router_peerings'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6440,6 +6733,7 @@ def virtual_routers(self): * 2020-05-01: :class:`VirtualRoutersOperations` * 2020-06-01: :class:`VirtualRoutersOperations` * 2020-07-01: :class:`VirtualRoutersOperations` + * 2020-08-01: :class:`VirtualRoutersOperations` """ api_version = self._get_api_version('virtual_routers') if api_version == '2019-07-01': @@ -6462,6 +6756,8 @@ def virtual_routers(self): from ..v2020_06_01.aio.operations import VirtualRoutersOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualRoutersOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualRoutersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_routers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6490,6 +6786,7 @@ def virtual_wans(self): * 2020-05-01: :class:`VirtualWansOperations` * 2020-06-01: :class:`VirtualWansOperations` * 2020-07-01: :class:`VirtualWansOperations` + * 2020-08-01: :class:`VirtualWansOperations` """ api_version = self._get_api_version('virtual_wans') if api_version == '2018-04-01': @@ -6532,6 +6829,8 @@ def virtual_wans(self): from ..v2020_06_01.aio.operations import VirtualWansOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VirtualWansOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VirtualWansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'virtual_wans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6560,6 +6859,7 @@ def vpn_connections(self): * 2020-05-01: :class:`VpnConnectionsOperations` * 2020-06-01: :class:`VpnConnectionsOperations` * 2020-07-01: :class:`VpnConnectionsOperations` + * 2020-08-01: :class:`VpnConnectionsOperations` """ api_version = self._get_api_version('vpn_connections') if api_version == '2018-04-01': @@ -6602,6 +6902,8 @@ def vpn_connections(self): from ..v2020_06_01.aio.operations import VpnConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6630,6 +6932,7 @@ def vpn_gateways(self): * 2020-05-01: :class:`VpnGatewaysOperations` * 2020-06-01: :class:`VpnGatewaysOperations` * 2020-07-01: :class:`VpnGatewaysOperations` + * 2020-08-01: :class:`VpnGatewaysOperations` """ api_version = self._get_api_version('vpn_gateways') if api_version == '2018-04-01': @@ -6672,6 +6975,8 @@ def vpn_gateways(self): from ..v2020_06_01.aio.operations import VpnGatewaysOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnGatewaysOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnGatewaysOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_gateways'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6691,6 +6996,7 @@ def vpn_link_connections(self): * 2020-05-01: :class:`VpnLinkConnectionsOperations` * 2020-06-01: :class:`VpnLinkConnectionsOperations` * 2020-07-01: :class:`VpnLinkConnectionsOperations` + * 2020-08-01: :class:`VpnLinkConnectionsOperations` """ api_version = self._get_api_version('vpn_link_connections') if api_version == '2019-06-01': @@ -6715,6 +7021,8 @@ def vpn_link_connections(self): from ..v2020_06_01.aio.operations import VpnLinkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnLinkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnLinkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_link_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6732,6 +7040,7 @@ def vpn_server_configurations(self): * 2020-05-01: :class:`VpnServerConfigurationsOperations` * 2020-06-01: :class:`VpnServerConfigurationsOperations` * 2020-07-01: :class:`VpnServerConfigurationsOperations` + * 2020-08-01: :class:`VpnServerConfigurationsOperations` """ api_version = self._get_api_version('vpn_server_configurations') if api_version == '2019-08-01': @@ -6752,6 +7061,8 @@ def vpn_server_configurations(self): from ..v2020_06_01.aio.operations import VpnServerConfigurationsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnServerConfigurationsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnServerConfigurationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_server_configurations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6769,6 +7080,7 @@ def vpn_server_configurations_associated_with_virtual_wan(self): * 2020-05-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` * 2020-06-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` * 2020-07-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` + * 2020-08-01: :class:`VpnServerConfigurationsAssociatedWithVirtualWanOperations` """ api_version = self._get_api_version('vpn_server_configurations_associated_with_virtual_wan') if api_version == '2019-08-01': @@ -6789,6 +7101,8 @@ def vpn_server_configurations_associated_with_virtual_wan(self): from ..v2020_06_01.aio.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_server_configurations_associated_with_virtual_wan'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6808,6 +7122,7 @@ def vpn_site_link_connections(self): * 2020-05-01: :class:`VpnSiteLinkConnectionsOperations` * 2020-06-01: :class:`VpnSiteLinkConnectionsOperations` * 2020-07-01: :class:`VpnSiteLinkConnectionsOperations` + * 2020-08-01: :class:`VpnSiteLinkConnectionsOperations` """ api_version = self._get_api_version('vpn_site_link_connections') if api_version == '2019-06-01': @@ -6832,6 +7147,8 @@ def vpn_site_link_connections(self): from ..v2020_06_01.aio.operations import VpnSiteLinkConnectionsOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnSiteLinkConnectionsOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnSiteLinkConnectionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_site_link_connections'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6851,6 +7168,7 @@ def vpn_site_links(self): * 2020-05-01: :class:`VpnSiteLinksOperations` * 2020-06-01: :class:`VpnSiteLinksOperations` * 2020-07-01: :class:`VpnSiteLinksOperations` + * 2020-08-01: :class:`VpnSiteLinksOperations` """ api_version = self._get_api_version('vpn_site_links') if api_version == '2019-06-01': @@ -6875,6 +7193,8 @@ def vpn_site_links(self): from ..v2020_06_01.aio.operations import VpnSiteLinksOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnSiteLinksOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnSiteLinksOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_site_links'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6903,6 +7223,7 @@ def vpn_sites(self): * 2020-05-01: :class:`VpnSitesOperations` * 2020-06-01: :class:`VpnSitesOperations` * 2020-07-01: :class:`VpnSitesOperations` + * 2020-08-01: :class:`VpnSitesOperations` """ api_version = self._get_api_version('vpn_sites') if api_version == '2018-04-01': @@ -6945,6 +7266,8 @@ def vpn_sites(self): from ..v2020_06_01.aio.operations import VpnSitesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnSitesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -6973,6 +7296,7 @@ def vpn_sites_configuration(self): * 2020-05-01: :class:`VpnSitesConfigurationOperations` * 2020-06-01: :class:`VpnSitesConfigurationOperations` * 2020-07-01: :class:`VpnSitesConfigurationOperations` + * 2020-08-01: :class:`VpnSitesConfigurationOperations` """ api_version = self._get_api_version('vpn_sites_configuration') if api_version == '2018-04-01': @@ -7015,6 +7339,8 @@ def vpn_sites_configuration(self): from ..v2020_06_01.aio.operations import VpnSitesConfigurationOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import VpnSitesConfigurationOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import VpnSitesConfigurationOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'vpn_sites_configuration'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -7037,6 +7363,7 @@ def web_application_firewall_policies(self): * 2020-05-01: :class:`WebApplicationFirewallPoliciesOperations` * 2020-06-01: :class:`WebApplicationFirewallPoliciesOperations` * 2020-07-01: :class:`WebApplicationFirewallPoliciesOperations` + * 2020-08-01: :class:`WebApplicationFirewallPoliciesOperations` """ api_version = self._get_api_version('web_application_firewall_policies') if api_version == '2018-12-01': @@ -7067,6 +7394,8 @@ def web_application_firewall_policies(self): from ..v2020_06_01.aio.operations import WebApplicationFirewallPoliciesOperations as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import WebApplicationFirewallPoliciesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import WebApplicationFirewallPoliciesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_application_firewall_policies'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -7076,10 +7405,13 @@ def web_categories(self): """Instance depends on the API version: * 2020-07-01: :class:`WebCategoriesOperations` + * 2020-08-01: :class:`WebCategoriesOperations` """ api_version = self._get_api_version('web_categories') if api_version == '2020-07-01': from ..v2020_07_01.aio.operations import WebCategoriesOperations as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import WebCategoriesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_categories'".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/network/azure-mgmt-network/azure/mgmt/network/aio/_operations_mixin.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_operations_mixin.py index 3aa3f32ac3a2..c299c20993f6 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_operations_mixin.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/aio/_operations_mixin.py @@ -37,7 +37,7 @@ async def begin_delete_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -65,6 +65,8 @@ async def begin_delete_bastion_shareable_link( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_delete_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -91,7 +93,7 @@ async def begin_generatevirtualwanvpnserverconfigurationvpnprofile( :type virtual_wan_name: str :param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation operation. - :type vpn_client_params: ~azure.mgmt.network.v2020_07_01.models.VirtualWanVpnProfileParameters + :type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -99,7 +101,7 @@ async def begin_generatevirtualwanvpnserverconfigurationvpnprofile( :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 VpnProfileResponse or the result of cls(response) - :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_07_01.models.VpnProfileResponse] + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_generatevirtualwanvpnserverconfigurationvpnprofile') @@ -121,6 +123,8 @@ async def begin_generatevirtualwanvpnserverconfigurationvpnprofile( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_generatevirtualwanvpnserverconfigurationvpnprofile'".format(api_version)) mixin_instance = OperationClass() @@ -149,7 +153,7 @@ def begin_get_active_sessions( :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 BastionActiveSessionListResult or the result of cls(response) - :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionActiveSessionListResult]] + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_get_active_sessions') @@ -169,6 +173,8 @@ def begin_get_active_sessions( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_get_active_sessions'".format(api_version)) mixin_instance = OperationClass() @@ -192,7 +198,7 @@ def begin_put_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -200,7 +206,7 @@ def begin_put_bastion_shareable_link( :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 BastionShareableLinkListResult or the result of cls(response) - :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListResult]] + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]] :raises ~azure.core.exceptions.HttpResponseError: """ api_version = self._get_api_version('begin_put_bastion_shareable_link') @@ -220,6 +226,8 @@ def begin_put_bastion_shareable_link( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'begin_put_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -244,7 +252,7 @@ async def check_dns_name_availability( :type domain_name_label: str :keyword callable cls: A custom type or function that will be passed the direct response :return: DnsNameAvailabilityResult, or the result of cls(response) - :rtype: ~azure.mgmt.network.v2020_07_01.models.DnsNameAvailabilityResult + :rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('check_dns_name_availability') @@ -310,6 +318,8 @@ async def check_dns_name_availability( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'check_dns_name_availability'".format(api_version)) mixin_instance = OperationClass() @@ -333,10 +343,10 @@ def disconnect_active_sessions( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param session_ids: The list of sessionids to disconnect. - :type session_ids: ~azure.mgmt.network.v2020_07_01.models.SessionIds + :type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionSessionDeleteResult] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('disconnect_active_sessions') @@ -356,6 +366,8 @@ def disconnect_active_sessions( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'disconnect_active_sessions'".format(api_version)) mixin_instance = OperationClass() @@ -379,10 +391,10 @@ def get_bastion_shareable_link( :param bastion_host_name: The name of the Bastion Host. :type bastion_host_name: str :param bsl_request: Post request for all the Bastion Shareable Link endpoints. - :type bsl_request: ~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListRequest + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_07_01.models.BastionShareableLinkListResult] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_bastion_shareable_link') @@ -402,6 +414,8 @@ def get_bastion_shareable_link( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_bastion_shareable_link'".format(api_version)) mixin_instance = OperationClass() @@ -426,7 +440,7 @@ async def supported_security_providers( :type virtual_wan_name: str :keyword callable cls: A custom type or function that will be passed the direct response :return: VirtualWanSecurityProviders, or the result of cls(response) - :rtype: ~azure.mgmt.network.v2020_07_01.models.VirtualWanSecurityProviders + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('supported_security_providers') @@ -464,6 +478,8 @@ async def supported_security_providers( from ..v2020_06_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass elif api_version == '2020-07-01': from ..v2020_07_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass + elif api_version == '2020-08-01': + from ..v2020_08_01.aio.operations import NetworkManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'supported_security_providers'".format(api_version)) mixin_instance = OperationClass() diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/models.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/models.py index 7dcbed35b605..ce57f0fc2a36 100644 --- a/sdk/network/azure-mgmt-network/azure/mgmt/network/models.py +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/models.py @@ -7,4 +7,4 @@ from .v2019_02_01.models import * from .v2019_07_01.models import * from .v2020_04_01.models import * -from .v2020_07_01.models import * +from .v2020_08_01.models import * diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/__init__.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/__init__.py new file mode 100644 index 000000000000..202b38f8e292 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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 ._network_management_client import NetworkManagementClient +__all__ = ['NetworkManagementClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_configuration.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_configuration.py new file mode 100644 index 000000000000..bc5f270f66ac --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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 NetworkManagementClientConfiguration(Configuration): + """Configuration for NetworkManagementClient. + + 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 subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call. + :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(NetworkManagementClientConfiguration, 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-network/{}'.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/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_metadata.json b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_metadata.json new file mode 100644 index 000000000000..b09292dbec8f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_metadata.json @@ -0,0 +1,310 @@ +{ + "chosen_version": "2020-08-01", + "total_api_version_list": ["2018-10-01", "2020-08-01"], + "client": { + "name": "NetworkManagementClient", + "filename": "_network_management_client", + "description": "Network 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 subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call.", + "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 subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call.", + "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_gateways": "ApplicationGatewaysOperations", + "application_gateway_private_link_resources": "ApplicationGatewayPrivateLinkResourcesOperations", + "application_gateway_private_endpoint_connections": "ApplicationGatewayPrivateEndpointConnectionsOperations", + "application_security_groups": "ApplicationSecurityGroupsOperations", + "available_delegations": "AvailableDelegationsOperations", + "available_resource_group_delegations": "AvailableResourceGroupDelegationsOperations", + "available_service_aliases": "AvailableServiceAliasesOperations", + "azure_firewalls": "AzureFirewallsOperations", + "azure_firewall_fqdn_tags": "AzureFirewallFqdnTagsOperations", + "web_categories": "WebCategoriesOperations", + "bastion_hosts": "BastionHostsOperations", + "custom_ip_prefixes": "CustomIPPrefixesOperations", + "ddos_custom_policies": "DdosCustomPoliciesOperations", + "ddos_protection_plans": "DdosProtectionPlansOperations", + "dscp_configuration": "DscpConfigurationOperations", + "available_endpoint_services": "AvailableEndpointServicesOperations", + "express_route_circuit_authorizations": "ExpressRouteCircuitAuthorizationsOperations", + "express_route_circuit_peerings": "ExpressRouteCircuitPeeringsOperations", + "express_route_circuit_connections": "ExpressRouteCircuitConnectionsOperations", + "peer_express_route_circuit_connections": "PeerExpressRouteCircuitConnectionsOperations", + "express_route_circuits": "ExpressRouteCircuitsOperations", + "express_route_service_providers": "ExpressRouteServiceProvidersOperations", + "express_route_cross_connections": "ExpressRouteCrossConnectionsOperations", + "express_route_cross_connection_peerings": "ExpressRouteCrossConnectionPeeringsOperations", + "express_route_ports_locations": "ExpressRoutePortsLocationsOperations", + "express_route_ports": "ExpressRoutePortsOperations", + "express_route_links": "ExpressRouteLinksOperations", + "firewall_policies": "FirewallPoliciesOperations", + "firewall_policy_rule_collection_groups": "FirewallPolicyRuleCollectionGroupsOperations", + "ip_allocations": "IpAllocationsOperations", + "ip_groups": "IpGroupsOperations", + "load_balancers": "LoadBalancersOperations", + "load_balancer_backend_address_pools": "LoadBalancerBackendAddressPoolsOperations", + "load_balancer_frontend_ip_configurations": "LoadBalancerFrontendIPConfigurationsOperations", + "inbound_nat_rules": "InboundNatRulesOperations", + "load_balancer_load_balancing_rules": "LoadBalancerLoadBalancingRulesOperations", + "load_balancer_outbound_rules": "LoadBalancerOutboundRulesOperations", + "load_balancer_network_interfaces": "LoadBalancerNetworkInterfacesOperations", + "load_balancer_probes": "LoadBalancerProbesOperations", + "nat_gateways": "NatGatewaysOperations", + "network_interfaces": "NetworkInterfacesOperations", + "network_interface_ip_configurations": "NetworkInterfaceIPConfigurationsOperations", + "network_interface_load_balancers": "NetworkInterfaceLoadBalancersOperations", + "network_interface_tap_configurations": "NetworkInterfaceTapConfigurationsOperations", + "network_profiles": "NetworkProfilesOperations", + "network_security_groups": "NetworkSecurityGroupsOperations", + "security_rules": "SecurityRulesOperations", + "default_security_rules": "DefaultSecurityRulesOperations", + "network_virtual_appliances": "NetworkVirtualAppliancesOperations", + "virtual_appliance_sites": "VirtualApplianceSitesOperations", + "virtual_appliance_skus": "VirtualApplianceSkusOperations", + "inbound_security_rule": "InboundSecurityRuleOperations", + "network_watchers": "NetworkWatchersOperations", + "packet_captures": "PacketCapturesOperations", + "connection_monitors": "ConnectionMonitorsOperations", + "flow_logs": "FlowLogsOperations", + "operations": "Operations", + "private_endpoints": "PrivateEndpointsOperations", + "available_private_endpoint_types": "AvailablePrivateEndpointTypesOperations", + "private_dns_zone_groups": "PrivateDnsZoneGroupsOperations", + "private_link_services": "PrivateLinkServicesOperations", + "public_ip_addresses": "PublicIPAddressesOperations", + "public_ip_prefixes": "PublicIPPrefixesOperations", + "route_filters": "RouteFiltersOperations", + "route_filter_rules": "RouteFilterRulesOperations", + "route_tables": "RouteTablesOperations", + "routes": "RoutesOperations", + "security_partner_providers": "SecurityPartnerProvidersOperations", + "bgp_service_communities": "BgpServiceCommunitiesOperations", + "service_endpoint_policies": "ServiceEndpointPoliciesOperations", + "service_endpoint_policy_definitions": "ServiceEndpointPolicyDefinitionsOperations", + "service_tags": "ServiceTagsOperations", + "usages": "UsagesOperations", + "virtual_networks": "VirtualNetworksOperations", + "subnets": "SubnetsOperations", + "resource_navigation_links": "ResourceNavigationLinksOperations", + "service_association_links": "ServiceAssociationLinksOperations", + "virtual_network_peerings": "VirtualNetworkPeeringsOperations", + "virtual_network_gateways": "VirtualNetworkGatewaysOperations", + "virtual_network_gateway_connections": "VirtualNetworkGatewayConnectionsOperations", + "local_network_gateways": "LocalNetworkGatewaysOperations", + "virtual_network_taps": "VirtualNetworkTapsOperations", + "virtual_routers": "VirtualRoutersOperations", + "virtual_router_peerings": "VirtualRouterPeeringsOperations", + "virtual_wans": "VirtualWansOperations", + "vpn_sites": "VpnSitesOperations", + "vpn_site_links": "VpnSiteLinksOperations", + "vpn_sites_configuration": "VpnSitesConfigurationOperations", + "vpn_server_configurations": "VpnServerConfigurationsOperations", + "virtual_hubs": "VirtualHubsOperations", + "hub_virtual_network_connections": "HubVirtualNetworkConnectionsOperations", + "vpn_gateways": "VpnGatewaysOperations", + "vpn_connections": "VpnConnectionsOperations", + "vpn_site_link_connections": "VpnSiteLinkConnectionsOperations", + "vpn_link_connections": "VpnLinkConnectionsOperations", + "nat_rules": "NatRulesOperations", + "p2_svpn_gateways": "P2SVpnGatewaysOperations", + "vpn_server_configurations_associated_with_virtual_wan": "VpnServerConfigurationsAssociatedWithVirtualWanOperations", + "virtual_hub_route_table_v2_s": "VirtualHubRouteTableV2SOperations", + "express_route_gateways": "ExpressRouteGatewaysOperations", + "express_route_connections": "ExpressRouteConnectionsOperations", + "virtual_hub_bgp_connection": "VirtualHubBgpConnectionOperations", + "virtual_hub_bgp_connections": "VirtualHubBgpConnectionsOperations", + "virtual_hub_ip_configuration": "VirtualHubIpConfigurationOperations", + "hub_route_tables": "HubRouteTablesOperations", + "web_application_firewall_policies": "WebApplicationFirewallPoliciesOperations" + }, + "operation_mixins": { + "_put_bastion_shareable_link_initial" : { + "sync": { + "signature": "def _put_bastion_shareable_link_initial(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n bsl_request, # type: \"_models.BastionShareableLinkListRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: BastionShareableLinkListResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def _put_bastion_shareable_link_initial(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n bsl_request: \"_models.BastionShareableLinkListRequest\",\n **kwargs\n) -\u003e Optional[\"_models.BastionShareableLinkListResult\"]:\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: BastionShareableLinkListResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name, bsl_request" + }, + "begin_put_bastion_shareable_link" : { + "sync": { + "signature": "def begin_put_bastion_shareable_link(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n bsl_request, # type: \"_models.BastionShareableLinkListRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Creates a Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.PollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of LROPoller that returns an iterator like instance of either BastionShareableLinkListResult or the result of cls(response)\n:rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def begin_put_bastion_shareable_link(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n bsl_request: \"_models.BastionShareableLinkListRequest\",\n **kwargs\n) -\u003e AsyncLROPoller[AsyncItemPaged[\"_models.BastionShareableLinkListResult\"]]:\n", + "doc": "\"\"\"Creates a Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of AsyncLROPoller that returns an iterator like instance of either BastionShareableLinkListResult or the result of cls(response)\n:rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name, bsl_request" + }, + "_delete_bastion_shareable_link_initial" : { + "sync": { + "signature": "def _delete_bastion_shareable_link_initial(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n bsl_request, # type: \"_models.BastionShareableLinkListRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\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 _delete_bastion_shareable_link_initial(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n bsl_request: \"_models.BastionShareableLinkListRequest\",\n **kwargs\n) -\u003e None:\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\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, bastion_host_name, bsl_request" + }, + "begin_delete_bastion_shareable_link" : { + "sync": { + "signature": "def begin_delete_bastion_shareable_link(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n bsl_request, # type: \"_models.BastionShareableLinkListRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Deletes the Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.PollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of LROPoller that returns either None or the result of cls(response)\n:rtype: ~azure.core.polling.LROPoller[None]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def begin_delete_bastion_shareable_link(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n bsl_request: \"_models.BastionShareableLinkListRequest\",\n **kwargs\n) -\u003e AsyncLROPoller[None]:\n", + "doc": "\"\"\"Deletes the Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of AsyncLROPoller that returns either None or the result of cls(response)\n:rtype: ~azure.core.polling.AsyncLROPoller[None]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name, bsl_request" + }, + "get_bastion_shareable_link" : { + "sync": { + "signature": "def get_bastion_shareable_link(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n bsl_request, # type: \"_models.BastionShareableLinkListRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Return the Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def get_bastion_shareable_link(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n bsl_request: \"_models.BastionShareableLinkListRequest\",\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.BastionShareableLinkListResult\"]:\n", + "doc": "\"\"\"Return the Bastion Shareable Links for all the VMs specified in the request.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param bsl_request: Post request for all the Bastion Shareable Link endpoints.\n:type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name, bsl_request" + }, + "_get_active_sessions_initial" : { + "sync": { + "signature": "def _get_active_sessions_initial(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: BastionActiveSessionListResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def _get_active_sessions_initial(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n **kwargs\n) -\u003e Optional[\"_models.BastionActiveSessionListResult\"]:\n", + "doc": "\"\"\"\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: BastionActiveSessionListResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name" + }, + "begin_get_active_sessions" : { + "sync": { + "signature": "def begin_get_active_sessions(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Returns the list of currently active sessions on the Bastion.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.PollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of LROPoller that returns an iterator like instance of either BastionActiveSessionListResult or the result of cls(response)\n:rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def begin_get_active_sessions(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n **kwargs\n) -\u003e AsyncLROPoller[AsyncItemPaged[\"_models.BastionActiveSessionListResult\"]]:\n", + "doc": "\"\"\"Returns the list of currently active sessions on the Bastion.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of AsyncLROPoller that returns an iterator like instance of either BastionActiveSessionListResult or the result of cls(response)\n:rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name" + }, + "disconnect_active_sessions" : { + "sync": { + "signature": "def disconnect_active_sessions(\n self,\n resource_group_name, # type: str\n bastion_host_name, # type: str\n session_ids, # type: \"_models.SessionIds\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Returns the list of currently active sessions on the Bastion.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param session_ids: The list of sessionids to disconnect.\n:type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def disconnect_active_sessions(\n self,\n resource_group_name: str,\n bastion_host_name: str,\n session_ids: \"_models.SessionIds\",\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.BastionSessionDeleteResult\"]:\n", + "doc": "\"\"\"Returns the list of currently active sessions on the Bastion.\n\n:param resource_group_name: The name of the resource group.\n:type resource_group_name: str\n:param bastion_host_name: The name of the Bastion Host.\n:type bastion_host_name: str\n:param session_ids: The list of sessionids to disconnect.\n:type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, bastion_host_name, session_ids" + }, + "check_dns_name_availability" : { + "sync": { + "signature": "def check_dns_name_availability(\n self,\n location, # type: str\n domain_name_label, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Checks whether a domain name in the cloudapp.azure.com zone is available for use.\n\n:param location: The location of the domain name.\n:type location: str\n:param domain_name_label: The domain name to be verified. It must conform to the following\n regular expression: ^[a-z][a-z0-9-]{1,61}[a-z0-9]$.\n:type domain_name_label: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DnsNameAvailabilityResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def check_dns_name_availability(\n self,\n location: str,\n domain_name_label: str,\n **kwargs\n) -\u003e \"_models.DnsNameAvailabilityResult\":\n", + "doc": "\"\"\"Checks whether a domain name in the cloudapp.azure.com zone is available for use.\n\n:param location: The location of the domain name.\n:type location: str\n:param domain_name_label: The domain name to be verified. It must conform to the following\n regular expression: ^[a-z][a-z0-9-]{1,61}[a-z0-9]$.\n:type domain_name_label: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DnsNameAvailabilityResult, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "location, domain_name_label" + }, + "supported_security_providers" : { + "sync": { + "signature": "def supported_security_providers(\n self,\n resource_group_name, # type: str\n virtual_wan_name, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gives the supported security providers for the virtual wan.\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN for which supported security providers are\n needed.\n:type virtual_wan_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VirtualWanSecurityProviders, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def supported_security_providers(\n self,\n resource_group_name: str,\n virtual_wan_name: str,\n **kwargs\n) -\u003e \"_models.VirtualWanSecurityProviders\":\n", + "doc": "\"\"\"Gives the supported security providers for the virtual wan.\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN for which supported security providers are\n needed.\n:type virtual_wan_name: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VirtualWanSecurityProviders, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, virtual_wan_name" + }, + "_generatevirtualwanvpnserverconfigurationvpnprofile_initial" : { + "sync": { + "signature": "def _generatevirtualwanvpnserverconfigurationvpnprofile_initial(\n self,\n resource_group_name, # type: str\n virtual_wan_name, # type: str\n vpn_client_params, # type: \"_models.VirtualWanVpnProfileParameters\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is\n needed.\n:type virtual_wan_name: str\n:param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation\n operation.\n:type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VpnProfileResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def _generatevirtualwanvpnserverconfigurationvpnprofile_initial(\n self,\n resource_group_name: str,\n virtual_wan_name: str,\n vpn_client_params: \"_models.VirtualWanVpnProfileParameters\",\n **kwargs\n) -\u003e Optional[\"_models.VpnProfileResponse\"]:\n", + "doc": "\"\"\"\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is\n needed.\n:type virtual_wan_name: str\n:param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation\n operation.\n:type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VpnProfileResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse or None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, virtual_wan_name, vpn_client_params" + }, + "begin_generatevirtualwanvpnserverconfigurationvpnprofile" : { + "sync": { + "signature": "def begin_generatevirtualwanvpnserverconfigurationvpnprofile(\n self,\n resource_group_name, # type: str\n virtual_wan_name, # type: str\n vpn_client_params, # type: \"_models.VirtualWanVpnProfileParameters\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Generates a unique VPN profile for P2S clients for VirtualWan and associated\nVpnServerConfiguration combination in the specified resource group.\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is\n needed.\n:type virtual_wan_name: str\n:param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation\n operation.\n:type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.PollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of LROPoller that returns either VpnProfileResponse or the result of cls(response)\n:rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def begin_generatevirtualwanvpnserverconfigurationvpnprofile(\n self,\n resource_group_name: str,\n virtual_wan_name: str,\n vpn_client_params: \"_models.VirtualWanVpnProfileParameters\",\n **kwargs\n) -\u003e AsyncLROPoller[\"_models.VpnProfileResponse\"]:\n", + "doc": "\"\"\"Generates a unique VPN profile for P2S clients for VirtualWan and associated\nVpnServerConfiguration combination in the specified resource group.\n\n:param resource_group_name: The resource group name.\n:type resource_group_name: str\n:param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is\n needed.\n:type virtual_wan_name: str\n:param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation\n operation.\n:type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:keyword str continuation_token: A continuation token to restart a poller from a saved state.\n:keyword polling: True for ARMPolling, False for no polling, or a\n polling object for personal polling strategy\n:paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod\n:keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present.\n:return: An instance of AsyncLROPoller that returns either VpnProfileResponse or the result of cls(response)\n:rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse]\n:raises ~azure.core.exceptions.HttpResponseError:\n\"\"\"" + }, + "call": "resource_group_name, virtual_wan_name, vpn_client_params" + } + }, + "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.polling\": [\"LROPoller\", \"NoPolling\", \"PollingMethod\"], \"azure.mgmt.core.polling.arm_polling\": [\"ARMPolling\"], \"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.polling\": [\"AsyncLROPoller\", \"AsyncNoPolling\", \"AsyncPollingMethod\"], \"azure.mgmt.core.polling.async_arm_polling\": [\"AsyncARMPolling\"], \"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/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_network_management_client.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_network_management_client.py new file mode 100644 index 000000000000..bd4b75edc116 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/_network_management_client.py @@ -0,0 +1,595 @@ +# 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 NetworkManagementClientConfiguration +from .operations import ApplicationGatewaysOperations +from .operations import ApplicationGatewayPrivateLinkResourcesOperations +from .operations import ApplicationGatewayPrivateEndpointConnectionsOperations +from .operations import ApplicationSecurityGroupsOperations +from .operations import AvailableDelegationsOperations +from .operations import AvailableResourceGroupDelegationsOperations +from .operations import AvailableServiceAliasesOperations +from .operations import AzureFirewallsOperations +from .operations import AzureFirewallFqdnTagsOperations +from .operations import WebCategoriesOperations +from .operations import BastionHostsOperations +from .operations import NetworkManagementClientOperationsMixin +from .operations import CustomIPPrefixesOperations +from .operations import DdosCustomPoliciesOperations +from .operations import DdosProtectionPlansOperations +from .operations import DscpConfigurationOperations +from .operations import AvailableEndpointServicesOperations +from .operations import ExpressRouteCircuitAuthorizationsOperations +from .operations import ExpressRouteCircuitPeeringsOperations +from .operations import ExpressRouteCircuitConnectionsOperations +from .operations import PeerExpressRouteCircuitConnectionsOperations +from .operations import ExpressRouteCircuitsOperations +from .operations import ExpressRouteServiceProvidersOperations +from .operations import ExpressRouteCrossConnectionsOperations +from .operations import ExpressRouteCrossConnectionPeeringsOperations +from .operations import ExpressRoutePortsLocationsOperations +from .operations import ExpressRoutePortsOperations +from .operations import ExpressRouteLinksOperations +from .operations import FirewallPoliciesOperations +from .operations import FirewallPolicyRuleCollectionGroupsOperations +from .operations import IpAllocationsOperations +from .operations import IpGroupsOperations +from .operations import LoadBalancersOperations +from .operations import LoadBalancerBackendAddressPoolsOperations +from .operations import LoadBalancerFrontendIPConfigurationsOperations +from .operations import InboundNatRulesOperations +from .operations import LoadBalancerLoadBalancingRulesOperations +from .operations import LoadBalancerOutboundRulesOperations +from .operations import LoadBalancerNetworkInterfacesOperations +from .operations import LoadBalancerProbesOperations +from .operations import NatGatewaysOperations +from .operations import NetworkInterfacesOperations +from .operations import NetworkInterfaceIPConfigurationsOperations +from .operations import NetworkInterfaceLoadBalancersOperations +from .operations import NetworkInterfaceTapConfigurationsOperations +from .operations import NetworkProfilesOperations +from .operations import NetworkSecurityGroupsOperations +from .operations import SecurityRulesOperations +from .operations import DefaultSecurityRulesOperations +from .operations import NetworkVirtualAppliancesOperations +from .operations import VirtualApplianceSitesOperations +from .operations import VirtualApplianceSkusOperations +from .operations import InboundSecurityRuleOperations +from .operations import NetworkWatchersOperations +from .operations import PacketCapturesOperations +from .operations import ConnectionMonitorsOperations +from .operations import FlowLogsOperations +from .operations import Operations +from .operations import PrivateEndpointsOperations +from .operations import AvailablePrivateEndpointTypesOperations +from .operations import PrivateDnsZoneGroupsOperations +from .operations import PrivateLinkServicesOperations +from .operations import PublicIPAddressesOperations +from .operations import PublicIPPrefixesOperations +from .operations import RouteFiltersOperations +from .operations import RouteFilterRulesOperations +from .operations import RouteTablesOperations +from .operations import RoutesOperations +from .operations import SecurityPartnerProvidersOperations +from .operations import BgpServiceCommunitiesOperations +from .operations import ServiceEndpointPoliciesOperations +from .operations import ServiceEndpointPolicyDefinitionsOperations +from .operations import ServiceTagsOperations +from .operations import UsagesOperations +from .operations import VirtualNetworksOperations +from .operations import SubnetsOperations +from .operations import ResourceNavigationLinksOperations +from .operations import ServiceAssociationLinksOperations +from .operations import VirtualNetworkPeeringsOperations +from .operations import VirtualNetworkGatewaysOperations +from .operations import VirtualNetworkGatewayConnectionsOperations +from .operations import LocalNetworkGatewaysOperations +from .operations import VirtualNetworkTapsOperations +from .operations import VirtualRoutersOperations +from .operations import VirtualRouterPeeringsOperations +from .operations import VirtualWansOperations +from .operations import VpnSitesOperations +from .operations import VpnSiteLinksOperations +from .operations import VpnSitesConfigurationOperations +from .operations import VpnServerConfigurationsOperations +from .operations import VirtualHubsOperations +from .operations import HubVirtualNetworkConnectionsOperations +from .operations import VpnGatewaysOperations +from .operations import VpnConnectionsOperations +from .operations import VpnSiteLinkConnectionsOperations +from .operations import VpnLinkConnectionsOperations +from .operations import NatRulesOperations +from .operations import P2SVpnGatewaysOperations +from .operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations +from .operations import VirtualHubRouteTableV2SOperations +from .operations import ExpressRouteGatewaysOperations +from .operations import ExpressRouteConnectionsOperations +from .operations import VirtualHubBgpConnectionOperations +from .operations import VirtualHubBgpConnectionsOperations +from .operations import VirtualHubIpConfigurationOperations +from .operations import HubRouteTablesOperations +from .operations import WebApplicationFirewallPoliciesOperations +from . import models + + +class NetworkManagementClient(NetworkManagementClientOperationsMixin): + """Network Client. + + :ivar application_gateways: ApplicationGatewaysOperations operations + :vartype application_gateways: azure.mgmt.network.v2020_08_01.operations.ApplicationGatewaysOperations + :ivar application_gateway_private_link_resources: ApplicationGatewayPrivateLinkResourcesOperations operations + :vartype application_gateway_private_link_resources: azure.mgmt.network.v2020_08_01.operations.ApplicationGatewayPrivateLinkResourcesOperations + :ivar application_gateway_private_endpoint_connections: ApplicationGatewayPrivateEndpointConnectionsOperations operations + :vartype application_gateway_private_endpoint_connections: azure.mgmt.network.v2020_08_01.operations.ApplicationGatewayPrivateEndpointConnectionsOperations + :ivar application_security_groups: ApplicationSecurityGroupsOperations operations + :vartype application_security_groups: azure.mgmt.network.v2020_08_01.operations.ApplicationSecurityGroupsOperations + :ivar available_delegations: AvailableDelegationsOperations operations + :vartype available_delegations: azure.mgmt.network.v2020_08_01.operations.AvailableDelegationsOperations + :ivar available_resource_group_delegations: AvailableResourceGroupDelegationsOperations operations + :vartype available_resource_group_delegations: azure.mgmt.network.v2020_08_01.operations.AvailableResourceGroupDelegationsOperations + :ivar available_service_aliases: AvailableServiceAliasesOperations operations + :vartype available_service_aliases: azure.mgmt.network.v2020_08_01.operations.AvailableServiceAliasesOperations + :ivar azure_firewalls: AzureFirewallsOperations operations + :vartype azure_firewalls: azure.mgmt.network.v2020_08_01.operations.AzureFirewallsOperations + :ivar azure_firewall_fqdn_tags: AzureFirewallFqdnTagsOperations operations + :vartype azure_firewall_fqdn_tags: azure.mgmt.network.v2020_08_01.operations.AzureFirewallFqdnTagsOperations + :ivar web_categories: WebCategoriesOperations operations + :vartype web_categories: azure.mgmt.network.v2020_08_01.operations.WebCategoriesOperations + :ivar bastion_hosts: BastionHostsOperations operations + :vartype bastion_hosts: azure.mgmt.network.v2020_08_01.operations.BastionHostsOperations + :ivar custom_ip_prefixes: CustomIPPrefixesOperations operations + :vartype custom_ip_prefixes: azure.mgmt.network.v2020_08_01.operations.CustomIPPrefixesOperations + :ivar ddos_custom_policies: DdosCustomPoliciesOperations operations + :vartype ddos_custom_policies: azure.mgmt.network.v2020_08_01.operations.DdosCustomPoliciesOperations + :ivar ddos_protection_plans: DdosProtectionPlansOperations operations + :vartype ddos_protection_plans: azure.mgmt.network.v2020_08_01.operations.DdosProtectionPlansOperations + :ivar dscp_configuration: DscpConfigurationOperations operations + :vartype dscp_configuration: azure.mgmt.network.v2020_08_01.operations.DscpConfigurationOperations + :ivar available_endpoint_services: AvailableEndpointServicesOperations operations + :vartype available_endpoint_services: azure.mgmt.network.v2020_08_01.operations.AvailableEndpointServicesOperations + :ivar express_route_circuit_authorizations: ExpressRouteCircuitAuthorizationsOperations operations + :vartype express_route_circuit_authorizations: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCircuitAuthorizationsOperations + :ivar express_route_circuit_peerings: ExpressRouteCircuitPeeringsOperations operations + :vartype express_route_circuit_peerings: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCircuitPeeringsOperations + :ivar express_route_circuit_connections: ExpressRouteCircuitConnectionsOperations operations + :vartype express_route_circuit_connections: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCircuitConnectionsOperations + :ivar peer_express_route_circuit_connections: PeerExpressRouteCircuitConnectionsOperations operations + :vartype peer_express_route_circuit_connections: azure.mgmt.network.v2020_08_01.operations.PeerExpressRouteCircuitConnectionsOperations + :ivar express_route_circuits: ExpressRouteCircuitsOperations operations + :vartype express_route_circuits: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCircuitsOperations + :ivar express_route_service_providers: ExpressRouteServiceProvidersOperations operations + :vartype express_route_service_providers: azure.mgmt.network.v2020_08_01.operations.ExpressRouteServiceProvidersOperations + :ivar express_route_cross_connections: ExpressRouteCrossConnectionsOperations operations + :vartype express_route_cross_connections: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCrossConnectionsOperations + :ivar express_route_cross_connection_peerings: ExpressRouteCrossConnectionPeeringsOperations operations + :vartype express_route_cross_connection_peerings: azure.mgmt.network.v2020_08_01.operations.ExpressRouteCrossConnectionPeeringsOperations + :ivar express_route_ports_locations: ExpressRoutePortsLocationsOperations operations + :vartype express_route_ports_locations: azure.mgmt.network.v2020_08_01.operations.ExpressRoutePortsLocationsOperations + :ivar express_route_ports: ExpressRoutePortsOperations operations + :vartype express_route_ports: azure.mgmt.network.v2020_08_01.operations.ExpressRoutePortsOperations + :ivar express_route_links: ExpressRouteLinksOperations operations + :vartype express_route_links: azure.mgmt.network.v2020_08_01.operations.ExpressRouteLinksOperations + :ivar firewall_policies: FirewallPoliciesOperations operations + :vartype firewall_policies: azure.mgmt.network.v2020_08_01.operations.FirewallPoliciesOperations + :ivar firewall_policy_rule_collection_groups: FirewallPolicyRuleCollectionGroupsOperations operations + :vartype firewall_policy_rule_collection_groups: azure.mgmt.network.v2020_08_01.operations.FirewallPolicyRuleCollectionGroupsOperations + :ivar ip_allocations: IpAllocationsOperations operations + :vartype ip_allocations: azure.mgmt.network.v2020_08_01.operations.IpAllocationsOperations + :ivar ip_groups: IpGroupsOperations operations + :vartype ip_groups: azure.mgmt.network.v2020_08_01.operations.IpGroupsOperations + :ivar load_balancers: LoadBalancersOperations operations + :vartype load_balancers: azure.mgmt.network.v2020_08_01.operations.LoadBalancersOperations + :ivar load_balancer_backend_address_pools: LoadBalancerBackendAddressPoolsOperations operations + :vartype load_balancer_backend_address_pools: azure.mgmt.network.v2020_08_01.operations.LoadBalancerBackendAddressPoolsOperations + :ivar load_balancer_frontend_ip_configurations: LoadBalancerFrontendIPConfigurationsOperations operations + :vartype load_balancer_frontend_ip_configurations: azure.mgmt.network.v2020_08_01.operations.LoadBalancerFrontendIPConfigurationsOperations + :ivar inbound_nat_rules: InboundNatRulesOperations operations + :vartype inbound_nat_rules: azure.mgmt.network.v2020_08_01.operations.InboundNatRulesOperations + :ivar load_balancer_load_balancing_rules: LoadBalancerLoadBalancingRulesOperations operations + :vartype load_balancer_load_balancing_rules: azure.mgmt.network.v2020_08_01.operations.LoadBalancerLoadBalancingRulesOperations + :ivar load_balancer_outbound_rules: LoadBalancerOutboundRulesOperations operations + :vartype load_balancer_outbound_rules: azure.mgmt.network.v2020_08_01.operations.LoadBalancerOutboundRulesOperations + :ivar load_balancer_network_interfaces: LoadBalancerNetworkInterfacesOperations operations + :vartype load_balancer_network_interfaces: azure.mgmt.network.v2020_08_01.operations.LoadBalancerNetworkInterfacesOperations + :ivar load_balancer_probes: LoadBalancerProbesOperations operations + :vartype load_balancer_probes: azure.mgmt.network.v2020_08_01.operations.LoadBalancerProbesOperations + :ivar nat_gateways: NatGatewaysOperations operations + :vartype nat_gateways: azure.mgmt.network.v2020_08_01.operations.NatGatewaysOperations + :ivar network_interfaces: NetworkInterfacesOperations operations + :vartype network_interfaces: azure.mgmt.network.v2020_08_01.operations.NetworkInterfacesOperations + :ivar network_interface_ip_configurations: NetworkInterfaceIPConfigurationsOperations operations + :vartype network_interface_ip_configurations: azure.mgmt.network.v2020_08_01.operations.NetworkInterfaceIPConfigurationsOperations + :ivar network_interface_load_balancers: NetworkInterfaceLoadBalancersOperations operations + :vartype network_interface_load_balancers: azure.mgmt.network.v2020_08_01.operations.NetworkInterfaceLoadBalancersOperations + :ivar network_interface_tap_configurations: NetworkInterfaceTapConfigurationsOperations operations + :vartype network_interface_tap_configurations: azure.mgmt.network.v2020_08_01.operations.NetworkInterfaceTapConfigurationsOperations + :ivar network_profiles: NetworkProfilesOperations operations + :vartype network_profiles: azure.mgmt.network.v2020_08_01.operations.NetworkProfilesOperations + :ivar network_security_groups: NetworkSecurityGroupsOperations operations + :vartype network_security_groups: azure.mgmt.network.v2020_08_01.operations.NetworkSecurityGroupsOperations + :ivar security_rules: SecurityRulesOperations operations + :vartype security_rules: azure.mgmt.network.v2020_08_01.operations.SecurityRulesOperations + :ivar default_security_rules: DefaultSecurityRulesOperations operations + :vartype default_security_rules: azure.mgmt.network.v2020_08_01.operations.DefaultSecurityRulesOperations + :ivar network_virtual_appliances: NetworkVirtualAppliancesOperations operations + :vartype network_virtual_appliances: azure.mgmt.network.v2020_08_01.operations.NetworkVirtualAppliancesOperations + :ivar virtual_appliance_sites: VirtualApplianceSitesOperations operations + :vartype virtual_appliance_sites: azure.mgmt.network.v2020_08_01.operations.VirtualApplianceSitesOperations + :ivar virtual_appliance_skus: VirtualApplianceSkusOperations operations + :vartype virtual_appliance_skus: azure.mgmt.network.v2020_08_01.operations.VirtualApplianceSkusOperations + :ivar inbound_security_rule: InboundSecurityRuleOperations operations + :vartype inbound_security_rule: azure.mgmt.network.v2020_08_01.operations.InboundSecurityRuleOperations + :ivar network_watchers: NetworkWatchersOperations operations + :vartype network_watchers: azure.mgmt.network.v2020_08_01.operations.NetworkWatchersOperations + :ivar packet_captures: PacketCapturesOperations operations + :vartype packet_captures: azure.mgmt.network.v2020_08_01.operations.PacketCapturesOperations + :ivar connection_monitors: ConnectionMonitorsOperations operations + :vartype connection_monitors: azure.mgmt.network.v2020_08_01.operations.ConnectionMonitorsOperations + :ivar flow_logs: FlowLogsOperations operations + :vartype flow_logs: azure.mgmt.network.v2020_08_01.operations.FlowLogsOperations + :ivar operations: Operations operations + :vartype operations: azure.mgmt.network.v2020_08_01.operations.Operations + :ivar private_endpoints: PrivateEndpointsOperations operations + :vartype private_endpoints: azure.mgmt.network.v2020_08_01.operations.PrivateEndpointsOperations + :ivar available_private_endpoint_types: AvailablePrivateEndpointTypesOperations operations + :vartype available_private_endpoint_types: azure.mgmt.network.v2020_08_01.operations.AvailablePrivateEndpointTypesOperations + :ivar private_dns_zone_groups: PrivateDnsZoneGroupsOperations operations + :vartype private_dns_zone_groups: azure.mgmt.network.v2020_08_01.operations.PrivateDnsZoneGroupsOperations + :ivar private_link_services: PrivateLinkServicesOperations operations + :vartype private_link_services: azure.mgmt.network.v2020_08_01.operations.PrivateLinkServicesOperations + :ivar public_ip_addresses: PublicIPAddressesOperations operations + :vartype public_ip_addresses: azure.mgmt.network.v2020_08_01.operations.PublicIPAddressesOperations + :ivar public_ip_prefixes: PublicIPPrefixesOperations operations + :vartype public_ip_prefixes: azure.mgmt.network.v2020_08_01.operations.PublicIPPrefixesOperations + :ivar route_filters: RouteFiltersOperations operations + :vartype route_filters: azure.mgmt.network.v2020_08_01.operations.RouteFiltersOperations + :ivar route_filter_rules: RouteFilterRulesOperations operations + :vartype route_filter_rules: azure.mgmt.network.v2020_08_01.operations.RouteFilterRulesOperations + :ivar route_tables: RouteTablesOperations operations + :vartype route_tables: azure.mgmt.network.v2020_08_01.operations.RouteTablesOperations + :ivar routes: RoutesOperations operations + :vartype routes: azure.mgmt.network.v2020_08_01.operations.RoutesOperations + :ivar security_partner_providers: SecurityPartnerProvidersOperations operations + :vartype security_partner_providers: azure.mgmt.network.v2020_08_01.operations.SecurityPartnerProvidersOperations + :ivar bgp_service_communities: BgpServiceCommunitiesOperations operations + :vartype bgp_service_communities: azure.mgmt.network.v2020_08_01.operations.BgpServiceCommunitiesOperations + :ivar service_endpoint_policies: ServiceEndpointPoliciesOperations operations + :vartype service_endpoint_policies: azure.mgmt.network.v2020_08_01.operations.ServiceEndpointPoliciesOperations + :ivar service_endpoint_policy_definitions: ServiceEndpointPolicyDefinitionsOperations operations + :vartype service_endpoint_policy_definitions: azure.mgmt.network.v2020_08_01.operations.ServiceEndpointPolicyDefinitionsOperations + :ivar service_tags: ServiceTagsOperations operations + :vartype service_tags: azure.mgmt.network.v2020_08_01.operations.ServiceTagsOperations + :ivar usages: UsagesOperations operations + :vartype usages: azure.mgmt.network.v2020_08_01.operations.UsagesOperations + :ivar virtual_networks: VirtualNetworksOperations operations + :vartype virtual_networks: azure.mgmt.network.v2020_08_01.operations.VirtualNetworksOperations + :ivar subnets: SubnetsOperations operations + :vartype subnets: azure.mgmt.network.v2020_08_01.operations.SubnetsOperations + :ivar resource_navigation_links: ResourceNavigationLinksOperations operations + :vartype resource_navigation_links: azure.mgmt.network.v2020_08_01.operations.ResourceNavigationLinksOperations + :ivar service_association_links: ServiceAssociationLinksOperations operations + :vartype service_association_links: azure.mgmt.network.v2020_08_01.operations.ServiceAssociationLinksOperations + :ivar virtual_network_peerings: VirtualNetworkPeeringsOperations operations + :vartype virtual_network_peerings: azure.mgmt.network.v2020_08_01.operations.VirtualNetworkPeeringsOperations + :ivar virtual_network_gateways: VirtualNetworkGatewaysOperations operations + :vartype virtual_network_gateways: azure.mgmt.network.v2020_08_01.operations.VirtualNetworkGatewaysOperations + :ivar virtual_network_gateway_connections: VirtualNetworkGatewayConnectionsOperations operations + :vartype virtual_network_gateway_connections: azure.mgmt.network.v2020_08_01.operations.VirtualNetworkGatewayConnectionsOperations + :ivar local_network_gateways: LocalNetworkGatewaysOperations operations + :vartype local_network_gateways: azure.mgmt.network.v2020_08_01.operations.LocalNetworkGatewaysOperations + :ivar virtual_network_taps: VirtualNetworkTapsOperations operations + :vartype virtual_network_taps: azure.mgmt.network.v2020_08_01.operations.VirtualNetworkTapsOperations + :ivar virtual_routers: VirtualRoutersOperations operations + :vartype virtual_routers: azure.mgmt.network.v2020_08_01.operations.VirtualRoutersOperations + :ivar virtual_router_peerings: VirtualRouterPeeringsOperations operations + :vartype virtual_router_peerings: azure.mgmt.network.v2020_08_01.operations.VirtualRouterPeeringsOperations + :ivar virtual_wans: VirtualWansOperations operations + :vartype virtual_wans: azure.mgmt.network.v2020_08_01.operations.VirtualWansOperations + :ivar vpn_sites: VpnSitesOperations operations + :vartype vpn_sites: azure.mgmt.network.v2020_08_01.operations.VpnSitesOperations + :ivar vpn_site_links: VpnSiteLinksOperations operations + :vartype vpn_site_links: azure.mgmt.network.v2020_08_01.operations.VpnSiteLinksOperations + :ivar vpn_sites_configuration: VpnSitesConfigurationOperations operations + :vartype vpn_sites_configuration: azure.mgmt.network.v2020_08_01.operations.VpnSitesConfigurationOperations + :ivar vpn_server_configurations: VpnServerConfigurationsOperations operations + :vartype vpn_server_configurations: azure.mgmt.network.v2020_08_01.operations.VpnServerConfigurationsOperations + :ivar virtual_hubs: VirtualHubsOperations operations + :vartype virtual_hubs: azure.mgmt.network.v2020_08_01.operations.VirtualHubsOperations + :ivar hub_virtual_network_connections: HubVirtualNetworkConnectionsOperations operations + :vartype hub_virtual_network_connections: azure.mgmt.network.v2020_08_01.operations.HubVirtualNetworkConnectionsOperations + :ivar vpn_gateways: VpnGatewaysOperations operations + :vartype vpn_gateways: azure.mgmt.network.v2020_08_01.operations.VpnGatewaysOperations + :ivar vpn_connections: VpnConnectionsOperations operations + :vartype vpn_connections: azure.mgmt.network.v2020_08_01.operations.VpnConnectionsOperations + :ivar vpn_site_link_connections: VpnSiteLinkConnectionsOperations operations + :vartype vpn_site_link_connections: azure.mgmt.network.v2020_08_01.operations.VpnSiteLinkConnectionsOperations + :ivar vpn_link_connections: VpnLinkConnectionsOperations operations + :vartype vpn_link_connections: azure.mgmt.network.v2020_08_01.operations.VpnLinkConnectionsOperations + :ivar nat_rules: NatRulesOperations operations + :vartype nat_rules: azure.mgmt.network.v2020_08_01.operations.NatRulesOperations + :ivar p2_svpn_gateways: P2SVpnGatewaysOperations operations + :vartype p2_svpn_gateways: azure.mgmt.network.v2020_08_01.operations.P2SVpnGatewaysOperations + :ivar vpn_server_configurations_associated_with_virtual_wan: VpnServerConfigurationsAssociatedWithVirtualWanOperations operations + :vartype vpn_server_configurations_associated_with_virtual_wan: azure.mgmt.network.v2020_08_01.operations.VpnServerConfigurationsAssociatedWithVirtualWanOperations + :ivar virtual_hub_route_table_v2_s: VirtualHubRouteTableV2SOperations operations + :vartype virtual_hub_route_table_v2_s: azure.mgmt.network.v2020_08_01.operations.VirtualHubRouteTableV2SOperations + :ivar express_route_gateways: ExpressRouteGatewaysOperations operations + :vartype express_route_gateways: azure.mgmt.network.v2020_08_01.operations.ExpressRouteGatewaysOperations + :ivar express_route_connections: ExpressRouteConnectionsOperations operations + :vartype express_route_connections: azure.mgmt.network.v2020_08_01.operations.ExpressRouteConnectionsOperations + :ivar virtual_hub_bgp_connection: VirtualHubBgpConnectionOperations operations + :vartype virtual_hub_bgp_connection: azure.mgmt.network.v2020_08_01.operations.VirtualHubBgpConnectionOperations + :ivar virtual_hub_bgp_connections: VirtualHubBgpConnectionsOperations operations + :vartype virtual_hub_bgp_connections: azure.mgmt.network.v2020_08_01.operations.VirtualHubBgpConnectionsOperations + :ivar virtual_hub_ip_configuration: VirtualHubIpConfigurationOperations operations + :vartype virtual_hub_ip_configuration: azure.mgmt.network.v2020_08_01.operations.VirtualHubIpConfigurationOperations + :ivar hub_route_tables: HubRouteTablesOperations operations + :vartype hub_route_tables: azure.mgmt.network.v2020_08_01.operations.HubRouteTablesOperations + :ivar web_application_firewall_policies: WebApplicationFirewallPoliciesOperations operations + :vartype web_application_firewall_policies: azure.mgmt.network.v2020_08_01.operations.WebApplicationFirewallPoliciesOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call. + :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 = NetworkManagementClientConfiguration(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_gateways = ApplicationGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_gateway_private_link_resources = ApplicationGatewayPrivateLinkResourcesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_gateway_private_endpoint_connections = ApplicationGatewayPrivateEndpointConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_security_groups = ApplicationSecurityGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_delegations = AvailableDelegationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_resource_group_delegations = AvailableResourceGroupDelegationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_service_aliases = AvailableServiceAliasesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.azure_firewalls = AzureFirewallsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.azure_firewall_fqdn_tags = AzureFirewallFqdnTagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_categories = WebCategoriesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.bastion_hosts = BastionHostsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.custom_ip_prefixes = CustomIPPrefixesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ddos_custom_policies = DdosCustomPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ddos_protection_plans = DdosProtectionPlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.dscp_configuration = DscpConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_endpoint_services = AvailableEndpointServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_authorizations = ExpressRouteCircuitAuthorizationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_peerings = ExpressRouteCircuitPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_connections = ExpressRouteCircuitConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.peer_express_route_circuit_connections = PeerExpressRouteCircuitConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuits = ExpressRouteCircuitsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_service_providers = ExpressRouteServiceProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_cross_connections = ExpressRouteCrossConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_cross_connection_peerings = ExpressRouteCrossConnectionPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_ports_locations = ExpressRoutePortsLocationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_ports = ExpressRoutePortsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_links = ExpressRouteLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.firewall_policies = FirewallPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.firewall_policy_rule_collection_groups = FirewallPolicyRuleCollectionGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ip_allocations = IpAllocationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ip_groups = IpGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancers = LoadBalancersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_backend_address_pools = LoadBalancerBackendAddressPoolsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_frontend_ip_configurations = LoadBalancerFrontendIPConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.inbound_nat_rules = InboundNatRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_load_balancing_rules = LoadBalancerLoadBalancingRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_outbound_rules = LoadBalancerOutboundRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_network_interfaces = LoadBalancerNetworkInterfacesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_probes = LoadBalancerProbesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.nat_gateways = NatGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interfaces = NetworkInterfacesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_ip_configurations = NetworkInterfaceIPConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_load_balancers = NetworkInterfaceLoadBalancersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_tap_configurations = NetworkInterfaceTapConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_profiles = NetworkProfilesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_security_groups = NetworkSecurityGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.security_rules = SecurityRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.default_security_rules = DefaultSecurityRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_virtual_appliances = NetworkVirtualAppliancesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_appliance_sites = VirtualApplianceSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_appliance_skus = VirtualApplianceSkusOperations( + self._client, self._config, self._serialize, self._deserialize) + self.inbound_security_rule = InboundSecurityRuleOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_watchers = NetworkWatchersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.packet_captures = PacketCapturesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.connection_monitors = ConnectionMonitorsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.flow_logs = FlowLogsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.private_endpoints = PrivateEndpointsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_private_endpoint_types = AvailablePrivateEndpointTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.private_dns_zone_groups = PrivateDnsZoneGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.private_link_services = PrivateLinkServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.public_ip_addresses = PublicIPAddressesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.public_ip_prefixes = PublicIPPrefixesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_filters = RouteFiltersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_filter_rules = RouteFilterRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_tables = RouteTablesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.routes = RoutesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.security_partner_providers = SecurityPartnerProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.bgp_service_communities = BgpServiceCommunitiesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_endpoint_policies = ServiceEndpointPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_endpoint_policy_definitions = ServiceEndpointPolicyDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_tags = ServiceTagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.usages = UsagesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_networks = VirtualNetworksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.subnets = SubnetsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_navigation_links = ResourceNavigationLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_association_links = ServiceAssociationLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_peerings = VirtualNetworkPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_gateways = VirtualNetworkGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_gateway_connections = VirtualNetworkGatewayConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.local_network_gateways = LocalNetworkGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_taps = VirtualNetworkTapsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_routers = VirtualRoutersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_router_peerings = VirtualRouterPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_wans = VirtualWansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_sites = VpnSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_site_links = VpnSiteLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_sites_configuration = VpnSitesConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_server_configurations = VpnServerConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hubs = VirtualHubsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.hub_virtual_network_connections = HubVirtualNetworkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_gateways = VpnGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_connections = VpnConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_site_link_connections = VpnSiteLinkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_link_connections = VpnLinkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.nat_rules = NatRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.p2_svpn_gateways = P2SVpnGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_server_configurations_associated_with_virtual_wan = VpnServerConfigurationsAssociatedWithVirtualWanOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_route_table_v2_s = VirtualHubRouteTableV2SOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_gateways = ExpressRouteGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_connections = ExpressRouteConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_bgp_connection = VirtualHubBgpConnectionOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_bgp_connections = VirtualHubBgpConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_ip_configuration = VirtualHubIpConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.hub_route_tables = HubRouteTablesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_application_firewall_policies = WebApplicationFirewallPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> NetworkManagementClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/__init__.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/__init__.py new file mode 100644 index 000000000000..1c78defcf225 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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 ._network_management_client import NetworkManagementClient +__all__ = ['NetworkManagementClient'] diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/_configuration.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/_configuration.py new file mode 100644 index 000000000000..13d69e860632 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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 NetworkManagementClientConfiguration(Configuration): + """Configuration for NetworkManagementClient. + + 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 subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call. + :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(NetworkManagementClientConfiguration, 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-network/{}'.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/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/_network_management_client.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/_network_management_client.py new file mode 100644 index 000000000000..06187ae8a250 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/_network_management_client.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, 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 NetworkManagementClientConfiguration +from .operations import ApplicationGatewaysOperations +from .operations import ApplicationGatewayPrivateLinkResourcesOperations +from .operations import ApplicationGatewayPrivateEndpointConnectionsOperations +from .operations import ApplicationSecurityGroupsOperations +from .operations import AvailableDelegationsOperations +from .operations import AvailableResourceGroupDelegationsOperations +from .operations import AvailableServiceAliasesOperations +from .operations import AzureFirewallsOperations +from .operations import AzureFirewallFqdnTagsOperations +from .operations import WebCategoriesOperations +from .operations import BastionHostsOperations +from .operations import NetworkManagementClientOperationsMixin +from .operations import CustomIPPrefixesOperations +from .operations import DdosCustomPoliciesOperations +from .operations import DdosProtectionPlansOperations +from .operations import DscpConfigurationOperations +from .operations import AvailableEndpointServicesOperations +from .operations import ExpressRouteCircuitAuthorizationsOperations +from .operations import ExpressRouteCircuitPeeringsOperations +from .operations import ExpressRouteCircuitConnectionsOperations +from .operations import PeerExpressRouteCircuitConnectionsOperations +from .operations import ExpressRouteCircuitsOperations +from .operations import ExpressRouteServiceProvidersOperations +from .operations import ExpressRouteCrossConnectionsOperations +from .operations import ExpressRouteCrossConnectionPeeringsOperations +from .operations import ExpressRoutePortsLocationsOperations +from .operations import ExpressRoutePortsOperations +from .operations import ExpressRouteLinksOperations +from .operations import FirewallPoliciesOperations +from .operations import FirewallPolicyRuleCollectionGroupsOperations +from .operations import IpAllocationsOperations +from .operations import IpGroupsOperations +from .operations import LoadBalancersOperations +from .operations import LoadBalancerBackendAddressPoolsOperations +from .operations import LoadBalancerFrontendIPConfigurationsOperations +from .operations import InboundNatRulesOperations +from .operations import LoadBalancerLoadBalancingRulesOperations +from .operations import LoadBalancerOutboundRulesOperations +from .operations import LoadBalancerNetworkInterfacesOperations +from .operations import LoadBalancerProbesOperations +from .operations import NatGatewaysOperations +from .operations import NetworkInterfacesOperations +from .operations import NetworkInterfaceIPConfigurationsOperations +from .operations import NetworkInterfaceLoadBalancersOperations +from .operations import NetworkInterfaceTapConfigurationsOperations +from .operations import NetworkProfilesOperations +from .operations import NetworkSecurityGroupsOperations +from .operations import SecurityRulesOperations +from .operations import DefaultSecurityRulesOperations +from .operations import NetworkVirtualAppliancesOperations +from .operations import VirtualApplianceSitesOperations +from .operations import VirtualApplianceSkusOperations +from .operations import InboundSecurityRuleOperations +from .operations import NetworkWatchersOperations +from .operations import PacketCapturesOperations +from .operations import ConnectionMonitorsOperations +from .operations import FlowLogsOperations +from .operations import Operations +from .operations import PrivateEndpointsOperations +from .operations import AvailablePrivateEndpointTypesOperations +from .operations import PrivateDnsZoneGroupsOperations +from .operations import PrivateLinkServicesOperations +from .operations import PublicIPAddressesOperations +from .operations import PublicIPPrefixesOperations +from .operations import RouteFiltersOperations +from .operations import RouteFilterRulesOperations +from .operations import RouteTablesOperations +from .operations import RoutesOperations +from .operations import SecurityPartnerProvidersOperations +from .operations import BgpServiceCommunitiesOperations +from .operations import ServiceEndpointPoliciesOperations +from .operations import ServiceEndpointPolicyDefinitionsOperations +from .operations import ServiceTagsOperations +from .operations import UsagesOperations +from .operations import VirtualNetworksOperations +from .operations import SubnetsOperations +from .operations import ResourceNavigationLinksOperations +from .operations import ServiceAssociationLinksOperations +from .operations import VirtualNetworkPeeringsOperations +from .operations import VirtualNetworkGatewaysOperations +from .operations import VirtualNetworkGatewayConnectionsOperations +from .operations import LocalNetworkGatewaysOperations +from .operations import VirtualNetworkTapsOperations +from .operations import VirtualRoutersOperations +from .operations import VirtualRouterPeeringsOperations +from .operations import VirtualWansOperations +from .operations import VpnSitesOperations +from .operations import VpnSiteLinksOperations +from .operations import VpnSitesConfigurationOperations +from .operations import VpnServerConfigurationsOperations +from .operations import VirtualHubsOperations +from .operations import HubVirtualNetworkConnectionsOperations +from .operations import VpnGatewaysOperations +from .operations import VpnConnectionsOperations +from .operations import VpnSiteLinkConnectionsOperations +from .operations import VpnLinkConnectionsOperations +from .operations import NatRulesOperations +from .operations import P2SVpnGatewaysOperations +from .operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations +from .operations import VirtualHubRouteTableV2SOperations +from .operations import ExpressRouteGatewaysOperations +from .operations import ExpressRouteConnectionsOperations +from .operations import VirtualHubBgpConnectionOperations +from .operations import VirtualHubBgpConnectionsOperations +from .operations import VirtualHubIpConfigurationOperations +from .operations import HubRouteTablesOperations +from .operations import WebApplicationFirewallPoliciesOperations +from .. import models + + +class NetworkManagementClient(NetworkManagementClientOperationsMixin): + """Network Client. + + :ivar application_gateways: ApplicationGatewaysOperations operations + :vartype application_gateways: azure.mgmt.network.v2020_08_01.aio.operations.ApplicationGatewaysOperations + :ivar application_gateway_private_link_resources: ApplicationGatewayPrivateLinkResourcesOperations operations + :vartype application_gateway_private_link_resources: azure.mgmt.network.v2020_08_01.aio.operations.ApplicationGatewayPrivateLinkResourcesOperations + :ivar application_gateway_private_endpoint_connections: ApplicationGatewayPrivateEndpointConnectionsOperations operations + :vartype application_gateway_private_endpoint_connections: azure.mgmt.network.v2020_08_01.aio.operations.ApplicationGatewayPrivateEndpointConnectionsOperations + :ivar application_security_groups: ApplicationSecurityGroupsOperations operations + :vartype application_security_groups: azure.mgmt.network.v2020_08_01.aio.operations.ApplicationSecurityGroupsOperations + :ivar available_delegations: AvailableDelegationsOperations operations + :vartype available_delegations: azure.mgmt.network.v2020_08_01.aio.operations.AvailableDelegationsOperations + :ivar available_resource_group_delegations: AvailableResourceGroupDelegationsOperations operations + :vartype available_resource_group_delegations: azure.mgmt.network.v2020_08_01.aio.operations.AvailableResourceGroupDelegationsOperations + :ivar available_service_aliases: AvailableServiceAliasesOperations operations + :vartype available_service_aliases: azure.mgmt.network.v2020_08_01.aio.operations.AvailableServiceAliasesOperations + :ivar azure_firewalls: AzureFirewallsOperations operations + :vartype azure_firewalls: azure.mgmt.network.v2020_08_01.aio.operations.AzureFirewallsOperations + :ivar azure_firewall_fqdn_tags: AzureFirewallFqdnTagsOperations operations + :vartype azure_firewall_fqdn_tags: azure.mgmt.network.v2020_08_01.aio.operations.AzureFirewallFqdnTagsOperations + :ivar web_categories: WebCategoriesOperations operations + :vartype web_categories: azure.mgmt.network.v2020_08_01.aio.operations.WebCategoriesOperations + :ivar bastion_hosts: BastionHostsOperations operations + :vartype bastion_hosts: azure.mgmt.network.v2020_08_01.aio.operations.BastionHostsOperations + :ivar custom_ip_prefixes: CustomIPPrefixesOperations operations + :vartype custom_ip_prefixes: azure.mgmt.network.v2020_08_01.aio.operations.CustomIPPrefixesOperations + :ivar ddos_custom_policies: DdosCustomPoliciesOperations operations + :vartype ddos_custom_policies: azure.mgmt.network.v2020_08_01.aio.operations.DdosCustomPoliciesOperations + :ivar ddos_protection_plans: DdosProtectionPlansOperations operations + :vartype ddos_protection_plans: azure.mgmt.network.v2020_08_01.aio.operations.DdosProtectionPlansOperations + :ivar dscp_configuration: DscpConfigurationOperations operations + :vartype dscp_configuration: azure.mgmt.network.v2020_08_01.aio.operations.DscpConfigurationOperations + :ivar available_endpoint_services: AvailableEndpointServicesOperations operations + :vartype available_endpoint_services: azure.mgmt.network.v2020_08_01.aio.operations.AvailableEndpointServicesOperations + :ivar express_route_circuit_authorizations: ExpressRouteCircuitAuthorizationsOperations operations + :vartype express_route_circuit_authorizations: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCircuitAuthorizationsOperations + :ivar express_route_circuit_peerings: ExpressRouteCircuitPeeringsOperations operations + :vartype express_route_circuit_peerings: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCircuitPeeringsOperations + :ivar express_route_circuit_connections: ExpressRouteCircuitConnectionsOperations operations + :vartype express_route_circuit_connections: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCircuitConnectionsOperations + :ivar peer_express_route_circuit_connections: PeerExpressRouteCircuitConnectionsOperations operations + :vartype peer_express_route_circuit_connections: azure.mgmt.network.v2020_08_01.aio.operations.PeerExpressRouteCircuitConnectionsOperations + :ivar express_route_circuits: ExpressRouteCircuitsOperations operations + :vartype express_route_circuits: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCircuitsOperations + :ivar express_route_service_providers: ExpressRouteServiceProvidersOperations operations + :vartype express_route_service_providers: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteServiceProvidersOperations + :ivar express_route_cross_connections: ExpressRouteCrossConnectionsOperations operations + :vartype express_route_cross_connections: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCrossConnectionsOperations + :ivar express_route_cross_connection_peerings: ExpressRouteCrossConnectionPeeringsOperations operations + :vartype express_route_cross_connection_peerings: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteCrossConnectionPeeringsOperations + :ivar express_route_ports_locations: ExpressRoutePortsLocationsOperations operations + :vartype express_route_ports_locations: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRoutePortsLocationsOperations + :ivar express_route_ports: ExpressRoutePortsOperations operations + :vartype express_route_ports: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRoutePortsOperations + :ivar express_route_links: ExpressRouteLinksOperations operations + :vartype express_route_links: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteLinksOperations + :ivar firewall_policies: FirewallPoliciesOperations operations + :vartype firewall_policies: azure.mgmt.network.v2020_08_01.aio.operations.FirewallPoliciesOperations + :ivar firewall_policy_rule_collection_groups: FirewallPolicyRuleCollectionGroupsOperations operations + :vartype firewall_policy_rule_collection_groups: azure.mgmt.network.v2020_08_01.aio.operations.FirewallPolicyRuleCollectionGroupsOperations + :ivar ip_allocations: IpAllocationsOperations operations + :vartype ip_allocations: azure.mgmt.network.v2020_08_01.aio.operations.IpAllocationsOperations + :ivar ip_groups: IpGroupsOperations operations + :vartype ip_groups: azure.mgmt.network.v2020_08_01.aio.operations.IpGroupsOperations + :ivar load_balancers: LoadBalancersOperations operations + :vartype load_balancers: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancersOperations + :ivar load_balancer_backend_address_pools: LoadBalancerBackendAddressPoolsOperations operations + :vartype load_balancer_backend_address_pools: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerBackendAddressPoolsOperations + :ivar load_balancer_frontend_ip_configurations: LoadBalancerFrontendIPConfigurationsOperations operations + :vartype load_balancer_frontend_ip_configurations: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerFrontendIPConfigurationsOperations + :ivar inbound_nat_rules: InboundNatRulesOperations operations + :vartype inbound_nat_rules: azure.mgmt.network.v2020_08_01.aio.operations.InboundNatRulesOperations + :ivar load_balancer_load_balancing_rules: LoadBalancerLoadBalancingRulesOperations operations + :vartype load_balancer_load_balancing_rules: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerLoadBalancingRulesOperations + :ivar load_balancer_outbound_rules: LoadBalancerOutboundRulesOperations operations + :vartype load_balancer_outbound_rules: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerOutboundRulesOperations + :ivar load_balancer_network_interfaces: LoadBalancerNetworkInterfacesOperations operations + :vartype load_balancer_network_interfaces: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerNetworkInterfacesOperations + :ivar load_balancer_probes: LoadBalancerProbesOperations operations + :vartype load_balancer_probes: azure.mgmt.network.v2020_08_01.aio.operations.LoadBalancerProbesOperations + :ivar nat_gateways: NatGatewaysOperations operations + :vartype nat_gateways: azure.mgmt.network.v2020_08_01.aio.operations.NatGatewaysOperations + :ivar network_interfaces: NetworkInterfacesOperations operations + :vartype network_interfaces: azure.mgmt.network.v2020_08_01.aio.operations.NetworkInterfacesOperations + :ivar network_interface_ip_configurations: NetworkInterfaceIPConfigurationsOperations operations + :vartype network_interface_ip_configurations: azure.mgmt.network.v2020_08_01.aio.operations.NetworkInterfaceIPConfigurationsOperations + :ivar network_interface_load_balancers: NetworkInterfaceLoadBalancersOperations operations + :vartype network_interface_load_balancers: azure.mgmt.network.v2020_08_01.aio.operations.NetworkInterfaceLoadBalancersOperations + :ivar network_interface_tap_configurations: NetworkInterfaceTapConfigurationsOperations operations + :vartype network_interface_tap_configurations: azure.mgmt.network.v2020_08_01.aio.operations.NetworkInterfaceTapConfigurationsOperations + :ivar network_profiles: NetworkProfilesOperations operations + :vartype network_profiles: azure.mgmt.network.v2020_08_01.aio.operations.NetworkProfilesOperations + :ivar network_security_groups: NetworkSecurityGroupsOperations operations + :vartype network_security_groups: azure.mgmt.network.v2020_08_01.aio.operations.NetworkSecurityGroupsOperations + :ivar security_rules: SecurityRulesOperations operations + :vartype security_rules: azure.mgmt.network.v2020_08_01.aio.operations.SecurityRulesOperations + :ivar default_security_rules: DefaultSecurityRulesOperations operations + :vartype default_security_rules: azure.mgmt.network.v2020_08_01.aio.operations.DefaultSecurityRulesOperations + :ivar network_virtual_appliances: NetworkVirtualAppliancesOperations operations + :vartype network_virtual_appliances: azure.mgmt.network.v2020_08_01.aio.operations.NetworkVirtualAppliancesOperations + :ivar virtual_appliance_sites: VirtualApplianceSitesOperations operations + :vartype virtual_appliance_sites: azure.mgmt.network.v2020_08_01.aio.operations.VirtualApplianceSitesOperations + :ivar virtual_appliance_skus: VirtualApplianceSkusOperations operations + :vartype virtual_appliance_skus: azure.mgmt.network.v2020_08_01.aio.operations.VirtualApplianceSkusOperations + :ivar inbound_security_rule: InboundSecurityRuleOperations operations + :vartype inbound_security_rule: azure.mgmt.network.v2020_08_01.aio.operations.InboundSecurityRuleOperations + :ivar network_watchers: NetworkWatchersOperations operations + :vartype network_watchers: azure.mgmt.network.v2020_08_01.aio.operations.NetworkWatchersOperations + :ivar packet_captures: PacketCapturesOperations operations + :vartype packet_captures: azure.mgmt.network.v2020_08_01.aio.operations.PacketCapturesOperations + :ivar connection_monitors: ConnectionMonitorsOperations operations + :vartype connection_monitors: azure.mgmt.network.v2020_08_01.aio.operations.ConnectionMonitorsOperations + :ivar flow_logs: FlowLogsOperations operations + :vartype flow_logs: azure.mgmt.network.v2020_08_01.aio.operations.FlowLogsOperations + :ivar operations: Operations operations + :vartype operations: azure.mgmt.network.v2020_08_01.aio.operations.Operations + :ivar private_endpoints: PrivateEndpointsOperations operations + :vartype private_endpoints: azure.mgmt.network.v2020_08_01.aio.operations.PrivateEndpointsOperations + :ivar available_private_endpoint_types: AvailablePrivateEndpointTypesOperations operations + :vartype available_private_endpoint_types: azure.mgmt.network.v2020_08_01.aio.operations.AvailablePrivateEndpointTypesOperations + :ivar private_dns_zone_groups: PrivateDnsZoneGroupsOperations operations + :vartype private_dns_zone_groups: azure.mgmt.network.v2020_08_01.aio.operations.PrivateDnsZoneGroupsOperations + :ivar private_link_services: PrivateLinkServicesOperations operations + :vartype private_link_services: azure.mgmt.network.v2020_08_01.aio.operations.PrivateLinkServicesOperations + :ivar public_ip_addresses: PublicIPAddressesOperations operations + :vartype public_ip_addresses: azure.mgmt.network.v2020_08_01.aio.operations.PublicIPAddressesOperations + :ivar public_ip_prefixes: PublicIPPrefixesOperations operations + :vartype public_ip_prefixes: azure.mgmt.network.v2020_08_01.aio.operations.PublicIPPrefixesOperations + :ivar route_filters: RouteFiltersOperations operations + :vartype route_filters: azure.mgmt.network.v2020_08_01.aio.operations.RouteFiltersOperations + :ivar route_filter_rules: RouteFilterRulesOperations operations + :vartype route_filter_rules: azure.mgmt.network.v2020_08_01.aio.operations.RouteFilterRulesOperations + :ivar route_tables: RouteTablesOperations operations + :vartype route_tables: azure.mgmt.network.v2020_08_01.aio.operations.RouteTablesOperations + :ivar routes: RoutesOperations operations + :vartype routes: azure.mgmt.network.v2020_08_01.aio.operations.RoutesOperations + :ivar security_partner_providers: SecurityPartnerProvidersOperations operations + :vartype security_partner_providers: azure.mgmt.network.v2020_08_01.aio.operations.SecurityPartnerProvidersOperations + :ivar bgp_service_communities: BgpServiceCommunitiesOperations operations + :vartype bgp_service_communities: azure.mgmt.network.v2020_08_01.aio.operations.BgpServiceCommunitiesOperations + :ivar service_endpoint_policies: ServiceEndpointPoliciesOperations operations + :vartype service_endpoint_policies: azure.mgmt.network.v2020_08_01.aio.operations.ServiceEndpointPoliciesOperations + :ivar service_endpoint_policy_definitions: ServiceEndpointPolicyDefinitionsOperations operations + :vartype service_endpoint_policy_definitions: azure.mgmt.network.v2020_08_01.aio.operations.ServiceEndpointPolicyDefinitionsOperations + :ivar service_tags: ServiceTagsOperations operations + :vartype service_tags: azure.mgmt.network.v2020_08_01.aio.operations.ServiceTagsOperations + :ivar usages: UsagesOperations operations + :vartype usages: azure.mgmt.network.v2020_08_01.aio.operations.UsagesOperations + :ivar virtual_networks: VirtualNetworksOperations operations + :vartype virtual_networks: azure.mgmt.network.v2020_08_01.aio.operations.VirtualNetworksOperations + :ivar subnets: SubnetsOperations operations + :vartype subnets: azure.mgmt.network.v2020_08_01.aio.operations.SubnetsOperations + :ivar resource_navigation_links: ResourceNavigationLinksOperations operations + :vartype resource_navigation_links: azure.mgmt.network.v2020_08_01.aio.operations.ResourceNavigationLinksOperations + :ivar service_association_links: ServiceAssociationLinksOperations operations + :vartype service_association_links: azure.mgmt.network.v2020_08_01.aio.operations.ServiceAssociationLinksOperations + :ivar virtual_network_peerings: VirtualNetworkPeeringsOperations operations + :vartype virtual_network_peerings: azure.mgmt.network.v2020_08_01.aio.operations.VirtualNetworkPeeringsOperations + :ivar virtual_network_gateways: VirtualNetworkGatewaysOperations operations + :vartype virtual_network_gateways: azure.mgmt.network.v2020_08_01.aio.operations.VirtualNetworkGatewaysOperations + :ivar virtual_network_gateway_connections: VirtualNetworkGatewayConnectionsOperations operations + :vartype virtual_network_gateway_connections: azure.mgmt.network.v2020_08_01.aio.operations.VirtualNetworkGatewayConnectionsOperations + :ivar local_network_gateways: LocalNetworkGatewaysOperations operations + :vartype local_network_gateways: azure.mgmt.network.v2020_08_01.aio.operations.LocalNetworkGatewaysOperations + :ivar virtual_network_taps: VirtualNetworkTapsOperations operations + :vartype virtual_network_taps: azure.mgmt.network.v2020_08_01.aio.operations.VirtualNetworkTapsOperations + :ivar virtual_routers: VirtualRoutersOperations operations + :vartype virtual_routers: azure.mgmt.network.v2020_08_01.aio.operations.VirtualRoutersOperations + :ivar virtual_router_peerings: VirtualRouterPeeringsOperations operations + :vartype virtual_router_peerings: azure.mgmt.network.v2020_08_01.aio.operations.VirtualRouterPeeringsOperations + :ivar virtual_wans: VirtualWansOperations operations + :vartype virtual_wans: azure.mgmt.network.v2020_08_01.aio.operations.VirtualWansOperations + :ivar vpn_sites: VpnSitesOperations operations + :vartype vpn_sites: azure.mgmt.network.v2020_08_01.aio.operations.VpnSitesOperations + :ivar vpn_site_links: VpnSiteLinksOperations operations + :vartype vpn_site_links: azure.mgmt.network.v2020_08_01.aio.operations.VpnSiteLinksOperations + :ivar vpn_sites_configuration: VpnSitesConfigurationOperations operations + :vartype vpn_sites_configuration: azure.mgmt.network.v2020_08_01.aio.operations.VpnSitesConfigurationOperations + :ivar vpn_server_configurations: VpnServerConfigurationsOperations operations + :vartype vpn_server_configurations: azure.mgmt.network.v2020_08_01.aio.operations.VpnServerConfigurationsOperations + :ivar virtual_hubs: VirtualHubsOperations operations + :vartype virtual_hubs: azure.mgmt.network.v2020_08_01.aio.operations.VirtualHubsOperations + :ivar hub_virtual_network_connections: HubVirtualNetworkConnectionsOperations operations + :vartype hub_virtual_network_connections: azure.mgmt.network.v2020_08_01.aio.operations.HubVirtualNetworkConnectionsOperations + :ivar vpn_gateways: VpnGatewaysOperations operations + :vartype vpn_gateways: azure.mgmt.network.v2020_08_01.aio.operations.VpnGatewaysOperations + :ivar vpn_connections: VpnConnectionsOperations operations + :vartype vpn_connections: azure.mgmt.network.v2020_08_01.aio.operations.VpnConnectionsOperations + :ivar vpn_site_link_connections: VpnSiteLinkConnectionsOperations operations + :vartype vpn_site_link_connections: azure.mgmt.network.v2020_08_01.aio.operations.VpnSiteLinkConnectionsOperations + :ivar vpn_link_connections: VpnLinkConnectionsOperations operations + :vartype vpn_link_connections: azure.mgmt.network.v2020_08_01.aio.operations.VpnLinkConnectionsOperations + :ivar nat_rules: NatRulesOperations operations + :vartype nat_rules: azure.mgmt.network.v2020_08_01.aio.operations.NatRulesOperations + :ivar p2_svpn_gateways: P2SVpnGatewaysOperations operations + :vartype p2_svpn_gateways: azure.mgmt.network.v2020_08_01.aio.operations.P2SVpnGatewaysOperations + :ivar vpn_server_configurations_associated_with_virtual_wan: VpnServerConfigurationsAssociatedWithVirtualWanOperations operations + :vartype vpn_server_configurations_associated_with_virtual_wan: azure.mgmt.network.v2020_08_01.aio.operations.VpnServerConfigurationsAssociatedWithVirtualWanOperations + :ivar virtual_hub_route_table_v2_s: VirtualHubRouteTableV2SOperations operations + :vartype virtual_hub_route_table_v2_s: azure.mgmt.network.v2020_08_01.aio.operations.VirtualHubRouteTableV2SOperations + :ivar express_route_gateways: ExpressRouteGatewaysOperations operations + :vartype express_route_gateways: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteGatewaysOperations + :ivar express_route_connections: ExpressRouteConnectionsOperations operations + :vartype express_route_connections: azure.mgmt.network.v2020_08_01.aio.operations.ExpressRouteConnectionsOperations + :ivar virtual_hub_bgp_connection: VirtualHubBgpConnectionOperations operations + :vartype virtual_hub_bgp_connection: azure.mgmt.network.v2020_08_01.aio.operations.VirtualHubBgpConnectionOperations + :ivar virtual_hub_bgp_connections: VirtualHubBgpConnectionsOperations operations + :vartype virtual_hub_bgp_connections: azure.mgmt.network.v2020_08_01.aio.operations.VirtualHubBgpConnectionsOperations + :ivar virtual_hub_ip_configuration: VirtualHubIpConfigurationOperations operations + :vartype virtual_hub_ip_configuration: azure.mgmt.network.v2020_08_01.aio.operations.VirtualHubIpConfigurationOperations + :ivar hub_route_tables: HubRouteTablesOperations operations + :vartype hub_route_tables: azure.mgmt.network.v2020_08_01.aio.operations.HubRouteTablesOperations + :ivar web_application_firewall_policies: WebApplicationFirewallPoliciesOperations operations + :vartype web_application_firewall_policies: azure.mgmt.network.v2020_08_01.aio.operations.WebApplicationFirewallPoliciesOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The subscription credentials which uniquely identify the Microsoft Azure subscription. The subscription ID forms part of the URI for every service call. + :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 = NetworkManagementClientConfiguration(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_gateways = ApplicationGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_gateway_private_link_resources = ApplicationGatewayPrivateLinkResourcesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_gateway_private_endpoint_connections = ApplicationGatewayPrivateEndpointConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_security_groups = ApplicationSecurityGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_delegations = AvailableDelegationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_resource_group_delegations = AvailableResourceGroupDelegationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_service_aliases = AvailableServiceAliasesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.azure_firewalls = AzureFirewallsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.azure_firewall_fqdn_tags = AzureFirewallFqdnTagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_categories = WebCategoriesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.bastion_hosts = BastionHostsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.custom_ip_prefixes = CustomIPPrefixesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ddos_custom_policies = DdosCustomPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ddos_protection_plans = DdosProtectionPlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.dscp_configuration = DscpConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_endpoint_services = AvailableEndpointServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_authorizations = ExpressRouteCircuitAuthorizationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_peerings = ExpressRouteCircuitPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuit_connections = ExpressRouteCircuitConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.peer_express_route_circuit_connections = PeerExpressRouteCircuitConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_circuits = ExpressRouteCircuitsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_service_providers = ExpressRouteServiceProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_cross_connections = ExpressRouteCrossConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_cross_connection_peerings = ExpressRouteCrossConnectionPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_ports_locations = ExpressRoutePortsLocationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_ports = ExpressRoutePortsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_links = ExpressRouteLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.firewall_policies = FirewallPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.firewall_policy_rule_collection_groups = FirewallPolicyRuleCollectionGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ip_allocations = IpAllocationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.ip_groups = IpGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancers = LoadBalancersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_backend_address_pools = LoadBalancerBackendAddressPoolsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_frontend_ip_configurations = LoadBalancerFrontendIPConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.inbound_nat_rules = InboundNatRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_load_balancing_rules = LoadBalancerLoadBalancingRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_outbound_rules = LoadBalancerOutboundRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_network_interfaces = LoadBalancerNetworkInterfacesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.load_balancer_probes = LoadBalancerProbesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.nat_gateways = NatGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interfaces = NetworkInterfacesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_ip_configurations = NetworkInterfaceIPConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_load_balancers = NetworkInterfaceLoadBalancersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_interface_tap_configurations = NetworkInterfaceTapConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_profiles = NetworkProfilesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_security_groups = NetworkSecurityGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.security_rules = SecurityRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.default_security_rules = DefaultSecurityRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_virtual_appliances = NetworkVirtualAppliancesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_appliance_sites = VirtualApplianceSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_appliance_skus = VirtualApplianceSkusOperations( + self._client, self._config, self._serialize, self._deserialize) + self.inbound_security_rule = InboundSecurityRuleOperations( + self._client, self._config, self._serialize, self._deserialize) + self.network_watchers = NetworkWatchersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.packet_captures = PacketCapturesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.connection_monitors = ConnectionMonitorsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.flow_logs = FlowLogsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.private_endpoints = PrivateEndpointsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.available_private_endpoint_types = AvailablePrivateEndpointTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.private_dns_zone_groups = PrivateDnsZoneGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.private_link_services = PrivateLinkServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.public_ip_addresses = PublicIPAddressesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.public_ip_prefixes = PublicIPPrefixesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_filters = RouteFiltersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_filter_rules = RouteFilterRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.route_tables = RouteTablesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.routes = RoutesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.security_partner_providers = SecurityPartnerProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.bgp_service_communities = BgpServiceCommunitiesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_endpoint_policies = ServiceEndpointPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_endpoint_policy_definitions = ServiceEndpointPolicyDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_tags = ServiceTagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.usages = UsagesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_networks = VirtualNetworksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.subnets = SubnetsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_navigation_links = ResourceNavigationLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.service_association_links = ServiceAssociationLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_peerings = VirtualNetworkPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_gateways = VirtualNetworkGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_gateway_connections = VirtualNetworkGatewayConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.local_network_gateways = LocalNetworkGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_network_taps = VirtualNetworkTapsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_routers = VirtualRoutersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_router_peerings = VirtualRouterPeeringsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_wans = VirtualWansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_sites = VpnSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_site_links = VpnSiteLinksOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_sites_configuration = VpnSitesConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_server_configurations = VpnServerConfigurationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hubs = VirtualHubsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.hub_virtual_network_connections = HubVirtualNetworkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_gateways = VpnGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_connections = VpnConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_site_link_connections = VpnSiteLinkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_link_connections = VpnLinkConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.nat_rules = NatRulesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.p2_svpn_gateways = P2SVpnGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.vpn_server_configurations_associated_with_virtual_wan = VpnServerConfigurationsAssociatedWithVirtualWanOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_route_table_v2_s = VirtualHubRouteTableV2SOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_gateways = ExpressRouteGatewaysOperations( + self._client, self._config, self._serialize, self._deserialize) + self.express_route_connections = ExpressRouteConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_bgp_connection = VirtualHubBgpConnectionOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_bgp_connections = VirtualHubBgpConnectionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.virtual_hub_ip_configuration = VirtualHubIpConfigurationOperations( + self._client, self._config, self._serialize, self._deserialize) + self.hub_route_tables = HubRouteTablesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_application_firewall_policies = WebApplicationFirewallPoliciesOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "NetworkManagementClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/__init__.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/__init__.py new file mode 100644 index 000000000000..e3c7e3bb9c53 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/__init__.py @@ -0,0 +1,225 @@ +# 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_gateways_operations import ApplicationGatewaysOperations +from ._application_gateway_private_link_resources_operations import ApplicationGatewayPrivateLinkResourcesOperations +from ._application_gateway_private_endpoint_connections_operations import ApplicationGatewayPrivateEndpointConnectionsOperations +from ._application_security_groups_operations import ApplicationSecurityGroupsOperations +from ._available_delegations_operations import AvailableDelegationsOperations +from ._available_resource_group_delegations_operations import AvailableResourceGroupDelegationsOperations +from ._available_service_aliases_operations import AvailableServiceAliasesOperations +from ._azure_firewalls_operations import AzureFirewallsOperations +from ._azure_firewall_fqdn_tags_operations import AzureFirewallFqdnTagsOperations +from ._web_categories_operations import WebCategoriesOperations +from ._bastion_hosts_operations import BastionHostsOperations +from ._network_management_client_operations import NetworkManagementClientOperationsMixin +from ._custom_ip_prefixes_operations import CustomIPPrefixesOperations +from ._ddos_custom_policies_operations import DdosCustomPoliciesOperations +from ._ddos_protection_plans_operations import DdosProtectionPlansOperations +from ._dscp_configuration_operations import DscpConfigurationOperations +from ._available_endpoint_services_operations import AvailableEndpointServicesOperations +from ._express_route_circuit_authorizations_operations import ExpressRouteCircuitAuthorizationsOperations +from ._express_route_circuit_peerings_operations import ExpressRouteCircuitPeeringsOperations +from ._express_route_circuit_connections_operations import ExpressRouteCircuitConnectionsOperations +from ._peer_express_route_circuit_connections_operations import PeerExpressRouteCircuitConnectionsOperations +from ._express_route_circuits_operations import ExpressRouteCircuitsOperations +from ._express_route_service_providers_operations import ExpressRouteServiceProvidersOperations +from ._express_route_cross_connections_operations import ExpressRouteCrossConnectionsOperations +from ._express_route_cross_connection_peerings_operations import ExpressRouteCrossConnectionPeeringsOperations +from ._express_route_ports_locations_operations import ExpressRoutePortsLocationsOperations +from ._express_route_ports_operations import ExpressRoutePortsOperations +from ._express_route_links_operations import ExpressRouteLinksOperations +from ._firewall_policies_operations import FirewallPoliciesOperations +from ._firewall_policy_rule_collection_groups_operations import FirewallPolicyRuleCollectionGroupsOperations +from ._ip_allocations_operations import IpAllocationsOperations +from ._ip_groups_operations import IpGroupsOperations +from ._load_balancers_operations import LoadBalancersOperations +from ._load_balancer_backend_address_pools_operations import LoadBalancerBackendAddressPoolsOperations +from ._load_balancer_frontend_ip_configurations_operations import LoadBalancerFrontendIPConfigurationsOperations +from ._inbound_nat_rules_operations import InboundNatRulesOperations +from ._load_balancer_load_balancing_rules_operations import LoadBalancerLoadBalancingRulesOperations +from ._load_balancer_outbound_rules_operations import LoadBalancerOutboundRulesOperations +from ._load_balancer_network_interfaces_operations import LoadBalancerNetworkInterfacesOperations +from ._load_balancer_probes_operations import LoadBalancerProbesOperations +from ._nat_gateways_operations import NatGatewaysOperations +from ._network_interfaces_operations import NetworkInterfacesOperations +from ._network_interface_ip_configurations_operations import NetworkInterfaceIPConfigurationsOperations +from ._network_interface_load_balancers_operations import NetworkInterfaceLoadBalancersOperations +from ._network_interface_tap_configurations_operations import NetworkInterfaceTapConfigurationsOperations +from ._network_profiles_operations import NetworkProfilesOperations +from ._network_security_groups_operations import NetworkSecurityGroupsOperations +from ._security_rules_operations import SecurityRulesOperations +from ._default_security_rules_operations import DefaultSecurityRulesOperations +from ._network_virtual_appliances_operations import NetworkVirtualAppliancesOperations +from ._virtual_appliance_sites_operations import VirtualApplianceSitesOperations +from ._virtual_appliance_skus_operations import VirtualApplianceSkusOperations +from ._inbound_security_rule_operations import InboundSecurityRuleOperations +from ._network_watchers_operations import NetworkWatchersOperations +from ._packet_captures_operations import PacketCapturesOperations +from ._connection_monitors_operations import ConnectionMonitorsOperations +from ._flow_logs_operations import FlowLogsOperations +from ._operations import Operations +from ._private_endpoints_operations import PrivateEndpointsOperations +from ._available_private_endpoint_types_operations import AvailablePrivateEndpointTypesOperations +from ._private_dns_zone_groups_operations import PrivateDnsZoneGroupsOperations +from ._private_link_services_operations import PrivateLinkServicesOperations +from ._public_ip_addresses_operations import PublicIPAddressesOperations +from ._public_ip_prefixes_operations import PublicIPPrefixesOperations +from ._route_filters_operations import RouteFiltersOperations +from ._route_filter_rules_operations import RouteFilterRulesOperations +from ._route_tables_operations import RouteTablesOperations +from ._routes_operations import RoutesOperations +from ._security_partner_providers_operations import SecurityPartnerProvidersOperations +from ._bgp_service_communities_operations import BgpServiceCommunitiesOperations +from ._service_endpoint_policies_operations import ServiceEndpointPoliciesOperations +from ._service_endpoint_policy_definitions_operations import ServiceEndpointPolicyDefinitionsOperations +from ._service_tags_operations import ServiceTagsOperations +from ._usages_operations import UsagesOperations +from ._virtual_networks_operations import VirtualNetworksOperations +from ._subnets_operations import SubnetsOperations +from ._resource_navigation_links_operations import ResourceNavigationLinksOperations +from ._service_association_links_operations import ServiceAssociationLinksOperations +from ._virtual_network_peerings_operations import VirtualNetworkPeeringsOperations +from ._virtual_network_gateways_operations import VirtualNetworkGatewaysOperations +from ._virtual_network_gateway_connections_operations import VirtualNetworkGatewayConnectionsOperations +from ._local_network_gateways_operations import LocalNetworkGatewaysOperations +from ._virtual_network_taps_operations import VirtualNetworkTapsOperations +from ._virtual_routers_operations import VirtualRoutersOperations +from ._virtual_router_peerings_operations import VirtualRouterPeeringsOperations +from ._virtual_wans_operations import VirtualWansOperations +from ._vpn_sites_operations import VpnSitesOperations +from ._vpn_site_links_operations import VpnSiteLinksOperations +from ._vpn_sites_configuration_operations import VpnSitesConfigurationOperations +from ._vpn_server_configurations_operations import VpnServerConfigurationsOperations +from ._virtual_hubs_operations import VirtualHubsOperations +from ._hub_virtual_network_connections_operations import HubVirtualNetworkConnectionsOperations +from ._vpn_gateways_operations import VpnGatewaysOperations +from ._vpn_connections_operations import VpnConnectionsOperations +from ._vpn_site_link_connections_operations import VpnSiteLinkConnectionsOperations +from ._vpn_link_connections_operations import VpnLinkConnectionsOperations +from ._nat_rules_operations import NatRulesOperations +from ._p2_svpn_gateways_operations import P2SVpnGatewaysOperations +from ._vpn_server_configurations_associated_with_virtual_wan_operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations +from ._virtual_hub_route_table_v2_s_operations import VirtualHubRouteTableV2SOperations +from ._express_route_gateways_operations import ExpressRouteGatewaysOperations +from ._express_route_connections_operations import ExpressRouteConnectionsOperations +from ._virtual_hub_bgp_connection_operations import VirtualHubBgpConnectionOperations +from ._virtual_hub_bgp_connections_operations import VirtualHubBgpConnectionsOperations +from ._virtual_hub_ip_configuration_operations import VirtualHubIpConfigurationOperations +from ._hub_route_tables_operations import HubRouteTablesOperations +from ._web_application_firewall_policies_operations import WebApplicationFirewallPoliciesOperations + +__all__ = [ + 'ApplicationGatewaysOperations', + 'ApplicationGatewayPrivateLinkResourcesOperations', + 'ApplicationGatewayPrivateEndpointConnectionsOperations', + 'ApplicationSecurityGroupsOperations', + 'AvailableDelegationsOperations', + 'AvailableResourceGroupDelegationsOperations', + 'AvailableServiceAliasesOperations', + 'AzureFirewallsOperations', + 'AzureFirewallFqdnTagsOperations', + 'WebCategoriesOperations', + 'BastionHostsOperations', + 'NetworkManagementClientOperationsMixin', + 'CustomIPPrefixesOperations', + 'DdosCustomPoliciesOperations', + 'DdosProtectionPlansOperations', + 'DscpConfigurationOperations', + 'AvailableEndpointServicesOperations', + 'ExpressRouteCircuitAuthorizationsOperations', + 'ExpressRouteCircuitPeeringsOperations', + 'ExpressRouteCircuitConnectionsOperations', + 'PeerExpressRouteCircuitConnectionsOperations', + 'ExpressRouteCircuitsOperations', + 'ExpressRouteServiceProvidersOperations', + 'ExpressRouteCrossConnectionsOperations', + 'ExpressRouteCrossConnectionPeeringsOperations', + 'ExpressRoutePortsLocationsOperations', + 'ExpressRoutePortsOperations', + 'ExpressRouteLinksOperations', + 'FirewallPoliciesOperations', + 'FirewallPolicyRuleCollectionGroupsOperations', + 'IpAllocationsOperations', + 'IpGroupsOperations', + 'LoadBalancersOperations', + 'LoadBalancerBackendAddressPoolsOperations', + 'LoadBalancerFrontendIPConfigurationsOperations', + 'InboundNatRulesOperations', + 'LoadBalancerLoadBalancingRulesOperations', + 'LoadBalancerOutboundRulesOperations', + 'LoadBalancerNetworkInterfacesOperations', + 'LoadBalancerProbesOperations', + 'NatGatewaysOperations', + 'NetworkInterfacesOperations', + 'NetworkInterfaceIPConfigurationsOperations', + 'NetworkInterfaceLoadBalancersOperations', + 'NetworkInterfaceTapConfigurationsOperations', + 'NetworkProfilesOperations', + 'NetworkSecurityGroupsOperations', + 'SecurityRulesOperations', + 'DefaultSecurityRulesOperations', + 'NetworkVirtualAppliancesOperations', + 'VirtualApplianceSitesOperations', + 'VirtualApplianceSkusOperations', + 'InboundSecurityRuleOperations', + 'NetworkWatchersOperations', + 'PacketCapturesOperations', + 'ConnectionMonitorsOperations', + 'FlowLogsOperations', + 'Operations', + 'PrivateEndpointsOperations', + 'AvailablePrivateEndpointTypesOperations', + 'PrivateDnsZoneGroupsOperations', + 'PrivateLinkServicesOperations', + 'PublicIPAddressesOperations', + 'PublicIPPrefixesOperations', + 'RouteFiltersOperations', + 'RouteFilterRulesOperations', + 'RouteTablesOperations', + 'RoutesOperations', + 'SecurityPartnerProvidersOperations', + 'BgpServiceCommunitiesOperations', + 'ServiceEndpointPoliciesOperations', + 'ServiceEndpointPolicyDefinitionsOperations', + 'ServiceTagsOperations', + 'UsagesOperations', + 'VirtualNetworksOperations', + 'SubnetsOperations', + 'ResourceNavigationLinksOperations', + 'ServiceAssociationLinksOperations', + 'VirtualNetworkPeeringsOperations', + 'VirtualNetworkGatewaysOperations', + 'VirtualNetworkGatewayConnectionsOperations', + 'LocalNetworkGatewaysOperations', + 'VirtualNetworkTapsOperations', + 'VirtualRoutersOperations', + 'VirtualRouterPeeringsOperations', + 'VirtualWansOperations', + 'VpnSitesOperations', + 'VpnSiteLinksOperations', + 'VpnSitesConfigurationOperations', + 'VpnServerConfigurationsOperations', + 'VirtualHubsOperations', + 'HubVirtualNetworkConnectionsOperations', + 'VpnGatewaysOperations', + 'VpnConnectionsOperations', + 'VpnSiteLinkConnectionsOperations', + 'VpnLinkConnectionsOperations', + 'NatRulesOperations', + 'P2SVpnGatewaysOperations', + 'VpnServerConfigurationsAssociatedWithVirtualWanOperations', + 'VirtualHubRouteTableV2SOperations', + 'ExpressRouteGatewaysOperations', + 'ExpressRouteConnectionsOperations', + 'VirtualHubBgpConnectionOperations', + 'VirtualHubBgpConnectionsOperations', + 'VirtualHubIpConfigurationOperations', + 'HubRouteTablesOperations', + 'WebApplicationFirewallPoliciesOperations', +] diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_endpoint_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_endpoint_connections_operations.py new file mode 100644 index 000000000000..c28e329c6505 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_endpoint_connections_operations.py @@ -0,0 +1,429 @@ +# 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 ApplicationGatewayPrivateEndpointConnectionsOperations: + """ApplicationGatewayPrivateEndpointConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + application_gateway_name: str, + connection_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-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + application_gateway_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type 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 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, + application_gateway_name=application_gateway_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + async def _update_initial( + self, + resource_group_name: str, + application_gateway_name: str, + connection_name: str, + parameters: "_models.ApplicationGatewayPrivateEndpointConnection", + **kwargs + ) -> Optional["_models.ApplicationGatewayPrivateEndpointConnection"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayPrivateEndpointConnection"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(parameters, 'ApplicationGatewayPrivateEndpointConnection') + 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + async def begin_update( + self, + resource_group_name: str, + application_gateway_name: str, + connection_name: str, + parameters: "_models.ApplicationGatewayPrivateEndpointConnection", + **kwargs + ) -> AsyncLROPoller["_models.ApplicationGatewayPrivateEndpointConnection"]: + """Updates the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type connection_name: str + :param parameters: Parameters supplied to update application gateway private endpoint + connection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationGatewayPrivateEndpointConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnection"] + lro_delay = kwargs.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, + application_gateway_name=application_gateway_name, + connection_name=connection_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('ApplicationGatewayPrivateEndpointConnection', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + application_gateway_name: str, + connection_name: str, + **kwargs + ) -> "_models.ApplicationGatewayPrivateEndpointConnection": + """Gets the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayPrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationGatewayPrivateEndpointConnectionListResult"]: + """Lists all private endpoint connections on an application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayPrivateEndpointConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_link_resources_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_link_resources_operations.py new file mode 100644 index 000000000000..bf444c434940 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateway_private_link_resources_operations.py @@ -0,0 +1,116 @@ +# 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 ApplicationGatewayPrivateLinkResourcesOperations: + """ApplicationGatewayPrivateLinkResourcesOperations 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.network.v2020_08_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, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationGatewayPrivateLinkResourceListResult"]: + """Lists all private link resources on an application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayPrivateLinkResourceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateLinkResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayPrivateLinkResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateLinkResources'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateways_operations.py new file mode 100644 index 000000000000..207e93b0b565 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_gateways_operations.py @@ -0,0 +1,1386 @@ +# 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 ApplicationGatewaysOperations: + """ApplicationGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + application_gateway_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-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> "_models.ApplicationGateway": + """Gets the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + application_gateway_name: str, + parameters: "_models.ApplicationGateway", + **kwargs + ) -> "_models.ApplicationGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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(parameters, 'ApplicationGateway') + 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('ApplicationGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + application_gateway_name: str, + parameters: "_models.ApplicationGateway", + **kwargs + ) -> AsyncLROPoller["_models.ApplicationGateway"]: + """Creates or updates the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param parameters: Parameters supplied to the create or update application gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + lro_delay = kwargs.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, + application_gateway_name=application_gateway_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('ApplicationGateway', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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': 'azure-async-operation'}, 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.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + application_gateway_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ApplicationGateway": + """Updates the specified application gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param parameters: Parameters supplied to update application gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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(parameters, 'TagsObject') + 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('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationGatewayListResult"]: + """Lists all application gateways in a 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 ApplicationGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/applicationGateways'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.ApplicationGatewayListResult"]: + """Gets all the application gateways 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 ApplicationGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ApplicationGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGateways'} # type: ignore + + async def _start_initial( + self, + resource_group_name: str, + application_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._start_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _start_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/start'} # type: ignore + + async def begin_start( + self, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Starts the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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._start_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/start'} # type: ignore + + async def _stop_initial( + self, + resource_group_name: str, + application_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/stop'} # type: ignore + + async def begin_stop( + self, + resource_group_name: str, + application_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Stops the specified application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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._stop_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/stop'} # type: ignore + + async def _backend_health_initial( + self, + resource_group_name: str, + application_gateway_name: str, + expand: Optional[str] = None, + **kwargs + ) -> Optional["_models.ApplicationGatewayBackendHealth"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayBackendHealth"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._backend_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ApplicationGatewayBackendHealth', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _backend_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/backendhealth'} # type: ignore + + async def begin_backend_health( + self, + resource_group_name: str, + application_gateway_name: str, + expand: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller["_models.ApplicationGatewayBackendHealth"]: + """Gets the backend health of the specified application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param expand: Expands BackendAddressPool and BackendHttpSettings referenced in backend health. + :type expand: 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 ApplicationGatewayBackendHealth or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealth] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayBackendHealth"] + lro_delay = kwargs.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._backend_health_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_name, + expand=expand, + 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('ApplicationGatewayBackendHealth', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_backend_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/backendhealth'} # type: ignore + + async def _backend_health_on_demand_initial( + self, + resource_group_name: str, + application_gateway_name: str, + probe_request: "_models.ApplicationGatewayOnDemandProbe", + expand: Optional[str] = None, + **kwargs + ) -> Optional["_models.ApplicationGatewayBackendHealthOnDemand"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayBackendHealthOnDemand"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._backend_health_on_demand_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(probe_request, 'ApplicationGatewayOnDemandProbe') + 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('ApplicationGatewayBackendHealthOnDemand', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _backend_health_on_demand_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/getBackendHealthOnDemand'} # type: ignore + + async def begin_backend_health_on_demand( + self, + resource_group_name: str, + application_gateway_name: str, + probe_request: "_models.ApplicationGatewayOnDemandProbe", + expand: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller["_models.ApplicationGatewayBackendHealthOnDemand"]: + """Gets the backend health for given combination of backend pool and http setting of the specified + application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param probe_request: Request body for on-demand test probe operation. + :type probe_request: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayOnDemandProbe + :param expand: Expands BackendAddressPool and BackendHttpSettings referenced in backend health. + :type expand: 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 ApplicationGatewayBackendHealthOnDemand or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthOnDemand] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayBackendHealthOnDemand"] + lro_delay = kwargs.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._backend_health_on_demand_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_name, + probe_request=probe_request, + expand=expand, + 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('ApplicationGatewayBackendHealthOnDemand', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_backend_health_on_demand.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/getBackendHealthOnDemand'} # type: ignore + + async def list_available_server_variables( + self, + **kwargs + ) -> List[str]: + """Lists all available server variables. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_server_variables.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.Error, 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 + list_available_server_variables.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableServerVariables'} # type: ignore + + async def list_available_request_headers( + self, + **kwargs + ) -> List[str]: + """Lists all available request headers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_request_headers.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.Error, 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 + list_available_request_headers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableRequestHeaders'} # type: ignore + + async def list_available_response_headers( + self, + **kwargs + ) -> List[str]: + """Lists all available response headers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_response_headers.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.Error, 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 + list_available_response_headers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableResponseHeaders'} # type: ignore + + async def list_available_waf_rule_sets( + self, + **kwargs + ) -> "_models.ApplicationGatewayAvailableWafRuleSetsResult": + """Lists all available web application firewall rule sets. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayAvailableWafRuleSetsResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableWafRuleSetsResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableWafRuleSetsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_waf_rule_sets.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayAvailableWafRuleSetsResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_available_waf_rule_sets.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableWafRuleSets'} # type: ignore + + async def list_available_ssl_options( + self, + **kwargs + ) -> "_models.ApplicationGatewayAvailableSslOptions": + """Lists available Ssl options for configuring Ssl policy. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayAvailableSslOptions, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableSslOptions + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableSslOptions"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_ssl_options.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayAvailableSslOptions', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_available_ssl_options.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default'} # type: ignore + + def list_available_ssl_predefined_policies( + self, + **kwargs + ) -> AsyncIterable["_models.ApplicationGatewayAvailableSslPredefinedPolicies"]: + """Lists all SSL predefined policies for configuring Ssl policy. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayAvailableSslPredefinedPolicies or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableSslPredefinedPolicies] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableSslPredefinedPolicies"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_available_ssl_predefined_policies.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('ApplicationGatewayAvailableSslPredefinedPolicies', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_available_ssl_predefined_policies.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default/predefinedPolicies'} # type: ignore + + async def get_ssl_predefined_policy( + self, + predefined_policy_name: str, + **kwargs + ) -> "_models.ApplicationGatewaySslPredefinedPolicy": + """Gets Ssl predefined policy with the specified policy name. + + :param predefined_policy_name: Name of Ssl predefined policy. + :type predefined_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewaySslPredefinedPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPredefinedPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewaySslPredefinedPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_ssl_predefined_policy.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'predefinedPolicyName': self._serialize.url("predefined_policy_name", predefined_policy_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('ApplicationGatewaySslPredefinedPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ssl_predefined_policy.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default/predefinedPolicies/{predefinedPolicyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_security_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_security_groups_operations.py new file mode 100644 index 000000000000..e33d72ab9baf --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_application_security_groups_operations.py @@ -0,0 +1,541 @@ +# 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 ApplicationSecurityGroupsOperations: + """ApplicationSecurityGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + application_security_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-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + application_security_group_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_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, + application_security_group_name=application_security_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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_group_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.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + application_security_group_name: str, + **kwargs + ) -> "_models.ApplicationSecurityGroup": + """Gets information about the specified application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + application_security_group_name: str, + parameters: "_models.ApplicationSecurityGroup", + **kwargs + ) -> "_models.ApplicationSecurityGroup": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ApplicationSecurityGroup') + 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('ApplicationSecurityGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + application_security_group_name: str, + parameters: "_models.ApplicationSecurityGroup", + **kwargs + ) -> AsyncLROPoller["_models.ApplicationSecurityGroup"]: + """Creates or updates an application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :param parameters: Parameters supplied to the create or update ApplicationSecurityGroup + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationSecurityGroup or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + lro_delay = kwargs.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, + application_security_group_name=application_security_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('ApplicationSecurityGroup', 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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_group_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': 'azure-async-operation'}, 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.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + application_security_group_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ApplicationSecurityGroup": + """Updates an application security group's tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :param parameters: Parameters supplied to update application security group tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.ApplicationSecurityGroupListResult"]: + """Gets all application security groups 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 ApplicationSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ApplicationSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationSecurityGroups'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationSecurityGroupListResult"]: + """Gets all the application security groups in a 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 ApplicationSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/applicationSecurityGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_delegations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_delegations_operations.py new file mode 100644 index 000000000000..0784506a2d5c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_delegations_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 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 AvailableDelegationsOperations: + """AvailableDelegationsOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> AsyncIterable["_models.AvailableDelegationsResult"]: + """Gets all of the available subnet delegations for this subscription in this region. + + :param location: The location of the subnet. + :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 AvailableDelegationsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableDelegationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableDelegationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailableDelegationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/availableDelegations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_endpoint_services_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_endpoint_services_operations.py new file mode 100644 index 000000000000..84d3bbdc04e4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_endpoint_services_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 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 AvailableEndpointServicesOperations: + """AvailableEndpointServicesOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> AsyncIterable["_models.EndpointServicesListResult"]: + """List what values of endpoint services are available for use. + + :param location: The location to check available endpoint services. + :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 EndpointServicesListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.EndpointServicesListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.EndpointServicesListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('EndpointServicesListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/virtualNetworkAvailableEndpointServices'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_private_endpoint_types_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_private_endpoint_types_operations.py new file mode 100644 index 000000000000..2f93f92fd3c1 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_private_endpoint_types_operations.py @@ -0,0 +1,188 @@ +# 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 AvailablePrivateEndpointTypesOperations: + """AvailablePrivateEndpointTypesOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> AsyncIterable["_models.AvailablePrivateEndpointTypesResult"]: + """Returns all of the resource types that can be linked to a Private Endpoint in this subscription + in this region. + + :param location: The location of the domain name. + :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 AvailablePrivateEndpointTypesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointTypesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailablePrivateEndpointTypesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailablePrivateEndpointTypesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/availablePrivateEndpointTypes'} # type: ignore + + def list_by_resource_group( + self, + location: str, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AvailablePrivateEndpointTypesResult"]: + """Returns all of the resource types that can be linked to a Private Endpoint in this subscription + in this region. + + :param location: The location of the domain name. + :type location: str + :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 AvailablePrivateEndpointTypesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointTypesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailablePrivateEndpointTypesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str'), + '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('AvailablePrivateEndpointTypesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/availablePrivateEndpointTypes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_resource_group_delegations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_resource_group_delegations_operations.py new file mode 100644 index 000000000000..8a68fee533b7 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_resource_group_delegations_operations.py @@ -0,0 +1,116 @@ +# 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 AvailableResourceGroupDelegationsOperations: + """AvailableResourceGroupDelegationsOperations 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.network.v2020_08_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, + location: str, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AvailableDelegationsResult"]: + """Gets all of the available subnet delegations for this resource group in this region. + + :param location: The location of the domain name. + :type location: str + :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 AvailableDelegationsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableDelegationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableDelegationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str'), + '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('AvailableDelegationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/locations/{location}/availableDelegations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_service_aliases_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_service_aliases_operations.py new file mode 100644 index 000000000000..3c6482feb6d4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_available_service_aliases_operations.py @@ -0,0 +1,186 @@ +# 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 AvailableServiceAliasesOperations: + """AvailableServiceAliasesOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> AsyncIterable["_models.AvailableServiceAliasesResult"]: + """Gets all available service aliases for this subscription in this region. + + :param location: The 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 AvailableServiceAliasesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAliasesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableServiceAliasesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailableServiceAliasesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/availableServiceAliases'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + location: str, + **kwargs + ) -> AsyncIterable["_models.AvailableServiceAliasesResult"]: + """Gets all available service aliases for this resource group in this region. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param location: The 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 AvailableServiceAliasesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAliasesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableServiceAliasesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + '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('AvailableServiceAliasesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/availableServiceAliases'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewall_fqdn_tags_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewall_fqdn_tags_operations.py new file mode 100644 index 000000000000..ce25fa9ab588 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewall_fqdn_tags_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 AzureFirewallFqdnTagsOperations: + """AzureFirewallFqdnTagsOperations 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.network.v2020_08_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_all( + self, + **kwargs + ) -> AsyncIterable["_models.AzureFirewallFqdnTagListResult"]: + """Gets all the Azure Firewall FQDN Tags 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 AzureFirewallFqdnTagListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallFqdnTagListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallFqdnTagListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('AzureFirewallFqdnTagListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureFirewallFqdnTags'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewalls_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewalls_operations.py new file mode 100644 index 000000000000..327d353c9b9c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_azure_firewalls_operations.py @@ -0,0 +1,600 @@ +# 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 AzureFirewallsOperations: + """AzureFirewallsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + azure_firewall_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-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + azure_firewall_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_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, + azure_firewall_name=azure_firewall_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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_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.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + azure_firewall_name: str, + **kwargs + ) -> "_models.AzureFirewall": + """Gets the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureFirewall, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.AzureFirewall + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + azure_firewall_name: str, + parameters: "_models.AzureFirewall", + **kwargs + ) -> "_models.AzureFirewall": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str', max_length=56, min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AzureFirewall') + 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('AzureFirewall', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + azure_firewall_name: str, + parameters: "_models.AzureFirewall", + **kwargs + ) -> AsyncLROPoller["_models.AzureFirewall"]: + """Creates or updates the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :param parameters: Parameters supplied to the create or update Azure Firewall operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AzureFirewall + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureFirewall or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + lro_delay = kwargs.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, + azure_firewall_name=azure_firewall_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('AzureFirewall', 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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str', max_length=56, min_length=1), + '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': 'azure-async-operation'}, 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.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + azure_firewall_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.AzureFirewall"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AzureFirewall"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + azure_firewall_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.AzureFirewall"]: + """Updates tags of an Azure Firewall resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :param parameters: Parameters supplied to update azure firewall tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureFirewall or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + azure_firewall_name=azure_firewall_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('AzureFirewall', 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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_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': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AzureFirewallListResult"]: + """Lists all Azure Firewalls in a 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 AzureFirewallListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AzureFirewallListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/azureFirewalls'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.AzureFirewallListResult"]: + """Gets all the Azure Firewalls 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 AzureFirewallListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('AzureFirewallListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureFirewalls'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bastion_hosts_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bastion_hosts_operations.py new file mode 100644 index 000000000000..e6e18a9d7b76 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bastion_hosts_operations.py @@ -0,0 +1,474 @@ +# 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 BastionHostsOperations: + """BastionHostsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + bastion_host_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-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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, 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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + bastion_host_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_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, + bastion_host_name=bastion_host_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + bastion_host_name: str, + **kwargs + ) -> "_models.BastionHost": + """Gets the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BastionHost, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BastionHost + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BastionHost', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + bastion_host_name: str, + parameters: "_models.BastionHost", + **kwargs + ) -> "_models.BastionHost": + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(parameters, 'BastionHost') + 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('BastionHost', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BastionHost', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + bastion_host_name: str, + parameters: "_models.BastionHost", + **kwargs + ) -> AsyncLROPoller["_models.BastionHost"]: + """Creates or updates the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param parameters: Parameters supplied to the create or update Bastion Host operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BastionHost + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BastionHost or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.BastionHost] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + lro_delay = kwargs.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, + bastion_host_name=bastion_host_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('BastionHost', 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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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': 'azure-async-operation'}, 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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.BastionHostListResult"]: + """Lists all Bastion Hosts 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 BastionHostListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionHostListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHostListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BastionHostListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/bastionHosts'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.BastionHostListResult"]: + """Lists all Bastion Hosts in a 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 BastionHostListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionHostListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHostListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BastionHostListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/bastionHosts'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bgp_service_communities_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bgp_service_communities_operations.py new file mode 100644 index 000000000000..be911ab48c7d --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_bgp_service_communities_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 BgpServiceCommunitiesOperations: + """BgpServiceCommunitiesOperations 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.network.v2020_08_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.BgpServiceCommunityListResult"]: + """Gets all the available bgp service communities. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BgpServiceCommunityListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BgpServiceCommunityListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpServiceCommunityListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BgpServiceCommunityListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/bgpServiceCommunities'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_connection_monitors_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_connection_monitors_operations.py new file mode 100644 index 000000000000..0f1b398b30ab --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_connection_monitors_operations.py @@ -0,0 +1,870 @@ +# 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 ConnectionMonitorsOperations: + """ConnectionMonitorsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + parameters: "_models.ConnectionMonitor", + migrate: Optional[str] = None, + **kwargs + ) -> "_models.ConnectionMonitorResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 migrate is not None: + query_parameters['migrate'] = self._serialize.query("migrate", migrate, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ConnectionMonitor') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + parameters: "_models.ConnectionMonitor", + migrate: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller["_models.ConnectionMonitorResult"]: + """Create or update a connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :param parameters: Parameters that define the operation to create a connection monitor. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitor + :param migrate: Value indicating whether connection monitor V1 should be migrated to V2 format. + :type migrate: 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 ConnectionMonitorResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + lro_delay = kwargs.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, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_name, + parameters=parameters, + migrate=migrate, + 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('ConnectionMonitorResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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': 'azure-async-operation'}, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> "_models.ConnectionMonitorResult": + """Gets a connection monitor by name. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionMonitorResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ConnectionMonitorResult": + """Update tags of the specified connection monitor. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :param parameters: Parameters supplied to update connection monitor tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionMonitorResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + async def _stop_initial( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/stop'} # type: ignore + + async def begin_stop( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Stops the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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._stop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/stop'} # type: ignore + + async def _start_initial( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_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-08-01" + accept = "application/json" + + # Construct URL + url = self._start_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _start_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/start'} # type: ignore + + async def begin_start( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Starts the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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._start_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/start'} # type: ignore + + async def _query_initial( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> "_models.ConnectionMonitorQueryResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorQueryResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._query_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectionMonitorQueryResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ConnectionMonitorQueryResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _query_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/query'} # type: ignore + + async def begin_query( + self, + resource_group_name: str, + network_watcher_name: str, + connection_monitor_name: str, + **kwargs + ) -> AsyncLROPoller["_models.ConnectionMonitorQueryResult"]: + """Query a snapshot of the most recent connection states. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name given to the connection monitor. + :type connection_monitor_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 ConnectionMonitorQueryResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorQueryResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorQueryResult"] + lro_delay = kwargs.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._query_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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('ConnectionMonitorQueryResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_query.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/query'} # type: ignore + + def list( + self, + resource_group_name: str, + network_watcher_name: str, + **kwargs + ) -> AsyncIterable["_models.ConnectionMonitorListResult"]: + """Lists all connection monitors for the specified Network Watcher. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ConnectionMonitorListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ConnectionMonitorListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_custom_ip_prefixes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_custom_ip_prefixes_operations.py new file mode 100644 index 000000000000..7362a762185a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_custom_ip_prefixes_operations.py @@ -0,0 +1,545 @@ +# 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 CustomIPPrefixesOperations: + """CustomIPPrefixesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + custom_ip_prefix_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-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + custom_ip_prefix_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified custom IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the CustomIpPrefix. + :type custom_ip_prefix_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, + custom_ip_prefix_name=custom_ip_prefix_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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_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.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + custom_ip_prefix_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.CustomIpPrefix": + """Gets the specified custom IP prefix in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomIpPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + custom_ip_prefix_name: str, + parameters: "_models.CustomIpPrefix", + **kwargs + ) -> "_models.CustomIpPrefix": + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'CustomIpPrefix') + 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('CustomIpPrefix', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + custom_ip_prefix_name: str, + parameters: "_models.CustomIpPrefix", + **kwargs + ) -> AsyncLROPoller["_models.CustomIpPrefix"]: + """Creates or updates a custom IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param parameters: Parameters supplied to the create or update custom IP prefix operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 CustomIpPrefix or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + lro_delay = kwargs.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, + custom_ip_prefix_name=custom_ip_prefix_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('CustomIpPrefix', 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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_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.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + custom_ip_prefix_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.CustomIpPrefix": + """Updates custom IP prefix tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param parameters: Parameters supplied to update custom IP prefix tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomIpPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.CustomIpPrefixListResult"]: + """Gets all the custom IP prefixes 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 CustomIpPrefixListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('CustomIpPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/customIpPrefixes'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.CustomIpPrefixListResult"]: + """Gets all custom IP prefixes in a 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 CustomIpPrefixListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CustomIpPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/customIpPrefixes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_custom_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_custom_policies_operations.py new file mode 100644 index 000000000000..270b6ba9f83e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_custom_policies_operations.py @@ -0,0 +1,403 @@ +# 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, Union +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.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 DdosCustomPoliciesOperations: + """DdosCustomPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + ddos_custom_policy_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-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + ddos_custom_policy_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_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, + ddos_custom_policy_name=ddos_custom_policy_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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_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.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + ddos_custom_policy_name: str, + **kwargs + ) -> "_models.DdosCustomPolicy": + """Gets information about the specified DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosCustomPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + ddos_custom_policy_name: str, + parameters: "_models.DdosCustomPolicy", + **kwargs + ) -> "_models.DdosCustomPolicy": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DdosCustomPolicy') + 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('DdosCustomPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + ddos_custom_policy_name: str, + parameters: "_models.DdosCustomPolicy", + **kwargs + ) -> AsyncLROPoller["_models.DdosCustomPolicy"]: + """Creates or updates a DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :param parameters: Parameters supplied to the create or update operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DdosCustomPolicy or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + lro_delay = kwargs.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, + ddos_custom_policy_name=ddos_custom_policy_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('DdosCustomPolicy', 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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_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': 'azure-async-operation'}, 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.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + ddos_custom_policy_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.DdosCustomPolicy": + """Update a DDoS custom policy tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :param parameters: Parameters supplied to update DDoS custom policy resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosCustomPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_protection_plans_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_protection_plans_operations.py new file mode 100644 index 000000000000..26afdff3628a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ddos_protection_plans_operations.py @@ -0,0 +1,540 @@ +# 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 DdosProtectionPlansOperations: + """DdosProtectionPlansOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + ddos_protection_plan_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-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + ddos_protection_plan_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_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, + ddos_protection_plan_name=ddos_protection_plan_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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_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.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + ddos_protection_plan_name: str, + **kwargs + ) -> "_models.DdosProtectionPlan": + """Gets information about the specified DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosProtectionPlan, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + ddos_protection_plan_name: str, + parameters: "_models.DdosProtectionPlan", + **kwargs + ) -> "_models.DdosProtectionPlan": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DdosProtectionPlan') + 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('DdosProtectionPlan', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + ddos_protection_plan_name: str, + parameters: "_models.DdosProtectionPlan", + **kwargs + ) -> AsyncLROPoller["_models.DdosProtectionPlan"]: + """Creates or updates a DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :param parameters: Parameters supplied to the create or update operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DdosProtectionPlan or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + lro_delay = kwargs.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, + ddos_protection_plan_name=ddos_protection_plan_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('DdosProtectionPlan', 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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_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': 'azure-async-operation'}, 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.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + ddos_protection_plan_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.DdosProtectionPlan": + """Update a DDoS protection plan tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :param parameters: Parameters supplied to the update DDoS protection plan resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosProtectionPlan, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.DdosProtectionPlanListResult"]: + """Gets all DDoS protection plans 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 DdosProtectionPlanListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlanListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlanListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('DdosProtectionPlanListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ddosProtectionPlans'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.DdosProtectionPlanListResult"]: + """Gets all the DDoS protection plans in a 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 DdosProtectionPlanListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlanListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlanListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('DdosProtectionPlanListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ddosProtectionPlans'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_default_security_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_default_security_rules_operations.py new file mode 100644 index 000000000000..5149ee99c697 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_default_security_rules_operations.py @@ -0,0 +1,178 @@ +# 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 DefaultSecurityRulesOperations: + """DefaultSecurityRulesOperations 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.network.v2020_08_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, + resource_group_name: str, + network_security_group_name: str, + **kwargs + ) -> AsyncIterable["_models.SecurityRuleListResult"]: + """Gets all default security rules in a network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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 SecurityRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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('SecurityRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_security_group_name: str, + default_security_rule_name: str, + **kwargs + ) -> "_models.SecurityRule": + """Get the specified default network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param default_security_rule_name: The name of the default security rule. + :type default_security_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'defaultSecurityRuleName': self._serialize.url("default_security_rule_name", default_security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules/{defaultSecurityRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_dscp_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_dscp_configuration_operations.py new file mode 100644 index 000000000000..fc004603d23c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_dscp_configuration_operations.py @@ -0,0 +1,474 @@ +# 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 DscpConfigurationOperations: + """DscpConfigurationOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + dscp_configuration_name: str, + parameters: "_models.DscpConfiguration", + **kwargs + ) -> "_models.DscpConfiguration": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DscpConfiguration') + 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('DscpConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DscpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + dscp_configuration_name: str, + parameters: "_models.DscpConfiguration", + **kwargs + ) -> AsyncLROPoller["_models.DscpConfiguration"]: + """Creates or updates a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_name: str + :param parameters: Parameters supplied to the create or update dscp configuration operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DscpConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DscpConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.DscpConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + lro_delay = kwargs.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, + dscp_configuration_name=dscp_configuration_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('DscpConfiguration', 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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_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.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + dscp_configuration_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-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + dscp_configuration_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_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, + dscp_configuration_name=dscp_configuration_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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_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.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + dscp_configuration_name: str, + **kwargs + ) -> "_models.DscpConfiguration": + """Gets a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DscpConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DscpConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DscpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.DscpConfigurationListResult"]: + """Gets a DSCP Configuration. + + :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 DscpConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.DscpConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DscpConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/dscpConfigurations'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.DscpConfigurationListResult"]: + """Gets all dscp configurations 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 DscpConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.DscpConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('DscpConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/dscpConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_authorizations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_authorizations_operations.py new file mode 100644 index 000000000000..abad41375c14 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_authorizations_operations.py @@ -0,0 +1,431 @@ +# 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 ExpressRouteCircuitAuthorizationsOperations: + """ExpressRouteCircuitAuthorizationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + circuit_name: str, + authorization_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + circuit_name: str, + authorization_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified authorization from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_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, + circuit_name=circuit_name, + authorization_name=authorization_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_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.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + circuit_name: str, + authorization_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuitAuthorization": + """Gets the specified authorization from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitAuthorization, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitAuthorization', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + circuit_name: str, + authorization_name: str, + authorization_parameters: "_models.ExpressRouteCircuitAuthorization", + **kwargs + ) -> "_models.ExpressRouteCircuitAuthorization": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(authorization_parameters, 'ExpressRouteCircuitAuthorization') + 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('ExpressRouteCircuitAuthorization', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitAuthorization', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + circuit_name: str, + authorization_name: str, + authorization_parameters: "_models.ExpressRouteCircuitAuthorization", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitAuthorization"]: + """Creates or updates an authorization in the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_name: str + :param authorization_parameters: Parameters supplied to the create or update express route + circuit authorization operation. + :type authorization_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitAuthorization or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + authorization_name=authorization_name, + authorization_parameters=authorization_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('ExpressRouteCircuitAuthorization', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def list( + self, + resource_group_name: str, + circuit_name: str, + **kwargs + ) -> AsyncIterable["_models.AuthorizationListResult"]: + """Gets all authorizations in an express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AuthorizationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AuthorizationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AuthorizationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AuthorizationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_connections_operations.py new file mode 100644 index 000000000000..3568795e93fd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_connections_operations.py @@ -0,0 +1,455 @@ +# 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 ExpressRouteCircuitConnectionsOperations: + """ExpressRouteCircuitConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Express Route Circuit Connection from the specified express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type 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 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, + circuit_name=circuit_name, + peering_name=peering_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuitConnection": + """Gets the specified Express Route Circuit Connection from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_name: str, + express_route_circuit_connection_parameters: "_models.ExpressRouteCircuitConnection", + **kwargs + ) -> "_models.ExpressRouteCircuitConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(express_route_circuit_connection_parameters, 'ExpressRouteCircuitConnection') + 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('ExpressRouteCircuitConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_name: str, + express_route_circuit_connection_parameters: "_models.ExpressRouteCircuitConnection", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitConnection"]: + """Creates or updates a Express Route Circuit Connection in the specified express route circuits. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type connection_name: str + :param express_route_circuit_connection_parameters: Parameters supplied to the create or update + express route circuit connection operation. + :type express_route_circuit_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + peering_name=peering_name, + connection_name=connection_name, + express_route_circuit_connection_parameters=express_route_circuit_connection_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('ExpressRouteCircuitConnection', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCircuitConnectionListResult"]: + """Gets all global reach connections associated with a private peering in an express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCircuitConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_peerings_operations.py new file mode 100644 index 000000000000..b5b6e2362f36 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuit_peerings_operations.py @@ -0,0 +1,431 @@ +# 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 ExpressRouteCircuitPeeringsOperations: + """ExpressRouteCircuitPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified peering from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_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, + circuit_name=circuit_name, + peering_name=peering_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuitPeering": + """Gets the specified peering for the express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + peering_parameters: "_models.ExpressRouteCircuitPeering", + **kwargs + ) -> "_models.ExpressRouteCircuitPeering": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(peering_parameters, 'ExpressRouteCircuitPeering') + 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('ExpressRouteCircuitPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + peering_parameters: "_models.ExpressRouteCircuitPeering", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitPeering"]: + """Creates or updates a peering in the specified express route circuits. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param peering_parameters: Parameters supplied to the create or update express route circuit + peering operation. + :type peering_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitPeering or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + peering_name=peering_name, + peering_parameters=peering_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('ExpressRouteCircuitPeering', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def list( + self, + resource_group_name: str, + circuit_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCircuitPeeringListResult"]: + """Gets all peerings in a specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCircuitPeeringListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuits_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuits_operations.py new file mode 100644 index 000000000000..e96da0f6fa8f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_circuits_operations.py @@ -0,0 +1,1053 @@ +# 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 ExpressRouteCircuitsOperations: + """ExpressRouteCircuitsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + circuit_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + circuit_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_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, + circuit_name=circuit_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_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.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + circuit_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuit": + """Gets information about the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuit, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + circuit_name: str, + parameters: "_models.ExpressRouteCircuit", + **kwargs + ) -> "_models.ExpressRouteCircuit": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ExpressRouteCircuit') + 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('ExpressRouteCircuit', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + circuit_name: str, + parameters: "_models.ExpressRouteCircuit", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuit"]: + """Creates or updates an express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param parameters: Parameters supplied to the create or update express route circuit operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuit or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + lro_delay = kwargs.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, + circuit_name=circuit_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('ExpressRouteCircuit', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + circuit_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ExpressRouteCircuit": + """Updates an express route circuit tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param parameters: Parameters supplied to update express route circuit tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuit, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + async def _list_arp_table_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCircuitsArpTableListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsArpTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_arp_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsArpTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_arp_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + async def begin_list_arp_table( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitsArpTableListResult"]: + """Gets the currently advertised ARP table associated with the express route circuit in a resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsArpTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsArpTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsArpTableListResult"] + lro_delay = kwargs.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_arp_table_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsArpTableListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_arp_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + async def _list_routes_table_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + async def begin_list_routes_table( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitsRoutesTableListResult"]: + """Gets the currently advertised routes table associated with the express route circuit in a + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableListResult"] + lro_delay = kwargs.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_routes_table_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + async def _list_routes_table_summary_initial( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_summary_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableSummaryListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_summary_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + async def begin_list_routes_table_summary( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"]: + """Gets the currently advertised routes table summary associated with the express route circuit in + a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableSummaryListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableSummaryListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"] + lro_delay = kwargs.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_routes_table_summary_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableSummaryListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table_summary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + async def get_stats( + self, + resource_group_name: str, + circuit_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuitStats": + """Gets all the stats from an express route circuit in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitStats, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitStats"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_stats.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitStats', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_stats.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/stats'} # type: ignore + + async def get_peering_stats( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + **kwargs + ) -> "_models.ExpressRouteCircuitStats": + """Gets all stats from an express route circuit in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitStats, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitStats"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_peering_stats.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitStats', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_peering_stats.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/stats'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCircuitListResult"]: + """Gets all the express route circuits in a 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 ExpressRouteCircuitListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCircuits'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCircuitListResult"]: + """Gets all the express route circuits 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 ExpressRouteCircuitListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ExpressRouteCircuitListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/expressRouteCircuits'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_connections_operations.py new file mode 100644 index 000000000000..c1cc963f9753 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_connections_operations.py @@ -0,0 +1,414 @@ +# 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, Union +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.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 ExpressRouteConnectionsOperations: + """ExpressRouteConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + express_route_gateway_name: str, + connection_name: str, + put_express_route_connection_parameters: "_models.ExpressRouteConnection", + **kwargs + ) -> "_models.ExpressRouteConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(put_express_route_connection_parameters, 'ExpressRouteConnection') + 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('ExpressRouteConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + express_route_gateway_name: str, + connection_name: str, + put_express_route_connection_parameters: "_models.ExpressRouteConnection", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteConnection"]: + """Creates a connection between an ExpressRoute gateway and an ExpressRoute circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the connection subresource. + :type connection_name: str + :param put_express_route_connection_parameters: Parameters required in an + ExpressRouteConnection PUT operation. + :type put_express_route_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + lro_delay = kwargs.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, + express_route_gateway_name=express_route_gateway_name, + connection_name=connection_name, + put_express_route_connection_parameters=put_express_route_connection_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('ExpressRouteConnection', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + express_route_gateway_name: str, + connection_name: str, + **kwargs + ) -> "_models.ExpressRouteConnection": + """Gets the specified ExpressRouteConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the ExpressRoute connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + express_route_gateway_name: str, + connection_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-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + express_route_gateway_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a connection to a ExpressRoute circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the connection subresource. + :type 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 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, + express_route_gateway_name=express_route_gateway_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + async def list( + self, + resource_group_name: str, + express_route_gateway_name: str, + **kwargs + ) -> "_models.ExpressRouteConnectionList": + """Lists ExpressRouteConnections. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteConnectionList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnectionList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnectionList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteConnectionList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connection_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connection_peerings_operations.py new file mode 100644 index 000000000000..f973e555bb74 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connection_peerings_operations.py @@ -0,0 +1,431 @@ +# 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 ExpressRouteCrossConnectionPeeringsOperations: + """ExpressRouteCrossConnectionPeeringsOperations 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.network.v2020_08_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, + resource_group_name: str, + cross_connection_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCrossConnectionPeeringList"]: + """Gets all peerings in a specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCrossConnectionPeeringList or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeeringList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeeringList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCrossConnectionPeeringList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cross_connection_name: str, + peering_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-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified peering from the ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_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, + cross_connection_name=cross_connection_name, + peering_name=peering_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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + **kwargs + ) -> "_models.ExpressRouteCrossConnectionPeering": + """Gets the specified peering for the ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnectionPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCrossConnectionPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + peering_parameters: "_models.ExpressRouteCrossConnectionPeering", + **kwargs + ) -> "_models.ExpressRouteCrossConnectionPeering": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(peering_parameters, 'ExpressRouteCrossConnectionPeering') + 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('ExpressRouteCrossConnectionPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCrossConnectionPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + peering_parameters: "_models.ExpressRouteCrossConnectionPeering", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCrossConnectionPeering"]: + """Creates or updates a peering in the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param peering_parameters: Parameters supplied to the create or update + ExpressRouteCrossConnection peering operation. + :type peering_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCrossConnectionPeering or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + lro_delay = kwargs.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, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + peering_parameters=peering_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('ExpressRouteCrossConnectionPeering', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connections_operations.py new file mode 100644 index 000000000000..2c357bdaf924 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_cross_connections_operations.py @@ -0,0 +1,823 @@ +# 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 ExpressRouteCrossConnectionsOperations: + """ExpressRouteCrossConnectionsOperations 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.network.v2020_08_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.ExpressRouteCrossConnectionListResult"]: + """Retrieves all the ExpressRouteCrossConnections 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 ExpressRouteCrossConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteCrossConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/expressRouteCrossConnections'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteCrossConnectionListResult"]: + """Retrieves all the ExpressRouteCrossConnections in a 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 ExpressRouteCrossConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteCrossConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/expressRouteCrossConnections'} # type: ignore + + async def get( + self, + resource_group_name: str, + cross_connection_name: str, + **kwargs + ) -> "_models.ExpressRouteCrossConnection": + """Gets details about the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group (peering location of the circuit). + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection (service key of the + circuit). + :type cross_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cross_connection_name: str, + parameters: "_models.ExpressRouteCrossConnection", + **kwargs + ) -> "_models.ExpressRouteCrossConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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(parameters, 'ExpressRouteCrossConnection') + 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('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cross_connection_name: str, + parameters: "_models.ExpressRouteCrossConnection", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCrossConnection"]: + """Update the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param parameters: Parameters supplied to the update express route crossConnection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCrossConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + lro_delay = kwargs.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, + cross_connection_name=cross_connection_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('ExpressRouteCrossConnection', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + cross_connection_name: str, + cross_connection_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ExpressRouteCrossConnection": + """Updates an express route cross connection tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the cross connection. + :type cross_connection_name: str + :param cross_connection_parameters: Parameters supplied to update express route cross + connection tags. + :type cross_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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(cross_connection_parameters, 'TagsObject') + 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('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + async def _list_arp_table_initial( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCircuitsArpTableListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsArpTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_arp_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsArpTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_arp_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + async def begin_list_arp_table( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitsArpTableListResult"]: + """Gets the currently advertised ARP table associated with the express route cross connection in a + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsArpTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsArpTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsArpTableListResult"] + lro_delay = kwargs.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_arp_table_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsArpTableListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_arp_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + async def _list_routes_table_summary_initial( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_summary_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCrossConnectionsRoutesTableSummaryListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_summary_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + async def begin_list_routes_table_summary( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"]: + """Gets the route table summary associated with the express route cross connection in a resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCrossConnectionsRoutesTableSummaryListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"] + lro_delay = kwargs.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_routes_table_summary_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCrossConnectionsRoutesTableSummaryListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table_summary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + async def _list_routes_table_initial( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + async def begin_list_routes_table( + self, + resource_group_name: str, + cross_connection_name: str, + peering_name: str, + device_path: str, + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteCircuitsRoutesTableListResult"]: + """Gets the currently advertised routes table associated with the express route cross connection + in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableListResult"] + lro_delay = kwargs.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_routes_table_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_gateways_operations.py new file mode 100644 index 000000000000..31c74b38b5ec --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_gateways_operations.py @@ -0,0 +1,570 @@ +# 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, Union +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.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 ExpressRouteGatewaysOperations: + """ExpressRouteGatewaysOperations 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.network.v2020_08_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_by_subscription( + self, + **kwargs + ) -> "_models.ExpressRouteGatewayList": + """Lists ExpressRoute gateways under a given subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteGatewayList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGatewayList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # 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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteGatewayList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_by_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/expressRouteGateways'} # type: ignore + + async def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> "_models.ExpressRouteGatewayList": + """Lists ExpressRoute gateways in a given 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: ExpressRouteGatewayList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGatewayList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # 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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteGatewayList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + express_route_gateway_name: str, + put_express_route_gateway_parameters: "_models.ExpressRouteGateway", + **kwargs + ) -> "_models.ExpressRouteGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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(put_express_route_gateway_parameters, 'ExpressRouteGateway') + 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('ExpressRouteGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + express_route_gateway_name: str, + put_express_route_gateway_parameters: "_models.ExpressRouteGateway", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteGateway"]: + """Creates or updates a ExpressRoute gateway in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param put_express_route_gateway_parameters: Parameters required in an ExpressRoute gateway PUT + operation. + :type put_express_route_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + lro_delay = kwargs.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, + express_route_gateway_name=express_route_gateway_name, + put_express_route_gateway_parameters=put_express_route_gateway_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('ExpressRouteGateway', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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': 'azure-async-operation'}, 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.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + express_route_gateway_name: str, + express_route_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.ExpressRouteGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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(express_route_gateway_parameters, 'TagsObject') + 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('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + express_route_gateway_name: str, + express_route_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRouteGateway"]: + """Updates express route gateway tags. + + :param resource_group_name: The resource group name of the ExpressRouteGateway. + :type resource_group_name: str + :param express_route_gateway_name: The name of the gateway. + :type express_route_gateway_name: str + :param express_route_gateway_parameters: Parameters supplied to update a virtual wan express + route gateway tags. + :type express_route_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + express_route_gateway_name=express_route_gateway_name, + express_route_gateway_parameters=express_route_gateway_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('ExpressRouteGateway', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + express_route_gateway_name: str, + **kwargs + ) -> "_models.ExpressRouteGateway": + """Fetches the details of a ExpressRoute gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + express_route_gateway_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-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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.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/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + express_route_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified ExpressRoute gateway in a resource group. An ExpressRoute gateway + resource can only be deleted when there are no connection subresources. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_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, + express_route_gateway_name=express_route_gateway_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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_links_operations.py new file mode 100644 index 000000000000..1d2ff88d4836 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_links_operations.py @@ -0,0 +1,178 @@ +# 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 ExpressRouteLinksOperations: + """ExpressRouteLinksOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + express_route_port_name: str, + link_name: str, + **kwargs + ) -> "_models.ExpressRouteLink": + """Retrieves the specified ExpressRouteLink resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param link_name: The name of the ExpressRouteLink resource. + :type link_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteLink, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteLink"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_name, 'str'), + 'linkName': self._serialize.url("link_name", link_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('ExpressRouteLink', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}/links/{linkName}'} # type: ignore + + def list( + self, + resource_group_name: str, + express_route_port_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRouteLinkListResult"]: + """Retrieve the ExpressRouteLink sub-resources of the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteLinkListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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('ExpressRouteLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}/links'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_locations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_locations_operations.py new file mode 100644 index 000000000000..f1108453f93a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_locations_operations.py @@ -0,0 +1,165 @@ +# 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 ExpressRoutePortsLocationsOperations: + """ExpressRoutePortsLocationsOperations 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.network.v2020_08_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.ExpressRoutePortsLocationListResult"]: + """Retrieves all ExpressRoutePort peering locations. Does not return available bandwidths for each + location. Available bandwidths can only be obtained when retrieving a specific peering + location. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRoutePortsLocationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortsLocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRoutePortsLocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ExpressRoutePortsLocations'} # type: ignore + + async def get( + self, + location_name: str, + **kwargs + ) -> "_models.ExpressRoutePortsLocation": + """Retrieves a single ExpressRoutePort peering location, including the list of available + bandwidths available at said peering location. + + :param location_name: Name of the requested ExpressRoutePort peering location. + :type location_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePortsLocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortsLocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'locationName': self._serialize.url("location_name", location_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('ExpressRoutePortsLocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/ExpressRoutePortsLocations/{locationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_operations.py new file mode 100644 index 000000000000..b5200673bba1 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_ports_operations.py @@ -0,0 +1,606 @@ +# 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 ExpressRoutePortsOperations: + """ExpressRoutePortsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + express_route_port_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-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + express_route_port_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_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, + express_route_port_name=express_route_port_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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + express_route_port_name: str, + **kwargs + ) -> "_models.ExpressRoutePort": + """Retrieves the requested ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of ExpressRoutePort. + :type express_route_port_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePort, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + express_route_port_name: str, + parameters: "_models.ExpressRoutePort", + **kwargs + ) -> "_models.ExpressRoutePort": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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, 'ExpressRoutePort') + 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('ExpressRoutePort', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + express_route_port_name: str, + parameters: "_models.ExpressRoutePort", + **kwargs + ) -> AsyncLROPoller["_models.ExpressRoutePort"]: + """Creates or updates the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param parameters: Parameters supplied to the create ExpressRoutePort operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRoutePort or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + lro_delay = kwargs.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, + express_route_port_name=express_route_port_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('ExpressRoutePort', 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + express_route_port_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ExpressRoutePort": + """Update ExpressRoutePort tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param parameters: Parameters supplied to update ExpressRoutePort resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePort, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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, 'TagsObject') + 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('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ExpressRoutePortListResult"]: + """List all the ExpressRoutePort resources in the specified 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 ExpressRoutePortListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ExpressRoutePortListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ExpressRoutePorts'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ExpressRoutePortListResult"]: + """List all the ExpressRoutePort resources in the specified subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRoutePortListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRoutePortListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ExpressRoutePorts'} # type: ignore + + async def generate_loa( + self, + resource_group_name: str, + express_route_port_name: str, + request: "_models.GenerateExpressRoutePortsLOARequest", + **kwargs + ) -> "_models.GenerateExpressRoutePortsLOAResult": + """Generate a letter of authorization for the requested ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of ExpressRoutePort. + :type express_route_port_name: str + :param request: Request parameters supplied to generate a letter of authorization. + :type request: ~azure.mgmt.network.v2020_08_01.models.GenerateExpressRoutePortsLOARequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenerateExpressRoutePortsLOAResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.GenerateExpressRoutePortsLOAResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenerateExpressRoutePortsLOAResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.generate_loa.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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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(request, 'GenerateExpressRoutePortsLOARequest') + 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('GenerateExpressRoutePortsLOAResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + generate_loa.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRoutePorts/{expressRoutePortName}/generateLoa'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_service_providers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_service_providers_operations.py new file mode 100644 index 000000000000..ae77c7463559 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_express_route_service_providers_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 ExpressRouteServiceProvidersOperations: + """ExpressRouteServiceProvidersOperations 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.network.v2020_08_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.ExpressRouteServiceProviderListResult"]: + """Gets all the available express route service providers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteServiceProviderListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteServiceProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteServiceProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/expressRouteServiceProviders'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policies_operations.py new file mode 100644 index 000000000000..4579d9e02864 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policies_operations.py @@ -0,0 +1,479 @@ +# 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 FirewallPoliciesOperations: + """FirewallPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + firewall_policy_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-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + firewall_policy_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_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, + firewall_policy_name=firewall_policy_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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_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.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + firewall_policy_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.FirewallPolicy": + """Gets the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + firewall_policy_name: str, + parameters: "_models.FirewallPolicy", + **kwargs + ) -> "_models.FirewallPolicy": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FirewallPolicy') + 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('FirewallPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + firewall_policy_name: str, + parameters: "_models.FirewallPolicy", + **kwargs + ) -> AsyncLROPoller["_models.FirewallPolicy"]: + """Creates or updates the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param parameters: Parameters supplied to the create or update Firewall Policy operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FirewallPolicy or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.FirewallPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + lro_delay = kwargs.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, + firewall_policy_name=firewall_policy_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('FirewallPolicy', 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_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': 'azure-async-operation'}, 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.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.FirewallPolicyListResult"]: + """Lists all Firewall Policies in a 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 FirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/firewallPolicies'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.FirewallPolicyListResult"]: + """Gets all the Firewall Policies 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 FirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('FirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/firewallPolicies'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policy_rule_collection_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policy_rule_collection_groups_operations.py new file mode 100644 index 000000000000..07d021f33f89 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_firewall_policy_rule_collection_groups_operations.py @@ -0,0 +1,431 @@ +# 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 FirewallPolicyRuleCollectionGroupsOperations: + """FirewallPolicyRuleCollectionGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + firewall_policy_name: str, + rule_collection_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-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + firewall_policy_name: str, + rule_collection_group_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_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, + firewall_policy_name=firewall_policy_name, + rule_collection_group_name=rule_collection_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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_group_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.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + firewall_policy_name: str, + rule_collection_group_name: str, + **kwargs + ) -> "_models.FirewallPolicyRuleCollectionGroup": + """Gets the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FirewallPolicyRuleCollectionGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + firewall_policy_name: str, + rule_collection_group_name: str, + parameters: "_models.FirewallPolicyRuleCollectionGroup", + **kwargs + ) -> "_models.FirewallPolicyRuleCollectionGroup": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FirewallPolicyRuleCollectionGroup') + 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('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + firewall_policy_name: str, + rule_collection_group_name: str, + parameters: "_models.FirewallPolicyRuleCollectionGroup", + **kwargs + ) -> AsyncLROPoller["_models.FirewallPolicyRuleCollectionGroup"]: + """Creates or updates the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_group_name: str + :param parameters: Parameters supplied to the create or update + FirewallPolicyRuleCollectionGroup operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FirewallPolicyRuleCollectionGroup or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + lro_delay = kwargs.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, + firewall_policy_name=firewall_policy_name, + rule_collection_group_name=rule_collection_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('FirewallPolicyRuleCollectionGroup', 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_group_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': 'azure-async-operation'}, 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.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def list( + self, + resource_group_name: str, + firewall_policy_name: str, + **kwargs + ) -> AsyncIterable["_models.FirewallPolicyRuleCollectionGroupListResult"]: + """Lists all FirewallPolicyRuleCollectionGroups in a FirewallPolicy resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FirewallPolicyRuleCollectionGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FirewallPolicyRuleCollectionGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_flow_logs_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_flow_logs_operations.py new file mode 100644 index 000000000000..03ea79740446 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_flow_logs_operations.py @@ -0,0 +1,505 @@ +# 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 FlowLogsOperations: + """FlowLogsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_name: str, + parameters: "_models.FlowLog", + **kwargs + ) -> "_models.FlowLog": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLog') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLog', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_name: str, + parameters: "_models.FlowLog", + **kwargs + ) -> AsyncLROPoller["_models.FlowLog"]: + """Create or update a flow log for the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log. + :type flow_log_name: str + :param parameters: Parameters that define the create or update flow log resource. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLog or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + lro_delay = kwargs.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, + network_watcher_name=network_watcher_name, + flow_log_name=flow_log_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('FlowLog', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_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': 'azure-async-operation'}, 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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.FlowLog": + """Update tags of the specified flow log. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log. + :type flow_log_name: str + :param parameters: Parameters supplied to update flow log tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FlowLog, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_name: str, + **kwargs + ) -> "_models.FlowLog": + """Gets a flow log resource by name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log resource. + :type flow_log_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FlowLog, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_watcher_name: str, + flow_log_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified flow log resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log resource. + :type flow_log_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, + network_watcher_name=network_watcher_name, + flow_log_name=flow_log_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def list( + self, + resource_group_name: str, + network_watcher_name: str, + **kwargs + ) -> AsyncIterable["_models.FlowLogListResult"]: + """Lists all flow log resources for the specified Network Watcher. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FlowLogListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.FlowLogListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FlowLogListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/flowLogs'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_route_tables_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_route_tables_operations.py new file mode 100644 index 000000000000..3cd79a66b079 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_route_tables_operations.py @@ -0,0 +1,430 @@ +# 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 HubRouteTablesOperations: + """HubRouteTablesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + route_table_parameters: "_models.HubRouteTable", + **kwargs + ) -> "_models.HubRouteTable": + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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(route_table_parameters, 'HubRouteTable') + 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('HubRouteTable', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubRouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + route_table_parameters: "_models.HubRouteTable", + **kwargs + ) -> AsyncLROPoller["_models.HubRouteTable"]: + """Creates a RouteTable resource if it doesn't exist else updates the existing RouteTable. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_name: str + :param route_table_parameters: Parameters supplied to create or update RouteTable. + :type route_table_parameters: ~azure.mgmt.network.v2020_08_01.models.HubRouteTable + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubRouteTable or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.HubRouteTable] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_name, + route_table_parameters=route_table_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('HubRouteTable', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + **kwargs + ) -> "_models.HubRouteTable": + """Retrieves the details of a RouteTable. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubRouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubRouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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('HubRouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a RouteTable. + + :param resource_group_name: The resource group name of the RouteTable. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncIterable["_models.ListHubRouteTablesResult"]: + """Retrieves the details of all RouteTables. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListHubRouteTablesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListHubRouteTablesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListHubRouteTablesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListHubRouteTablesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_virtual_network_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_virtual_network_connections_operations.py new file mode 100644 index 000000000000..145766cf0a65 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_hub_virtual_network_connections_operations.py @@ -0,0 +1,431 @@ +# 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 HubVirtualNetworkConnectionsOperations: + """HubVirtualNetworkConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + hub_virtual_network_connection_parameters: "_models.HubVirtualNetworkConnection", + **kwargs + ) -> "_models.HubVirtualNetworkConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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(hub_virtual_network_connection_parameters, 'HubVirtualNetworkConnection') + 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('HubVirtualNetworkConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubVirtualNetworkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + hub_virtual_network_connection_parameters: "_models.HubVirtualNetworkConnection", + **kwargs + ) -> AsyncLROPoller["_models.HubVirtualNetworkConnection"]: + """Creates a hub virtual network connection if it doesn't exist else updates the existing one. + + :param resource_group_name: The resource group name of the HubVirtualNetworkConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the HubVirtualNetworkConnection. + :type connection_name: str + :param hub_virtual_network_connection_parameters: Parameters supplied to create or update a hub + virtual network connection. + :type hub_virtual_network_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubVirtualNetworkConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + connection_name=connection_name, + hub_virtual_network_connection_parameters=hub_virtual_network_connection_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('HubVirtualNetworkConnection', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a HubVirtualNetworkConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the HubVirtualNetworkConnection. + :type 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 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, + virtual_hub_name=virtual_hub_name, + connection_name=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): + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + **kwargs + ) -> "_models.HubVirtualNetworkConnection": + """Retrieves the details of a HubVirtualNetworkConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubVirtualNetworkConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('HubVirtualNetworkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncIterable["_models.ListHubVirtualNetworkConnectionsResult"]: + """Retrieves the details of all HubVirtualNetworkConnections. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListHubVirtualNetworkConnectionsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListHubVirtualNetworkConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListHubVirtualNetworkConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListHubVirtualNetworkConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_nat_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_nat_rules_operations.py new file mode 100644 index 000000000000..68544441ac56 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_nat_rules_operations.py @@ -0,0 +1,436 @@ +# 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 InboundNatRulesOperations: + """InboundNatRulesOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.InboundNatRuleListResult"]: + """Gets all the inbound nat rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundNatRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.InboundNatRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('InboundNatRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + load_balancer_name: str, + inbound_nat_rule_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + load_balancer_name: str, + inbound_nat_rule_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_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, + load_balancer_name=load_balancer_name, + inbound_nat_rule_name=inbound_nat_rule_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_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.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + inbound_nat_rule_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.InboundNatRule": + """Gets the specified load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: InboundNatRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.InboundNatRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('InboundNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + load_balancer_name: str, + inbound_nat_rule_name: str, + inbound_nat_rule_parameters: "_models.InboundNatRule", + **kwargs + ) -> "_models.InboundNatRule": + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(inbound_nat_rule_parameters, 'InboundNatRule') + 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('InboundNatRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('InboundNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + load_balancer_name: str, + inbound_nat_rule_name: str, + inbound_nat_rule_parameters: "_models.InboundNatRule", + **kwargs + ) -> AsyncLROPoller["_models.InboundNatRule"]: + """Creates or updates a load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_name: str + :param inbound_nat_rule_parameters: Parameters supplied to the create or update inbound nat + rule operation. + :type inbound_nat_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.InboundNatRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 InboundNatRule or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_name, + inbound_nat_rule_name=inbound_nat_rule_name, + inbound_nat_rule_parameters=inbound_nat_rule_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('InboundNatRule', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_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': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_security_rule_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_security_rule_operations.py new file mode 100644 index 000000000000..5e03319833fd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_inbound_security_rule_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 Any, Callable, Dict, Generic, Optional, TypeVar, Union +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.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 InboundSecurityRuleOperations: + """InboundSecurityRuleOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + rule_collection_name: str, + parameters: "_models.InboundSecurityRule", + **kwargs + ) -> "_models.InboundSecurityRule": + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundSecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'ruleCollectionName': self._serialize.url("rule_collection_name", rule_collection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'InboundSecurityRule') + 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('InboundSecurityRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('InboundSecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/inboundSecurityRules/{ruleCollectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + rule_collection_name: str, + parameters: "_models.InboundSecurityRule", + **kwargs + ) -> AsyncLROPoller["_models.InboundSecurityRule"]: + """Creates or updates the specified Network Virtual Appliance Inbound Security Rules. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param rule_collection_name: The name of security rule collection. + :type rule_collection_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance + Inbound Security Rules operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.InboundSecurityRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 InboundSecurityRule or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.InboundSecurityRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundSecurityRule"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_name, + rule_collection_name=rule_collection_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('InboundSecurityRule', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'ruleCollectionName': self._serialize.url("rule_collection_name", rule_collection_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/inboundSecurityRules/{ruleCollectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_allocations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_allocations_operations.py new file mode 100644 index 000000000000..61979dc02d67 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_allocations_operations.py @@ -0,0 +1,545 @@ +# 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 IpAllocationsOperations: + """IpAllocationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + ip_allocation_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-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + ip_allocation_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified IpAllocation. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_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, + ip_allocation_name=ip_allocation_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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_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.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + ip_allocation_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.IpAllocation": + """Gets the specified IpAllocation by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpAllocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + ip_allocation_name: str, + parameters: "_models.IpAllocation", + **kwargs + ) -> "_models.IpAllocation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'IpAllocation') + 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('IpAllocation', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + ip_allocation_name: str, + parameters: "_models.IpAllocation", + **kwargs + ) -> AsyncLROPoller["_models.IpAllocation"]: + """Creates or updates an IpAllocation in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param parameters: Parameters supplied to the create or update virtual network operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 IpAllocation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.IpAllocation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + lro_delay = kwargs.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, + ip_allocation_name=ip_allocation_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('IpAllocation', 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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_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': 'azure-async-operation'}, 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.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + ip_allocation_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.IpAllocation": + """Updates a IpAllocation tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param parameters: Parameters supplied to update IpAllocation tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpAllocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.IpAllocationListResult"]: + """Gets all IpAllocations 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 IpAllocationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.IpAllocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpAllocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/IpAllocations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.IpAllocationListResult"]: + """Gets all IpAllocations in a 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 IpAllocationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.IpAllocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpAllocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/IpAllocations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_groups_operations.py new file mode 100644 index 000000000000..db3a7371db83 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_ip_groups_operations.py @@ -0,0 +1,552 @@ +# 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 IpGroupsOperations: + """IpGroupsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + ip_groups_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.IpGroup": + """Gets the specified ipGroups. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param expand: Expands resourceIds (of Firewalls/Network Security Groups etc.) back referenced + by the IpGroups resource. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + ip_groups_name: str, + parameters: "_models.IpGroup", + **kwargs + ) -> "_models.IpGroup": + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'IpGroup') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('IpGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + ip_groups_name: str, + parameters: "_models.IpGroup", + **kwargs + ) -> AsyncLROPoller["_models.IpGroup"]: + """Creates or updates an ipGroups in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param parameters: Parameters supplied to the create or update IpGroups operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 IpGroup or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.IpGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + lro_delay = kwargs.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, + ip_groups_name=ip_groups_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('IpGroup', 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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_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': 'azure-async-operation'}, 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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + async def update_groups( + self, + resource_group_name: str, + ip_groups_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.IpGroup": + """Updates tags of an IpGroups resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param parameters: Parameters supplied to the update ipGroups operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_groups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_groups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + ip_groups_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-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + ip_groups_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified ipGroups. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_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, + ip_groups_name=ip_groups_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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.IpGroupListResult"]: + """Gets all IpGroups in a 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 IpGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.IpGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/ipGroups'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.IpGroupListResult"]: + """Gets all IpGroups 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 IpGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.IpGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/ipGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_backend_address_pools_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_backend_address_pools_operations.py new file mode 100644 index 000000000000..5d951506f507 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_backend_address_pools_operations.py @@ -0,0 +1,431 @@ +# 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 LoadBalancerBackendAddressPoolsOperations: + """LoadBalancerBackendAddressPoolsOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerBackendAddressPoolListResult"]: + """Gets all the load balancer backed address pools. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerBackendAddressPoolListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerBackendAddressPoolListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerBackendAddressPoolListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerBackendAddressPoolListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + backend_address_pool_name: str, + **kwargs + ) -> "_models.BackendAddressPool": + """Gets load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackendAddressPool, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BackendAddressPool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackendAddressPool', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + load_balancer_name: str, + backend_address_pool_name: str, + parameters: "_models.BackendAddressPool", + **kwargs + ) -> "_models.BackendAddressPool": + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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(parameters, 'BackendAddressPool') + 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('BackendAddressPool', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BackendAddressPool', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + load_balancer_name: str, + backend_address_pool_name: str, + parameters: "_models.BackendAddressPool", + **kwargs + ) -> AsyncLROPoller["_models.BackendAddressPool"]: + """Creates or updates a load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_name: str + :param parameters: Parameters supplied to the create or update load balancer backend address + pool operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BackendAddressPool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BackendAddressPool or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_name, + backend_address_pool_name=backend_address_pool_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('BackendAddressPool', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + load_balancer_name: str, + backend_address_pool_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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.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/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + load_balancer_name: str, + backend_address_pool_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_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, + load_balancer_name=load_balancer_name, + backend_address_pool_name=backend_address_pool_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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, 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.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_frontend_ip_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_frontend_ip_configurations_operations.py new file mode 100644 index 000000000000..b516f08e2de6 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_frontend_ip_configurations_operations.py @@ -0,0 +1,178 @@ +# 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 LoadBalancerFrontendIPConfigurationsOperations: + """LoadBalancerFrontendIPConfigurationsOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerFrontendIPConfigurationListResult"]: + """Gets all the load balancer frontend IP configurations. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerFrontendIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerFrontendIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerFrontendIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerFrontendIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/frontendIPConfigurations'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + frontend_ip_configuration_name: str, + **kwargs + ) -> "_models.FrontendIPConfiguration": + """Gets load balancer frontend IP configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param frontend_ip_configuration_name: The name of the frontend IP configuration. + :type frontend_ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FrontendIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FrontendIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'frontendIPConfigurationName': self._serialize.url("frontend_ip_configuration_name", frontend_ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FrontendIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/frontendIPConfigurations/{frontendIPConfigurationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_load_balancing_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_load_balancing_rules_operations.py new file mode 100644 index 000000000000..529002d4ec8b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_load_balancing_rules_operations.py @@ -0,0 +1,178 @@ +# 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 LoadBalancerLoadBalancingRulesOperations: + """LoadBalancerLoadBalancingRulesOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerLoadBalancingRuleListResult"]: + """Gets all the load balancing rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerLoadBalancingRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerLoadBalancingRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerLoadBalancingRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerLoadBalancingRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/loadBalancingRules'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + load_balancing_rule_name: str, + **kwargs + ) -> "_models.LoadBalancingRule": + """Gets the specified load balancer load balancing rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param load_balancing_rule_name: The name of the load balancing rule. + :type load_balancing_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancingRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancingRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'loadBalancingRuleName': self._serialize.url("load_balancing_rule_name", load_balancing_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LoadBalancingRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/loadBalancingRules/{loadBalancingRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_network_interfaces_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_network_interfaces_operations.py new file mode 100644 index 000000000000..14e0ce95f3f2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_network_interfaces_operations.py @@ -0,0 +1,116 @@ +# 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 LoadBalancerNetworkInterfacesOperations: + """LoadBalancerNetworkInterfacesOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets associated load balancer network interfaces. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/networkInterfaces'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_outbound_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_outbound_rules_operations.py new file mode 100644 index 000000000000..80c53630ee5b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_outbound_rules_operations.py @@ -0,0 +1,178 @@ +# 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 LoadBalancerOutboundRulesOperations: + """LoadBalancerOutboundRulesOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerOutboundRuleListResult"]: + """Gets all the outbound rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerOutboundRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerOutboundRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerOutboundRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerOutboundRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/outboundRules'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + outbound_rule_name: str, + **kwargs + ) -> "_models.OutboundRule": + """Gets the specified load balancer outbound rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param outbound_rule_name: The name of the outbound rule. + :type outbound_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: OutboundRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.OutboundRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'outboundRuleName': self._serialize.url("outbound_rule_name", outbound_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('OutboundRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/outboundRules/{outboundRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_probes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_probes_operations.py new file mode 100644 index 000000000000..aa614c613d8b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancer_probes_operations.py @@ -0,0 +1,178 @@ +# 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 LoadBalancerProbesOperations: + """LoadBalancerProbesOperations 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.network.v2020_08_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, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerProbeListResult"]: + """Gets all the load balancer probes. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerProbeListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerProbeListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerProbeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerProbeListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + probe_name: str, + **kwargs + ) -> "_models.Probe": + """Gets load balancer probe. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param probe_name: The name of the probe. + :type probe_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Probe, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Probe + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Probe"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'probeName': self._serialize.url("probe_name", probe_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('Probe', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancers_operations.py new file mode 100644 index 000000000000..c3865f1f3a49 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_load_balancers_operations.py @@ -0,0 +1,545 @@ +# 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 LoadBalancersOperations: + """LoadBalancersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + load_balancer_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + load_balancer_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_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, + load_balancer_name=load_balancer_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_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.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + load_balancer_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.LoadBalancer": + """Gets the specified load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancer, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + load_balancer_name: str, + parameters: "_models.LoadBalancer", + **kwargs + ) -> "_models.LoadBalancer": + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'LoadBalancer') + 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('LoadBalancer', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + load_balancer_name: str, + parameters: "_models.LoadBalancer", + **kwargs + ) -> AsyncLROPoller["_models.LoadBalancer"]: + """Creates or updates a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param parameters: Parameters supplied to the create or update load balancer operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 LoadBalancer or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_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('LoadBalancer', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_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': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + load_balancer_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.LoadBalancer": + """Updates a load balancer tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param parameters: Parameters supplied to update load balancer tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancer, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerListResult"]: + """Gets all the load balancers 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 LoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('LoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/loadBalancers'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.LoadBalancerListResult"]: + """Gets all the load balancers in a 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 LoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/loadBalancers'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_local_network_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_local_network_gateways_operations.py new file mode 100644 index 000000000000..eb7d94f985c7 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_local_network_gateways_operations.py @@ -0,0 +1,474 @@ +# 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 LocalNetworkGatewaysOperations: + """LocalNetworkGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + local_network_gateway_name: str, + parameters: "_models.LocalNetworkGateway", + **kwargs + ) -> "_models.LocalNetworkGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'LocalNetworkGateway') + 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('LocalNetworkGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + local_network_gateway_name: str, + parameters: "_models.LocalNetworkGateway", + **kwargs + ) -> AsyncLROPoller["_models.LocalNetworkGateway"]: + """Creates or updates a local network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :param parameters: Parameters supplied to the create or update local network gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 LocalNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + lro_delay = kwargs.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, + local_network_gateway_name=local_network_gateway_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('LocalNetworkGateway', 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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + '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': 'azure-async-operation'}, 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.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + local_network_gateway_name: str, + **kwargs + ) -> "_models.LocalNetworkGateway": + """Gets the specified local network gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LocalNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + local_network_gateway_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-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + local_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified local network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_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, + local_network_gateway_name=local_network_gateway_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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + '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.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + local_network_gateway_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.LocalNetworkGateway": + """Updates a local network gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :param parameters: Parameters supplied to update local network gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LocalNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.LocalNetworkGatewayListResult"]: + """Gets all the local network gateways in a 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 LocalNetworkGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('LocalNetworkGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/localNetworkGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_gateways_operations.py new file mode 100644 index 000000000000..1907c148a583 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_gateways_operations.py @@ -0,0 +1,546 @@ +# 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 NatGatewaysOperations: + """NatGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + nat_gateway_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-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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.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/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + nat_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified nat gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_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, + nat_gateway_name=nat_gateway_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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_gateway_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.Network/natGateways/{natGatewayName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + nat_gateway_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NatGateway": + """Gets the specified nat gateway in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NatGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + nat_gateway_name: str, + parameters: "_models.NatGateway", + **kwargs + ) -> Optional["_models.NatGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NatGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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(parameters, 'NatGateway') + 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('NatGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + nat_gateway_name: str, + parameters: "_models.NatGateway", + **kwargs + ) -> AsyncLROPoller["_models.NatGateway"]: + """Creates or updates a nat gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param parameters: Parameters supplied to the create or update nat gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NatGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NatGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + lro_delay = kwargs.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, + nat_gateway_name=nat_gateway_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('NatGateway', 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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_gateway_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': 'azure-async-operation'}, 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.Network/natGateways/{natGatewayName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + nat_gateway_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NatGateway": + """Updates nat gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param parameters: Parameters supplied to update nat gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NatGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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(parameters, 'TagsObject') + 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('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.NatGatewayListResult"]: + """Gets all the Nat Gateways 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 NatGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NatGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NatGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/natGateways'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NatGatewayListResult"]: + """Gets all nat gateways in a 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 NatGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NatGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NatGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/natGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_rules_operations.py new file mode 100644 index 000000000000..8475bf6bd02f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_nat_rules_operations.py @@ -0,0 +1,431 @@ +# 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 NatRulesOperations: + """NatRulesOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + gateway_name: str, + nat_rule_name: str, + **kwargs + ) -> "_models.VpnGatewayNatRule": + """Retrieves the details of a nat ruleGet. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnGatewayNatRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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('VpnGatewayNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + gateway_name: str, + nat_rule_name: str, + nat_rule_parameters: "_models.VpnGatewayNatRule", + **kwargs + ) -> "_models.VpnGatewayNatRule": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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(nat_rule_parameters, 'VpnGatewayNatRule') + 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('VpnGatewayNatRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnGatewayNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + gateway_name: str, + nat_rule_name: str, + nat_rule_parameters: "_models.VpnGatewayNatRule", + **kwargs + ) -> AsyncLROPoller["_models.VpnGatewayNatRule"]: + """Creates a nat rule to a scalable vpn gateway if it doesn't exist else updates the existing nat + rules. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_name: str + :param nat_rule_parameters: Parameters supplied to create or Update a Nat Rule. + :type nat_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGatewayNatRule or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + nat_rule_name=nat_rule_name, + nat_rule_parameters=nat_rule_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('VpnGatewayNatRule', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + gateway_name: str, + nat_rule_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + gateway_name: str, + nat_rule_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a nat rule. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_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, + gateway_name=gateway_name, + nat_rule_name=nat_rule_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def list_by_vpn_gateway( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnGatewayNatRulesResult"]: + """Retrieves all nat rules for a particular virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnGatewayNatRulesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewayNatRulesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewayNatRulesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_gateway.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('ListVpnGatewayNatRulesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_vpn_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_ip_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_ip_configurations_operations.py new file mode 100644 index 000000000000..5defc6b96faa --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_ip_configurations_operations.py @@ -0,0 +1,178 @@ +# 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 NetworkInterfaceIPConfigurationsOperations: + """NetworkInterfaceIPConfigurationsOperations 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.network.v2020_08_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, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceIPConfigurationListResult"]: + """Get all ip configurations in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/ipConfigurations'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_interface_name: str, + ip_configuration_name: str, + **kwargs + ) -> "_models.NetworkInterfaceIPConfiguration": + """Gets the specified network interface ip configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the ip configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/ipConfigurations/{ipConfigurationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_load_balancers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_load_balancers_operations.py new file mode 100644 index 000000000000..cca84c6fb806 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_load_balancers_operations.py @@ -0,0 +1,116 @@ +# 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 NetworkInterfaceLoadBalancersOperations: + """NetworkInterfaceLoadBalancersOperations 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.network.v2020_08_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, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceLoadBalancerListResult"]: + """List all load balancers in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceLoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceLoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceLoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceLoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/loadBalancers'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_tap_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_tap_configurations_operations.py new file mode 100644 index 000000000000..5fa2ecd5f739 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interface_tap_configurations_operations.py @@ -0,0 +1,431 @@ +# 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 NetworkInterfaceTapConfigurationsOperations: + """NetworkInterfaceTapConfigurationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_interface_name: str, + tap_configuration_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-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_interface_name: str, + tap_configuration_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified tap configuration from the NetworkInterface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_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, + network_interface_name=network_interface_name, + tap_configuration_name=tap_configuration_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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_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.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_interface_name: str, + tap_configuration_name: str, + **kwargs + ) -> "_models.NetworkInterfaceTapConfiguration": + """Get the specified tap configuration on a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceTapConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceTapConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_interface_name: str, + tap_configuration_name: str, + tap_configuration_parameters: "_models.NetworkInterfaceTapConfiguration", + **kwargs + ) -> "_models.NetworkInterfaceTapConfiguration": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(tap_configuration_parameters, 'NetworkInterfaceTapConfiguration') + 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('NetworkInterfaceTapConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkInterfaceTapConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_interface_name: str, + tap_configuration_name: str, + tap_configuration_parameters: "_models.NetworkInterfaceTapConfiguration", + **kwargs + ) -> AsyncLROPoller["_models.NetworkInterfaceTapConfiguration"]: + """Creates or updates a Tap configuration in the specified NetworkInterface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_name: str + :param tap_configuration_parameters: Parameters supplied to the create or update tap + configuration operation. + :type tap_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkInterfaceTapConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + lro_delay = kwargs.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, + network_interface_name=network_interface_name, + tap_configuration_name=tap_configuration_name, + tap_configuration_parameters=tap_configuration_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('NetworkInterfaceTapConfiguration', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_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': 'azure-async-operation'}, 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.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def list( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceTapConfigurationListResult"]: + """Get all Tap configurations in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceTapConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceTapConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interfaces_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interfaces_operations.py new file mode 100644 index 000000000000..41e6d0acd1c3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_interfaces_operations.py @@ -0,0 +1,1386 @@ +# 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 NetworkInterfacesOperations: + """NetworkInterfacesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_interface_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-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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, + network_interface_name=network_interface_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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_interface_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkInterface": + """Gets information about the specified network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_interface_name: str, + parameters: "_models.NetworkInterface", + **kwargs + ) -> "_models.NetworkInterface": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkInterface') + 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('NetworkInterface', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_interface_name: str, + parameters: "_models.NetworkInterface", + **kwargs + ) -> AsyncLROPoller["_models.NetworkInterface"]: + """Creates or updates a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param parameters: Parameters supplied to the create or update network interface operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkInterface or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + lro_delay = kwargs.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, + network_interface_name=network_interface_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('NetworkInterface', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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': 'azure-async-operation'}, 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.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_interface_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NetworkInterface": + """Updates a network interface tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param parameters: Parameters supplied to update network interface tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets all network interfaces 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 NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkInterfaces'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets all network interfaces in a 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 NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkInterfaces'} # type: ignore + + async def _get_effective_route_table_initial( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> Optional["_models.EffectiveRouteListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.EffectiveRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_effective_route_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('EffectiveRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_effective_route_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveRouteTable'} # type: ignore + + async def begin_get_effective_route_table( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncLROPoller["_models.EffectiveRouteListResult"]: + """Gets all route tables applied to a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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 EffectiveRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.EffectiveRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.EffectiveRouteListResult"] + lro_delay = kwargs.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._get_effective_route_table_initial( + resource_group_name=resource_group_name, + network_interface_name=network_interface_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('EffectiveRouteListResult', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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_get_effective_route_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveRouteTable'} # type: ignore + + async def _list_effective_network_security_groups_initial( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> Optional["_models.EffectiveNetworkSecurityGroupListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.EffectiveNetworkSecurityGroupListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_effective_network_security_groups_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('EffectiveNetworkSecurityGroupListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_effective_network_security_groups_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveNetworkSecurityGroups'} # type: ignore + + async def begin_list_effective_network_security_groups( + self, + resource_group_name: str, + network_interface_name: str, + **kwargs + ) -> AsyncLROPoller["_models.EffectiveNetworkSecurityGroupListResult"]: + """Gets all network security groups applied to a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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 EffectiveNetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroupListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.EffectiveNetworkSecurityGroupListResult"] + lro_delay = kwargs.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_effective_network_security_groups_initial( + resource_group_name=resource_group_name, + network_interface_name=network_interface_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('EffectiveNetworkSecurityGroupListResult', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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_list_effective_network_security_groups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveNetworkSecurityGroups'} # type: ignore + + def list_virtual_machine_scale_set_vm_network_interfaces( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets information about all network interfaces in a virtual machine in a virtual machine scale + set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_vm_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_virtual_machine_scale_set_vm_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces'} # type: ignore + + def list_virtual_machine_scale_set_network_interfaces( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets all network interfaces in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_virtual_machine_scale_set_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/networkInterfaces'} # type: ignore + + async def get_virtual_machine_scale_set_network_interface( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + network_interface_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkInterface": + """Get the specified network interface in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_network_interface.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_network_interface.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def list_virtual_machine_scale_set_ip_configurations( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + network_interface_name: str, + expand: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceIPConfigurationListResult"]: + """Get the specified network interface ip configuration in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :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 NetworkInterfaceIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_ip_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_virtual_machine_scale_set_ip_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipConfigurations'} # type: ignore + + async def get_virtual_machine_scale_set_ip_configuration( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + network_interface_name: str, + ip_configuration_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkInterfaceIPConfiguration": + """Get the specified network interface ip configuration in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the ip configuration. + :type ip_configuration_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_ip_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_ip_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipConfigurations/{ipConfigurationName}'} # type: ignore + + def list_cloud_service_role_instance_network_interfaces( + self, + resource_group_name: str, + cloud_service_name: str, + role_instance_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets information about all network interfaces in a role instance in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_role_instance_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_cloud_service_role_instance_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces'} # type: ignore + + def list_cloud_service_network_interfaces( + self, + resource_group_name: str, + cloud_service_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkInterfaceListResult"]: + """Gets all network interfaces in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_cloud_service_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/networkInterfaces'} # type: ignore + + async def get_cloud_service_network_interface( + self, + resource_group_name: str, + cloud_service_name: str, + role_instance_name: str, + network_interface_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkInterface": + """Get the specified network interface in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_cloud_service_network_interface.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_cloud_service_network_interface.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_management_client_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_management_client_operations.py new file mode 100644 index 000000000000..097c6812379e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_management_client_operations.py @@ -0,0 +1,917 @@ +# 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 NetworkManagementClientOperationsMixin: + + async def _put_bastion_shareable_link_initial( + self, + resource_group_name: str, + bastion_host_name: str, + bsl_request: "_models.BastionShareableLinkListRequest", + **kwargs + ) -> Optional["_models.BastionShareableLinkListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BastionShareableLinkListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._put_bastion_shareable_link_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _put_bastion_shareable_link_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/createShareableLinks'} # type: ignore + + async def begin_put_bastion_shareable_link( + self, + resource_group_name: str, + bastion_host_name: str, + bsl_request: "_models.BastionShareableLinkListRequest", + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.BastionShareableLinkListResult"]]: + """Creates a Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BastionShareableLinkListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.put_bastion_shareable_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(bsl_request, 'BastionShareableLinkListRequest') + 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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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 + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + lro_delay = kwargs.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._put_bastion_shareable_link_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_name, + bsl_request=bsl_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): + 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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_put_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/createShareableLinks'} # type: ignore + + async def _delete_bastion_shareable_link_initial( + self, + resource_group_name: str, + bastion_host_name: str, + bsl_request: "_models.BastionShareableLinkListRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._delete_bastion_shareable_link_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(bsl_request, 'BastionShareableLinkListRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_bastion_shareable_link_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/deleteShareableLinks'} # type: ignore + + async def begin_delete_bastion_shareable_link( + self, + resource_group_name: str, + bastion_host_name: str, + bsl_request: "_models.BastionShareableLinkListRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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_bastion_shareable_link_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_name, + bsl_request=bsl_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/deleteShareableLinks'} # type: ignore + + def get_bastion_shareable_link( + self, + resource_group_name: str, + bastion_host_name: str, + bsl_request: "_models.BastionShareableLinkListRequest", + **kwargs + ) -> AsyncIterable["_models.BastionShareableLinkListResult"]: + """Return the Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.get_bastion_shareable_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(bsl_request, 'BastionShareableLinkListRequest') + 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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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 + ) + get_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getShareableLinks'} # type: ignore + + async def _get_active_sessions_initial( + self, + resource_group_name: str, + bastion_host_name: str, + **kwargs + ) -> Optional["_models.BastionActiveSessionListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BastionActiveSessionListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_active_sessions_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('BastionActiveSessionListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_active_sessions_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getActiveSessions'} # type: ignore + + async def begin_get_active_sessions( + self, + resource_group_name: str, + bastion_host_name: str, + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.BastionActiveSessionListResult"]]: + """Returns the list of currently active sessions on the Bastion. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_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 BastionActiveSessionListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionActiveSessionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct 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_active_sessions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + 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('BastionActiveSessionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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 + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionActiveSessionListResult"] + lro_delay = kwargs.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._get_active_sessions_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_get_active_sessions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getActiveSessions'} # type: ignore + + def disconnect_active_sessions( + self, + resource_group_name: str, + bastion_host_name: str, + session_ids: "_models.SessionIds", + **kwargs + ) -> AsyncIterable["_models.BastionSessionDeleteResult"]: + """Returns the list of currently active sessions on the Bastion. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param session_ids: The list of sessionids to disconnect. + :type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionSessionDeleteResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.disconnect_active_sessions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(session_ids, 'SessionIds') + 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(session_ids, 'SessionIds') + 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('BastionSessionDeleteResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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 + ) + disconnect_active_sessions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/disconnectActiveSessions'} # type: ignore + + async def check_dns_name_availability( + self, + location: str, + domain_name_label: str, + **kwargs + ) -> "_models.DnsNameAvailabilityResult": + """Checks whether a domain name in the cloudapp.azure.com zone is available for use. + + :param location: The location of the domain name. + :type location: str + :param domain_name_label: The domain name to be verified. It must conform to the following + regular expression: ^[a-z][a-z0-9-]{1,61}[a-z0-9]$. + :type domain_name_label: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DnsNameAvailabilityResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DnsNameAvailabilityResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.check_dns_name_availability.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['domainNameLabel'] = self._serialize.query("domain_name_label", domain_name_label, '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('DnsNameAvailabilityResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_dns_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/CheckDnsNameAvailability'} # type: ignore + + async def supported_security_providers( + self, + resource_group_name: str, + virtual_wan_name: str, + **kwargs + ) -> "_models.VirtualWanSecurityProviders": + """Gives the supported security providers for the virtual wan. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN for which supported security providers are + needed. + :type virtual_wan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWanSecurityProviders, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWanSecurityProviders"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.supported_security_providers.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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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('VirtualWanSecurityProviders', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + supported_security_providers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/supportedSecurityProviders'} # type: ignore + + async def _generatevirtualwanvpnserverconfigurationvpnprofile_initial( + self, + resource_group_name: str, + virtual_wan_name: str, + vpn_client_params: "_models.VirtualWanVpnProfileParameters", + **kwargs + ) -> Optional["_models.VpnProfileResponse"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnProfileResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generatevirtualwanvpnserverconfigurationvpnprofile_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(vpn_client_params, 'VirtualWanVpnProfileParameters') + 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('VpnProfileResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generatevirtualwanvpnserverconfigurationvpnprofile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/GenerateVpnProfile'} # type: ignore + + async def begin_generatevirtualwanvpnserverconfigurationvpnprofile( + self, + resource_group_name: str, + virtual_wan_name: str, + vpn_client_params: "_models.VirtualWanVpnProfileParameters", + **kwargs + ) -> AsyncLROPoller["_models.VpnProfileResponse"]: + """Generates a unique VPN profile for P2S clients for VirtualWan and associated + VpnServerConfiguration combination in the specified resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is + needed. + :type virtual_wan_name: str + :param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation + operation. + :type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnProfileResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnProfileResponse"] + lro_delay = kwargs.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._generatevirtualwanvpnserverconfigurationvpnprofile_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_name, + vpn_client_params=vpn_client_params, + 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('VpnProfileResponse', 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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_generatevirtualwanvpnserverconfigurationvpnprofile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/GenerateVpnProfile'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_profiles_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_profiles_operations.py new file mode 100644 index 000000000000..82be41ac1b75 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_profiles_operations.py @@ -0,0 +1,487 @@ +# 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 NetworkProfilesOperations: + """NetworkProfilesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_profile_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-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_profile_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified network profile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the NetworkProfile. + :type network_profile_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, + network_profile_name=network_profile_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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_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.Network/networkProfiles/{networkProfileName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_profile_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkProfile": + """Gets the specified network profile in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the public IP prefix. + :type network_profile_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + network_profile_name: str, + parameters: "_models.NetworkProfile", + **kwargs + ) -> "_models.NetworkProfile": + """Creates or updates a network profile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the network profile. + :type network_profile_name: str + :param parameters: Parameters supplied to the create or update network profile operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkProfile') + 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('NetworkProfile', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_profile_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NetworkProfile": + """Updates network profile tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the network profile. + :type network_profile_name: str + :param parameters: Parameters supplied to update network profile tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.NetworkProfileListResult"]: + """Gets all the network profiles 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 NetworkProfileListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkProfileListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfileListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkProfileListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkProfiles'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkProfileListResult"]: + """Gets all network profiles in a 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 NetworkProfileListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkProfileListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfileListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkProfileListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkProfiles'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_security_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_security_groups_operations.py new file mode 100644 index 000000000000..08dcb5effc13 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_security_groups_operations.py @@ -0,0 +1,546 @@ +# 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 NetworkSecurityGroupsOperations: + """NetworkSecurityGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_security_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-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_security_group_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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, + network_security_group_name=network_security_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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_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.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_security_group_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkSecurityGroup": + """Gets the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_security_group_name: str, + parameters: "_models.NetworkSecurityGroup", + **kwargs + ) -> "_models.NetworkSecurityGroup": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkSecurityGroup') + 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('NetworkSecurityGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_security_group_name: str, + parameters: "_models.NetworkSecurityGroup", + **kwargs + ) -> AsyncLROPoller["_models.NetworkSecurityGroup"]: + """Creates or updates a network security group in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param parameters: Parameters supplied to the create or update network security group + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkSecurityGroup or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + lro_delay = kwargs.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, + network_security_group_name=network_security_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('NetworkSecurityGroup', 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_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': 'azure-async-operation'}, 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.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_security_group_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NetworkSecurityGroup": + """Updates a network security group tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param parameters: Parameters supplied to update network security group tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.NetworkSecurityGroupListResult"]: + """Gets all network security groups 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 NetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkSecurityGroups'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkSecurityGroupListResult"]: + """Gets all network security groups in a 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 NetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkSecurityGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_virtual_appliances_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_virtual_appliances_operations.py new file mode 100644 index 000000000000..88f6451fa559 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_virtual_appliances_operations.py @@ -0,0 +1,545 @@ +# 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 NetworkVirtualAppliancesOperations: + """NetworkVirtualAppliancesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_virtual_appliance_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-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_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, + network_virtual_appliance_name=network_virtual_appliance_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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.NetworkVirtualAppliance": + """Gets the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualAppliance, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NetworkVirtualAppliance": + """Updates a Network Virtual Appliance. + + :param resource_group_name: The resource group name of Network Virtual Appliance. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance being updated. + :type network_virtual_appliance_name: str + :param parameters: Parameters supplied to Update Network Virtual Appliance Tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualAppliance, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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, 'TagsObject') + 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('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + parameters: "_models.NetworkVirtualAppliance", + **kwargs + ) -> "_models.NetworkVirtualAppliance": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkVirtualAppliance') + 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('NetworkVirtualAppliance', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + parameters: "_models.NetworkVirtualAppliance", + **kwargs + ) -> AsyncLROPoller["_models.NetworkVirtualAppliance"]: + """Creates or updates the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkVirtualAppliance or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_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('NetworkVirtualAppliance', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkVirtualApplianceListResult"]: + """Lists all Network Virtual Appliances in a 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 NetworkVirtualApplianceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/networkVirtualAppliances'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.NetworkVirtualApplianceListResult"]: + """Gets all Network Virtual Appliances 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 NetworkVirtualApplianceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/networkVirtualAppliances'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_watchers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_watchers_operations.py new file mode 100644 index 000000000000..fdd47677df26 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_network_watchers_operations.py @@ -0,0 +1,1983 @@ +# 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 NetworkWatchersOperations: + """NetworkWatchersOperations 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.network.v2020_08_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, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.NetworkWatcher", + **kwargs + ) -> "_models.NetworkWatcher": + """Creates or updates a network watcher in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the network watcher resource. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkWatcher') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_watcher_name: str, + **kwargs + ) -> "_models.NetworkWatcher": + """Gets the specified network watcher by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + network_watcher_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_watcher_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified network watcher resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_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, + network_watcher_name=network_watcher_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.NetworkWatcher": + """Updates a network watcher tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters supplied to update network watcher tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkWatcherListResult"]: + """Gets all network watchers by 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 NetworkWatcherListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkWatcherListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcherListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkWatcherListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.NetworkWatcherListResult"]: + """Gets all network watchers by subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkWatcherListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkWatcherListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcherListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkWatcherListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.ErrorResponse, response) + map_error(status_code=response.status_code, 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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkWatchers'} # type: ignore + + async def get_topology( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.TopologyParameters", + **kwargs + ) -> "_models.Topology": + """Gets the current network topology by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the representation of topology. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TopologyParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Topology, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Topology + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Topology"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.get_topology.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TopologyParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Topology', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_topology.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/topology'} # type: ignore + + async def _verify_ip_flow_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.VerificationIPFlowParameters", + **kwargs + ) -> "_models.VerificationIPFlowResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VerificationIPFlowResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._verify_ip_flow_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VerificationIPFlowParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VerificationIPFlowResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('VerificationIPFlowResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _verify_ip_flow_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/ipFlowVerify'} # type: ignore + + async def begin_verify_ip_flow( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.VerificationIPFlowParameters", + **kwargs + ) -> AsyncLROPoller["_models.VerificationIPFlowResult"]: + """Verify IP flow from the specified VM to a location given the currently configured NSG rules. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the IP flow to be verified. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VerificationIPFlowParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VerificationIPFlowResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VerificationIPFlowResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VerificationIPFlowResult"] + lro_delay = kwargs.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._verify_ip_flow_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('VerificationIPFlowResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_verify_ip_flow.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/ipFlowVerify'} # type: ignore + + async def _get_next_hop_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.NextHopParameters", + **kwargs + ) -> "_models.NextHopResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NextHopResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_next_hop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NextHopParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NextHopResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NextHopResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_next_hop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/nextHop'} # type: ignore + + async def begin_get_next_hop( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.NextHopParameters", + **kwargs + ) -> AsyncLROPoller["_models.NextHopResult"]: + """Gets the next hop from the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the source and destination endpoint. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NextHopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NextHopResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NextHopResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NextHopResult"] + lro_delay = kwargs.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._get_next_hop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('NextHopResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_next_hop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/nextHop'} # type: ignore + + async def _get_vm_security_rules_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.SecurityGroupViewParameters", + **kwargs + ) -> "_models.SecurityGroupViewResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityGroupViewResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_vm_security_rules_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'SecurityGroupViewParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SecurityGroupViewResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SecurityGroupViewResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vm_security_rules_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/securityGroupView'} # type: ignore + + async def begin_get_vm_security_rules( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.SecurityGroupViewParameters", + **kwargs + ) -> AsyncLROPoller["_models.SecurityGroupViewResult"]: + """Gets the configured and effective security group rules on the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the VM to check security groups for. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityGroupViewParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityGroupViewResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityGroupViewResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityGroupViewResult"] + lro_delay = kwargs.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._get_vm_security_rules_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('SecurityGroupViewResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_vm_security_rules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/securityGroupView'} # type: ignore + + async def _get_troubleshooting_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.TroubleshootingParameters", + **kwargs + ) -> "_models.TroubleshootingResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_troubleshooting_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TroubleshootingParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_troubleshooting_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/troubleshoot'} # type: ignore + + async def begin_get_troubleshooting( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.TroubleshootingParameters", + **kwargs + ) -> AsyncLROPoller["_models.TroubleshootingResult"]: + """Initiate troubleshooting on a specified resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the resource to troubleshoot. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TroubleshootingParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 TroubleshootingResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.TroubleshootingResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + lro_delay = kwargs.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._get_troubleshooting_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('TroubleshootingResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_troubleshooting.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/troubleshoot'} # type: ignore + + async def _get_troubleshooting_result_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.QueryTroubleshootingParameters", + **kwargs + ) -> "_models.TroubleshootingResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_troubleshooting_result_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'QueryTroubleshootingParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_troubleshooting_result_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryTroubleshootResult'} # type: ignore + + async def begin_get_troubleshooting_result( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.QueryTroubleshootingParameters", + **kwargs + ) -> AsyncLROPoller["_models.TroubleshootingResult"]: + """Get the last completed troubleshooting result on a specified resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the resource to query the troubleshooting result. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.QueryTroubleshootingParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 TroubleshootingResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.TroubleshootingResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + lro_delay = kwargs.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._get_troubleshooting_result_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('TroubleshootingResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_troubleshooting_result.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryTroubleshootResult'} # type: ignore + + async def _set_flow_log_configuration_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.FlowLogInformation", + **kwargs + ) -> "_models.FlowLogInformation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_flow_log_configuration_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLogInformation') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_flow_log_configuration_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/configureFlowLog'} # type: ignore + + async def begin_set_flow_log_configuration( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.FlowLogInformation", + **kwargs + ) -> AsyncLROPoller["_models.FlowLogInformation"]: + """Configures flow log and traffic analytics (optional) on a specified resource. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the configuration of flow log. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLogInformation + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLogInformation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLogInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + lro_delay = kwargs.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._set_flow_log_configuration_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('FlowLogInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_set_flow_log_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/configureFlowLog'} # type: ignore + + async def _get_flow_log_status_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.FlowLogStatusParameters", + **kwargs + ) -> "_models.FlowLogInformation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_flow_log_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLogStatusParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_flow_log_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryFlowLogStatus'} # type: ignore + + async def begin_get_flow_log_status( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.FlowLogStatusParameters", + **kwargs + ) -> AsyncLROPoller["_models.FlowLogInformation"]: + """Queries status of flow log and traffic analytics (optional) on a specified resource. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define a resource to query flow log and traffic analytics + (optional) status. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLogStatusParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLogInformation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLogInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + lro_delay = kwargs.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._get_flow_log_status_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('FlowLogInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_flow_log_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryFlowLogStatus'} # type: ignore + + async def _check_connectivity_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.ConnectivityParameters", + **kwargs + ) -> "_models.ConnectivityInformation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectivityInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_connectivity_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ConnectivityParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectivityInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ConnectivityInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_connectivity_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectivityCheck'} # type: ignore + + async def begin_check_connectivity( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.ConnectivityParameters", + **kwargs + ) -> AsyncLROPoller["_models.ConnectivityInformation"]: + """Verifies the possibility of establishing a direct TCP connection from a virtual machine to a + given endpoint including another VM or an arbitrary remote server. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that determine how the connectivity check will be performed. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectivityParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectivityInformation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectivityInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectivityInformation"] + lro_delay = kwargs.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._check_connectivity_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('ConnectivityInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_check_connectivity.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectivityCheck'} # type: ignore + + async def _get_azure_reachability_report_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.AzureReachabilityReportParameters", + **kwargs + ) -> "_models.AzureReachabilityReport": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureReachabilityReport"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_azure_reachability_report_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AzureReachabilityReportParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AzureReachabilityReport', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AzureReachabilityReport', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_azure_reachability_report_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/azureReachabilityReport'} # type: ignore + + async def begin_get_azure_reachability_report( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.AzureReachabilityReportParameters", + **kwargs + ) -> AsyncLROPoller["_models.AzureReachabilityReport"]: + """NOTE: This feature is currently in preview and still being tested for stability. Gets the + relative latency score for internet service providers from a specified location to Azure + regions. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that determine Azure reachability report configuration. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureReachabilityReport or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReport] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureReachabilityReport"] + lro_delay = kwargs.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._get_azure_reachability_report_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('AzureReachabilityReport', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_azure_reachability_report.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/azureReachabilityReport'} # type: ignore + + async def _list_available_providers_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.AvailableProvidersListParameters", + **kwargs + ) -> "_models.AvailableProvidersList": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableProvidersList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._list_available_providers_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AvailableProvidersListParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AvailableProvidersList', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AvailableProvidersList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_available_providers_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/availableProvidersList'} # type: ignore + + async def begin_list_available_providers( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.AvailableProvidersListParameters", + **kwargs + ) -> AsyncLROPoller["_models.AvailableProvidersList"]: + """NOTE: This feature is currently in preview and still being tested for stability. Lists all + available internet service providers for a specified Azure region. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that scope the list of available providers. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AvailableProvidersList or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableProvidersList"] + lro_delay = kwargs.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_available_providers_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('AvailableProvidersList', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_list_available_providers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/availableProvidersList'} # type: ignore + + async def _get_network_configuration_diagnostic_initial( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.NetworkConfigurationDiagnosticParameters", + **kwargs + ) -> "_models.NetworkConfigurationDiagnosticResponse": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkConfigurationDiagnosticResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_network_configuration_diagnostic_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkConfigurationDiagnosticParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NetworkConfigurationDiagnosticResponse', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NetworkConfigurationDiagnosticResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_network_configuration_diagnostic_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/networkConfigurationDiagnostic'} # type: ignore + + async def begin_get_network_configuration_diagnostic( + self, + resource_group_name: str, + network_watcher_name: str, + parameters: "_models.NetworkConfigurationDiagnosticParameters", + **kwargs + ) -> AsyncLROPoller["_models.NetworkConfigurationDiagnosticResponse"]: + """Gets Network Configuration Diagnostic data to help customers understand and debug network + behavior. It provides detailed information on what security rules were applied to a specified + traffic flow and the result of evaluating these rules. Customers must provide details of a flow + like source, destination, protocol, etc. The API returns whether traffic was allowed or denied, + the rules evaluated for the specified flow and the evaluation results. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters to get network configuration diagnostic. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkConfigurationDiagnosticResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkConfigurationDiagnosticResponse"] + lro_delay = kwargs.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._get_network_configuration_diagnostic_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('NetworkConfigurationDiagnosticResponse', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_network_configuration_diagnostic.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/networkConfigurationDiagnostic'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_operations.py new file mode 100644 index 000000000000..26bdf65575ba --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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.network.v2020_08_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 Network 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.network.v2020_08_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-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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.Network/operations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_p2_svpn_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_p2_svpn_gateways_operations.py new file mode 100644 index 000000000000..29a74c50d423 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_p2_svpn_gateways_operations.py @@ -0,0 +1,1208 @@ +# 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 P2SVpnGatewaysOperations: + """P2SVpnGatewaysOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> "_models.P2SVpnGateway": + """Retrieves the details of a virtual wan p2s vpn gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: P2SVpnGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + gateway_name: str, + p2_s_vpn_gateway_parameters: "_models.P2SVpnGateway", + **kwargs + ) -> "_models.P2SVpnGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(p2_s_vpn_gateway_parameters, 'P2SVpnGateway') + 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('P2SVpnGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + gateway_name: str, + p2_s_vpn_gateway_parameters: "_models.P2SVpnGateway", + **kwargs + ) -> AsyncLROPoller["_models.P2SVpnGateway"]: + """Creates a virtual wan p2s vpn gateway if it doesn't exist else updates the existing gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param p2_s_vpn_gateway_parameters: Parameters supplied to create or Update a virtual wan p2s + vpn gateway. + :type p2_s_vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + p2_s_vpn_gateway_parameters=p2_s_vpn_gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + gateway_name: str, + p2_s_vpn_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.P2SVpnGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(p2_s_vpn_gateway_parameters, 'TagsObject') + 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('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + gateway_name: str, + p2_s_vpn_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.P2SVpnGateway"]: + """Updates virtual wan p2s vpn gateway tags. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param p2_s_vpn_gateway_parameters: Parameters supplied to update a virtual wan p2s vpn gateway + tags. + :type p2_s_vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + p2_s_vpn_gateway_parameters=p2_s_vpn_gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + gateway_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a virtual wan p2s vpn gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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, + gateway_name=gateway_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListP2SVpnGatewaysResult"]: + """Lists all the P2SVpnGateways in a resource group. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :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 ListP2SVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListP2SVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListP2SVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListP2SVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/p2svpnGateways'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListP2SVpnGatewaysResult"]: + """Lists all the P2SVpnGateways 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 ListP2SVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListP2SVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListP2SVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListP2SVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/p2svpnGateways'} # type: ignore + + async def _reset_initial( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> Optional["_models.P2SVpnGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/reset'} # type: ignore + + async def begin_reset( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.P2SVpnGateway"]: + """Resets the primary of the p2s vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/reset'} # type: ignore + + async def _generate_vpn_profile_initial( + self, + resource_group_name: str, + gateway_name: str, + parameters: "_models.P2SVpnProfileParameters", + **kwargs + ) -> Optional["_models.VpnProfileResponse"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnProfileResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generate_vpn_profile_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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(parameters, 'P2SVpnProfileParameters') + 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('VpnProfileResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generate_vpn_profile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/generatevpnprofile'} # type: ignore + + async def begin_generate_vpn_profile( + self, + resource_group_name: str, + gateway_name: str, + parameters: "_models.P2SVpnProfileParameters", + **kwargs + ) -> AsyncLROPoller["_models.VpnProfileResponse"]: + """Generates VPN profile for P2S client of the P2SVpnGateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_name: str + :param parameters: Parameters supplied to the generate P2SVpnGateway VPN client package + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.P2SVpnProfileParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnProfileResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnProfileResponse"] + lro_delay = kwargs.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._generate_vpn_profile_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('VpnProfileResponse', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_generate_vpn_profile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/generatevpnprofile'} # type: ignore + + async def _get_p2_s_vpn_connection_health_initial( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> Optional["_models.P2SVpnGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_p2_s_vpn_connection_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_p2_s_vpn_connection_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealth'} # type: ignore + + async def begin_get_p2_s_vpn_connection_health( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.P2SVpnGateway"]: + """Gets the connection health of P2S clients of the virtual wan P2SVpnGateway in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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._get_p2_s_vpn_connection_health_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_get_p2_s_vpn_connection_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealth'} # type: ignore + + async def _get_p2_s_vpn_connection_health_detailed_initial( + self, + resource_group_name: str, + gateway_name: str, + request: "_models.P2SVpnConnectionHealthRequest", + **kwargs + ) -> Optional["_models.P2SVpnConnectionHealth"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnConnectionHealth"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_p2_s_vpn_connection_health_detailed_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(request, 'P2SVpnConnectionHealthRequest') + 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('P2SVpnConnectionHealth', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_p2_s_vpn_connection_health_detailed_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealthDetailed'} # type: ignore + + async def begin_get_p2_s_vpn_connection_health_detailed( + self, + resource_group_name: str, + gateway_name: str, + request: "_models.P2SVpnConnectionHealthRequest", + **kwargs + ) -> AsyncLROPoller["_models.P2SVpnConnectionHealth"]: + """Gets the sas url to get the connection health detail of P2S clients of the virtual wan + P2SVpnGateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_name: str + :param request: Request parameters supplied to get p2s vpn connections detailed health. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionHealthRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnConnectionHealth or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionHealth] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnConnectionHealth"] + lro_delay = kwargs.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._get_p2_s_vpn_connection_health_detailed_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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): + deserialized = self._deserialize('P2SVpnConnectionHealth', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_get_p2_s_vpn_connection_health_detailed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealthDetailed'} # type: ignore + + async def _disconnect_p2_s_vpn_connections_initial( + self, + resource_group_name: str, + p2_s_vpn_gateway_name: str, + request: "_models.P2SVpnConnectionRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._disconnect_p2_s_vpn_connections_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'), + 'p2sVpnGatewayName': self._serialize.url("p2_s_vpn_gateway_name", p2_s_vpn_gateway_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(request, 'P2SVpnConnectionRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _disconnect_p2_s_vpn_connections_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{p2sVpnGatewayName}/disconnectP2sVpnConnections'} # type: ignore + + async def begin_disconnect_p2_s_vpn_connections( + self, + resource_group_name: str, + p2_s_vpn_gateway_name: str, + request: "_models.P2SVpnConnectionRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Disconnect P2S vpn connections of the virtual wan P2SVpnGateway in the specified resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param p2_s_vpn_gateway_name: The name of the P2S Vpn Gateway. + :type p2_s_vpn_gateway_name: str + :param request: The parameters are supplied to disconnect p2s vpn connections. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._disconnect_p2_s_vpn_connections_initial( + resource_group_name=resource_group_name, + p2_s_vpn_gateway_name=p2_s_vpn_gateway_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'p2sVpnGatewayName': self._serialize.url("p2_s_vpn_gateway_name", p2_s_vpn_gateway_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_disconnect_p2_s_vpn_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{p2sVpnGatewayName}/disconnectP2sVpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_packet_captures_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_packet_captures_operations.py new file mode 100644 index 000000000000..6578c76810de --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_packet_captures_operations.py @@ -0,0 +1,672 @@ +# 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 PacketCapturesOperations: + """PacketCapturesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + parameters: "_models.PacketCapture", + **kwargs + ) -> "_models.PacketCaptureResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PacketCapture') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PacketCaptureResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + async def begin_create( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + parameters: "_models.PacketCapture", + **kwargs + ) -> AsyncLROPoller["_models.PacketCaptureResult"]: + """Create and start a packet capture on the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_name: str + :param parameters: Parameters that define the create packet capture operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PacketCapture + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PacketCaptureResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + lro_delay = kwargs.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_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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('PacketCaptureResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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': 'azure-async-operation'}, 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.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + **kwargs + ) -> "_models.PacketCaptureResult": + """Gets a packet capture session by name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PacketCaptureResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PacketCaptureResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_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, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + async def _stop_initial( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/stop'} # type: ignore + + async def begin_stop( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Stops a specified packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_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._stop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/stop'} # type: ignore + + async def _get_status_initial( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + **kwargs + ) -> "_models.PacketCaptureQueryStatusResult": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureQueryStatusResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PacketCaptureQueryStatusResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PacketCaptureQueryStatusResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/queryStatus'} # type: ignore + + async def begin_get_status( + self, + resource_group_name: str, + network_watcher_name: str, + packet_capture_name: str, + **kwargs + ) -> AsyncLROPoller["_models.PacketCaptureQueryStatusResult"]: + """Query the status of a running packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param packet_capture_name: The name given to the packet capture session. + :type packet_capture_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 PacketCaptureQueryStatusResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PacketCaptureQueryStatusResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureQueryStatusResult"] + lro_delay = kwargs.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._get_status_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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('PacketCaptureQueryStatusResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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_get_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/queryStatus'} # type: ignore + + def list( + self, + resource_group_name: str, + network_watcher_name: str, + **kwargs + ) -> AsyncIterable["_models.PacketCaptureListResult"]: + """Lists all packet capture sessions within the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PacketCaptureListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PacketCaptureListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PacketCaptureListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/packetCaptures'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_peer_express_route_circuit_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_peer_express_route_circuit_connections_operations.py new file mode 100644 index 000000000000..9c16d6881040 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_peer_express_route_circuit_connections_operations.py @@ -0,0 +1,188 @@ +# 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 PeerExpressRouteCircuitConnectionsOperations: + """PeerExpressRouteCircuitConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + connection_name: str, + **kwargs + ) -> "_models.PeerExpressRouteCircuitConnection": + """Gets the specified Peer Express Route Circuit Connection from the specified express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the peer express route circuit connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PeerExpressRouteCircuitConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PeerExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/peerConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name: str, + circuit_name: str, + peering_name: str, + **kwargs + ) -> AsyncIterable["_models.PeerExpressRouteCircuitConnectionListResult"]: + """Gets all global reach peer connections associated with a private peering in an express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PeerExpressRouteCircuitConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerExpressRouteCircuitConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PeerExpressRouteCircuitConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/peerConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_dns_zone_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_dns_zone_groups_operations.py new file mode 100644 index 000000000000..f2b1cf48ef9a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_dns_zone_groups_operations.py @@ -0,0 +1,432 @@ +# 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 PrivateDnsZoneGroupsOperations: + """PrivateDnsZoneGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + private_endpoint_name: str, + private_dns_zone_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-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + private_endpoint_name: str, + private_dns_zone_group_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified private dns zone group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_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, + private_endpoint_name=private_endpoint_name, + private_dns_zone_group_name=private_dns_zone_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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_group_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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + private_endpoint_name: str, + private_dns_zone_group_name: str, + **kwargs + ) -> "_models.PrivateDnsZoneGroup": + """Gets the private dns zone group resource by specified private dns zone group name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateDnsZoneGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PrivateDnsZoneGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + private_endpoint_name: str, + private_dns_zone_group_name: str, + parameters: "_models.PrivateDnsZoneGroup", + **kwargs + ) -> "_models.PrivateDnsZoneGroup": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateDnsZoneGroup') + 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('PrivateDnsZoneGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateDnsZoneGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + private_endpoint_name: str, + private_dns_zone_group_name: str, + parameters: "_models.PrivateDnsZoneGroup", + **kwargs + ) -> AsyncLROPoller["_models.PrivateDnsZoneGroup"]: + """Creates or updates a private dns zone group in the specified private endpoint. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_group_name: str + :param parameters: Parameters supplied to the create or update private dns zone group + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateDnsZoneGroup or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + lro_delay = kwargs.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, + private_endpoint_name=private_endpoint_name, + private_dns_zone_group_name=private_dns_zone_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('PrivateDnsZoneGroup', 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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_group_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': 'azure-async-operation'}, 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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def list( + self, + private_endpoint_name: str, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.PrivateDnsZoneGroupListResult"]: + """Gets all private dns zone groups in a private endpoint. + + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :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 PrivateDnsZoneGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + '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('PrivateDnsZoneGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_endpoints_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_endpoints_operations.py new file mode 100644 index 000000000000..c33d291ec1b7 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_endpoints_operations.py @@ -0,0 +1,484 @@ +# 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 PrivateEndpointsOperations: + """PrivateEndpointsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + private_endpoint_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-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + private_endpoint_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified private endpoint. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_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, + private_endpoint_name=private_endpoint_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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + private_endpoint_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PrivateEndpoint": + """Gets the specified private endpoint by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpoint, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + private_endpoint_name: str, + parameters: "_models.PrivateEndpoint", + **kwargs + ) -> "_models.PrivateEndpoint": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateEndpoint') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + private_endpoint_name: str, + parameters: "_models.PrivateEndpoint", + **kwargs + ) -> AsyncLROPoller["_models.PrivateEndpoint"]: + """Creates or updates an private endpoint in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param parameters: Parameters supplied to the create or update private endpoint operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateEndpoint or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + lro_delay = kwargs.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, + private_endpoint_name=private_endpoint_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('PrivateEndpoint', 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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_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': 'azure-async-operation'}, 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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.PrivateEndpointListResult"]: + """Gets all private endpoints in a 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 PrivateEndpointListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateEndpointListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints'} # type: ignore + + def list_by_subscription( + self, + **kwargs + ) -> AsyncIterable["_models.PrivateEndpointListResult"]: + """Gets all private endpoints 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 PrivateEndpointListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('PrivateEndpointListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_link_services_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_link_services_operations.py new file mode 100644 index 000000000000..383fd3ed322a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_private_link_services_operations.py @@ -0,0 +1,1207 @@ +# 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 PrivateLinkServicesOperations: + """PrivateLinkServicesOperations 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.network.v2020_08_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_initial( + self, + resource_group_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 = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/privateLinkServices/{serviceName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + service_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified private link service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :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, + 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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_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.Network/privateLinkServices/{serviceName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + service_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PrivateLinkService": + """Gets the specified private link service by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkService, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateLinkService + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + service_name: str, + parameters: "_models.PrivateLinkService", + **kwargs + ) -> "_models.PrivateLinkService": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateLinkService') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + service_name: str, + parameters: "_models.PrivateLinkService", + **kwargs + ) -> AsyncLROPoller["_models.PrivateLinkService"]: + """Creates or updates an private link service in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param parameters: Parameters supplied to the create or update private link service operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateLinkService + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkService or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkService] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + lro_delay = kwargs.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, + 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('PrivateLinkService', 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'), + 'serviceName': self._serialize.url("service_name", service_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': 'azure-async-operation'}, 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.Network/privateLinkServices/{serviceName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.PrivateLinkServiceListResult"]: + """Gets all private link services in a 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 PrivateLinkServiceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateLinkServiceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateLinkServices'} # type: ignore + + def list_by_subscription( + self, + **kwargs + ) -> AsyncIterable["_models.PrivateLinkServiceListResult"]: + """Gets all private link service 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 PrivateLinkServiceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('PrivateLinkServiceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateLinkServices'} # type: ignore + + async def get_private_endpoint_connection( + self, + resource_group_name: str, + service_name: str, + pe_connection_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PrivateEndpointConnection": + """Get the specific private end point connection by specific private link service in the resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_connection_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + async def update_private_endpoint_connection( + self, + resource_group_name: str, + service_name: str, + pe_connection_name: str, + parameters: "_models.PrivateEndpointConnection", + **kwargs + ) -> "_models.PrivateEndpointConnection": + """Approve or reject private end point connection for a private link service in a subscription. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_connection_name: str + :param parameters: Parameters supplied to approve or reject the private end point connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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(parameters, 'PrivateEndpointConnection') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + async def _delete_private_endpoint_connection_initial( + self, + resource_group_name: str, + service_name: str, + pe_connection_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-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + async def begin_delete_private_endpoint_connection( + self, + resource_group_name: str, + service_name: str, + pe_connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Delete private end point connection for a private link service in a subscription. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_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 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_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + service_name=service_name, + pe_connection_name=pe_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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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, 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_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + def list_private_endpoint_connections( + self, + resource_group_name: str, + service_name: str, + **kwargs + ) -> AsyncIterable["_models.PrivateEndpointConnectionListResult"]: + """Gets all private end point connections for a specific private link service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PrivateEndpointConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_private_endpoint_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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_private_endpoint_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections'} # type: ignore + + async def _check_private_link_service_visibility_initial( + self, + location: str, + parameters: "_models.CheckPrivateLinkServiceVisibilityRequest", + **kwargs + ) -> Optional["_models.PrivateLinkServiceVisibility"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PrivateLinkServiceVisibility"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_private_link_service_visibility_initial.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(parameters, 'CheckPrivateLinkServiceVisibilityRequest') + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_private_link_service_visibility_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + async def begin_check_private_link_service_visibility( + self, + location: str, + parameters: "_models.CheckPrivateLinkServiceVisibilityRequest", + **kwargs + ) -> AsyncLROPoller["_models.PrivateLinkServiceVisibility"]: + """Checks whether the subscription is visible to private link service. + + :param location: The location of the domain name. + :type location: str + :param parameters: The request body of CheckPrivateLinkService API call. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CheckPrivateLinkServiceVisibilityRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkServiceVisibility or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceVisibility] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceVisibility"] + lro_delay = kwargs.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._check_private_link_service_visibility_initial( + location=location, + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'location': self._serialize.url("location", location, '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_check_private_link_service_visibility.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + async def _check_private_link_service_visibility_by_resource_group_initial( + self, + location: str, + resource_group_name: str, + parameters: "_models.CheckPrivateLinkServiceVisibilityRequest", + **kwargs + ) -> Optional["_models.PrivateLinkServiceVisibility"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PrivateLinkServiceVisibility"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_private_link_service_visibility_by_resource_group_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + '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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'CheckPrivateLinkServiceVisibilityRequest') + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_private_link_service_visibility_by_resource_group_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + async def begin_check_private_link_service_visibility_by_resource_group( + self, + location: str, + resource_group_name: str, + parameters: "_models.CheckPrivateLinkServiceVisibilityRequest", + **kwargs + ) -> AsyncLROPoller["_models.PrivateLinkServiceVisibility"]: + """Checks whether the subscription is visible to private link service in the specified resource + group. + + :param location: The location of the domain name. + :type location: str + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param parameters: The request body of CheckPrivateLinkService API call. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CheckPrivateLinkServiceVisibilityRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkServiceVisibility or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceVisibility] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceVisibility"] + lro_delay = kwargs.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._check_private_link_service_visibility_by_resource_group_initial( + location=location, + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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_check_private_link_service_visibility_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + def list_auto_approved_private_link_services( + self, + location: str, + **kwargs + ) -> AsyncIterable["_models.AutoApprovedPrivateLinkServicesResult"]: + """Returns all of the private link service ids that can be linked to a Private Endpoint with auto + approved in this subscription in this region. + + :param location: The location of the domain name. + :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 AutoApprovedPrivateLinkServicesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkServicesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AutoApprovedPrivateLinkServicesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_auto_approved_private_link_services.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('AutoApprovedPrivateLinkServicesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_auto_approved_private_link_services.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/autoApprovedPrivateLinkServices'} # type: ignore + + def list_auto_approved_private_link_services_by_resource_group( + self, + location: str, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AutoApprovedPrivateLinkServicesResult"]: + """Returns all of the private link service ids that can be linked to a Private Endpoint with auto + approved in this subscription in this region. + + :param location: The location of the domain name. + :type location: str + :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 AutoApprovedPrivateLinkServicesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkServicesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AutoApprovedPrivateLinkServicesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_auto_approved_private_link_services_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + '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('AutoApprovedPrivateLinkServicesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_auto_approved_private_link_services_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/autoApprovedPrivateLinkServices'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_addresses_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_addresses_operations.py new file mode 100644 index 000000000000..9d0ad0dccfe6 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_addresses_operations.py @@ -0,0 +1,1025 @@ +# 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 PublicIPAddressesOperations: + """PublicIPAddressesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + public_ip_address_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-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + public_ip_address_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified public IP address. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_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, + public_ip_address_name=public_ip_address_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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_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.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + public_ip_address_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PublicIPAddress": + """Gets the specified public IP address in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + public_ip_address_name: str, + parameters: "_models.PublicIPAddress", + **kwargs + ) -> "_models.PublicIPAddress": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PublicIPAddress') + 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('PublicIPAddress', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + public_ip_address_name: str, + parameters: "_models.PublicIPAddress", + **kwargs + ) -> AsyncLROPoller["_models.PublicIPAddress"]: + """Creates or updates a static or dynamic public IP address. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param parameters: Parameters supplied to the create or update public IP address operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PublicIPAddress or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PublicIPAddress] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + lro_delay = kwargs.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, + public_ip_address_name=public_ip_address_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('PublicIPAddress', 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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_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': 'azure-async-operation'}, 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.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + public_ip_address_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.PublicIPAddress": + """Updates public IP address tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param parameters: Parameters supplied to update public IP address tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets all the public IP addresses 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 PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/publicIPAddresses'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets all public IP addresses in a 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 PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/publicIPAddresses'} # type: ignore + + def list_virtual_machine_scale_set_public_ip_addresses( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets information about all public IP addresses on a virtual machine scale set level. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_virtual_machine_scale_set_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/publicipaddresses'} # type: ignore + + def list_virtual_machine_scale_set_vm_public_ip_addresses( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + network_interface_name: str, + ip_configuration_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets information about all public IP addresses in a virtual machine IP configuration in a + virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The network interface name. + :type network_interface_name: str + :param ip_configuration_name: The IP configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_vm_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_virtual_machine_scale_set_vm_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses'} # type: ignore + + async def get_virtual_machine_scale_set_public_ip_address( + self, + resource_group_name: str, + virtual_machine_scale_set_name: str, + virtualmachine_index: str, + network_interface_name: str, + ip_configuration_name: str, + public_ip_address_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PublicIPAddress": + """Get the specified public IP address in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the IP configuration. + :type ip_configuration_name: str + :param public_ip_address_name: The name of the public IP Address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_public_ip_address.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_public_ip_address.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses/{publicIpAddressName}'} # type: ignore + + def list_cloud_service_public_ip_addresses( + self, + resource_group_name: str, + cloud_service_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets information about all public IP addresses on a cloud service level. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_cloud_service_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/publicipaddresses'} # type: ignore + + def list_cloud_service_role_instance_public_ip_addresses( + self, + resource_group_name: str, + cloud_service_name: str, + role_instance_name: str, + network_interface_name: str, + ip_configuration_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPAddressListResult"]: + """Gets information about all public IP addresses in a role instance IP configuration in a cloud + service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :param network_interface_name: The network interface name. + :type network_interface_name: str + :param ip_configuration_name: The IP configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_role_instance_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_cloud_service_role_instance_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses'} # type: ignore + + async def get_cloud_service_public_ip_address( + self, + resource_group_name: str, + cloud_service_name: str, + role_instance_name: str, + network_interface_name: str, + ip_configuration_name: str, + public_ip_address_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PublicIPAddress": + """Get the specified public IP address in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The role instance name. + :type role_instance_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the IP configuration. + :type ip_configuration_name: str + :param public_ip_address_name: The name of the public IP Address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_cloud_service_public_ip_address.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_cloud_service_public_ip_address.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses/{publicIpAddressName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_prefixes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_prefixes_operations.py new file mode 100644 index 000000000000..22cadac2900f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_public_ip_prefixes_operations.py @@ -0,0 +1,545 @@ +# 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 PublicIPPrefixesOperations: + """PublicIPPrefixesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + public_ip_prefix_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-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + public_ip_prefix_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified public IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the PublicIpPrefix. + :type public_ip_prefix_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, + public_ip_prefix_name=public_ip_prefix_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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_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.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + public_ip_prefix_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.PublicIPPrefix": + """Gets the specified public IP prefix in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + public_ip_prefix_name: str, + parameters: "_models.PublicIPPrefix", + **kwargs + ) -> "_models.PublicIPPrefix": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PublicIPPrefix') + 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('PublicIPPrefix', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + public_ip_prefix_name: str, + parameters: "_models.PublicIPPrefix", + **kwargs + ) -> AsyncLROPoller["_models.PublicIPPrefix"]: + """Creates or updates a static or dynamic public IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param parameters: Parameters supplied to the create or update public IP prefix operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PublicIPPrefix or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + lro_delay = kwargs.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, + public_ip_prefix_name=public_ip_prefix_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('PublicIPPrefix', 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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_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.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + public_ip_prefix_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.PublicIPPrefix": + """Updates public IP prefix tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param parameters: Parameters supplied to update public IP prefix tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.PublicIPPrefixListResult"]: + """Gets all the public IP prefixes 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 PublicIPPrefixListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('PublicIPPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/publicIPPrefixes'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.PublicIPPrefixListResult"]: + """Gets all public IP prefixes in a 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 PublicIPPrefixListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/publicIPPrefixes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_resource_navigation_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_resource_navigation_links_operations.py new file mode 100644 index 000000000000..b04b46f8fd40 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_resource_navigation_links_operations.py @@ -0,0 +1,103 @@ +# 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 ResourceNavigationLinksOperations: + """ResourceNavigationLinksOperations 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.network.v2020_08_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_group_name: str, + virtual_network_name: str, + subnet_name: str, + **kwargs + ) -> "_models.ResourceNavigationLinksListResult": + """Gets a list of resource navigation links for a subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNavigationLinksListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLinksListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNavigationLinksListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ResourceNavigationLinksListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/ResourceNavigationLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filter_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filter_rules_operations.py new file mode 100644 index 000000000000..f2d3911dcce7 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filter_rules_operations.py @@ -0,0 +1,431 @@ +# 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 RouteFilterRulesOperations: + """RouteFilterRulesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + route_filter_name: str, + rule_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-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + route_filter_name: str, + rule_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified rule from a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the rule. + :type rule_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, + route_filter_name=route_filter_name, + rule_name=rule_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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_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.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + route_filter_name: str, + rule_name: str, + **kwargs + ) -> "_models.RouteFilterRule": + """Gets the specified rule from a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the rule. + :type rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilterRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilterRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteFilterRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + route_filter_name: str, + rule_name: str, + route_filter_rule_parameters: "_models.RouteFilterRule", + **kwargs + ) -> "_models.RouteFilterRule": + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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_filter_rule_parameters, 'RouteFilterRule') + 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('RouteFilterRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteFilterRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + route_filter_name: str, + rule_name: str, + route_filter_rule_parameters: "_models.RouteFilterRule", + **kwargs + ) -> AsyncLROPoller["_models.RouteFilterRule"]: + """Creates or updates a route in the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the route filter rule. + :type rule_name: str + :param route_filter_rule_parameters: Parameters supplied to the create or update route filter + rule operation. + :type route_filter_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.RouteFilterRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteFilterRule or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + lro_delay = kwargs.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, + route_filter_name=route_filter_name, + rule_name=rule_name, + route_filter_rule_parameters=route_filter_rule_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('RouteFilterRule', 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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_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': 'azure-async-operation'}, 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.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def list_by_route_filter( + self, + resource_group_name: str, + route_filter_name: str, + **kwargs + ) -> AsyncIterable["_models.RouteFilterRuleListResult"]: + """Gets all RouteFilterRules in a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RouteFilterRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_route_filter.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RouteFilterRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_route_filter.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filters_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filters_operations.py new file mode 100644 index 000000000000..70507aa919c8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_filters_operations.py @@ -0,0 +1,546 @@ +# 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 RouteFiltersOperations: + """RouteFiltersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + route_filter_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-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + route_filter_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_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, + route_filter_name=route_filter_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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_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.Network/routeFilters/{routeFilterName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + route_filter_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.RouteFilter": + """Gets the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param expand: Expands referenced express route bgp peering resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + route_filter_name: str, + route_filter_parameters: "_models.RouteFilter", + **kwargs + ) -> "_models.RouteFilter": + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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_filter_parameters, 'RouteFilter') + 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('RouteFilter', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + route_filter_name: str, + route_filter_parameters: "_models.RouteFilter", + **kwargs + ) -> AsyncLROPoller["_models.RouteFilter"]: + """Creates or updates a route filter in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param route_filter_parameters: Parameters supplied to the create or update route filter + operation. + :type route_filter_parameters: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteFilter or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.RouteFilter] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + lro_delay = kwargs.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, + route_filter_name=route_filter_name, + route_filter_parameters=route_filter_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('RouteFilter', 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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_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': 'azure-async-operation'}, 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.Network/routeFilters/{routeFilterName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + route_filter_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.RouteFilter": + """Updates tags of a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param parameters: Parameters supplied to update route filter tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.RouteFilterListResult"]: + """Gets all route filters in a 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 RouteFilterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('RouteFilterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/routeFilters'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.RouteFilterListResult"]: + """Gets all route filters 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 RouteFilterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('RouteFilterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/routeFilters'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_tables_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_tables_operations.py new file mode 100644 index 000000000000..5b3a42888f0b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_route_tables_operations.py @@ -0,0 +1,545 @@ +# 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 RouteTablesOperations: + """RouteTablesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + route_table_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-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + route_table_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_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, + route_table_name=route_table_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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/routeTables/{routeTableName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + route_table_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.RouteTable": + """Gets the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + route_table_name: str, + parameters: "_models.RouteTable", + **kwargs + ) -> "_models.RouteTable": + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'RouteTable') + 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('RouteTable', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + route_table_name: str, + parameters: "_models.RouteTable", + **kwargs + ) -> AsyncLROPoller["_models.RouteTable"]: + """Create or updates a route table in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param parameters: Parameters supplied to the create or update route table operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteTable or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.RouteTable] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + lro_delay = kwargs.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, + route_table_name=route_table_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('RouteTable', 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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': 'azure-async-operation'}, 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.Network/routeTables/{routeTableName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + route_table_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.RouteTable": + """Updates a route table tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param parameters: Parameters supplied to update route table tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.RouteTableListResult"]: + """Gets all route tables in a 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 RouteTableListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteTableListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTableListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RouteTableListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/routeTables'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.RouteTableListResult"]: + """Gets all route tables 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 RouteTableListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteTableListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTableListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('RouteTableListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/routeTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_routes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_routes_operations.py new file mode 100644 index 000000000000..cc6df955e5cd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_routes_operations.py @@ -0,0 +1,430 @@ +# 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 RoutesOperations: + """RoutesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + route_table_name: str, + route_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-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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, 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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + route_table_name: str, + route_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified route from a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_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, + route_table_name=route_table_name, + route_name=route_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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'routeName': self._serialize.url("route_name", route_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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + route_table_name: str, + route_name: str, + **kwargs + ) -> "_models.Route": + """Gets the specified route from a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Route, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Route + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Route', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + route_table_name: str, + route_name: str, + route_parameters: "_models.Route", + **kwargs + ) -> "_models.Route": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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_parameters, 'Route') + 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('Route', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('Route', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + route_table_name: str, + route_name: str, + route_parameters: "_models.Route", + **kwargs + ) -> AsyncLROPoller["_models.Route"]: + """Creates or updates a route in the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_name: str + :param route_parameters: Parameters supplied to the create or update route operation. + :type route_parameters: ~azure.mgmt.network.v2020_08_01.models.Route + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 Route or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.Route] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + lro_delay = kwargs.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, + route_table_name=route_table_name, + route_name=route_name, + route_parameters=route_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('Route', 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'routeName': self._serialize.url("route_name", route_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': 'azure-async-operation'}, 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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def list( + self, + resource_group_name: str, + route_table_name: str, + **kwargs + ) -> AsyncIterable["_models.RouteListResult"]: + """Gets all routes in a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RouteListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RouteListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/routeTables/{routeTableName}/routes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_partner_providers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_partner_providers_operations.py new file mode 100644 index 000000000000..e696bcea99c0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_partner_providers_operations.py @@ -0,0 +1,541 @@ +# 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 SecurityPartnerProvidersOperations: + """SecurityPartnerProvidersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + security_partner_provider_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-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + security_partner_provider_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_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, + security_partner_provider_name=security_partner_provider_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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_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.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + security_partner_provider_name: str, + **kwargs + ) -> "_models.SecurityPartnerProvider": + """Gets the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityPartnerProvider, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + security_partner_provider_name: str, + parameters: "_models.SecurityPartnerProvider", + **kwargs + ) -> "_models.SecurityPartnerProvider": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'SecurityPartnerProvider') + 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('SecurityPartnerProvider', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + security_partner_provider_name: str, + parameters: "_models.SecurityPartnerProvider", + **kwargs + ) -> AsyncLROPoller["_models.SecurityPartnerProvider"]: + """Creates or updates the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :param parameters: Parameters supplied to the create or update Security Partner Provider + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityPartnerProvider or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + lro_delay = kwargs.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, + security_partner_provider_name=security_partner_provider_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('SecurityPartnerProvider', 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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_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': 'azure-async-operation'}, 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.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + security_partner_provider_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.SecurityPartnerProvider": + """Updates tags of a Security Partner Provider resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :param parameters: Parameters supplied to update Security Partner Provider tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityPartnerProvider, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.SecurityPartnerProviderListResult"]: + """Lists all Security Partner Providers in a 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 SecurityPartnerProviderListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('SecurityPartnerProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/securityPartnerProviders'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.SecurityPartnerProviderListResult"]: + """Gets all the Security Partner Providers 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 SecurityPartnerProviderListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('SecurityPartnerProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/securityPartnerProviders'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_rules_operations.py new file mode 100644 index 000000000000..e300f9f26e2e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_security_rules_operations.py @@ -0,0 +1,431 @@ +# 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 SecurityRulesOperations: + """SecurityRulesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_security_group_name: str, + security_rule_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-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_security_group_name: str, + security_rule_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_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, + network_security_group_name=network_security_group_name, + security_rule_name=security_rule_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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_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.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_security_group_name: str, + security_rule_name: str, + **kwargs + ) -> "_models.SecurityRule": + """Get the specified network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_security_group_name: str, + security_rule_name: str, + security_rule_parameters: "_models.SecurityRule", + **kwargs + ) -> "_models.SecurityRule": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(security_rule_parameters, 'SecurityRule') + 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('SecurityRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_security_group_name: str, + security_rule_name: str, + security_rule_parameters: "_models.SecurityRule", + **kwargs + ) -> AsyncLROPoller["_models.SecurityRule"]: + """Creates or updates a security rule in the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_name: str + :param security_rule_parameters: Parameters supplied to the create or update network security + rule operation. + :type security_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityRule or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + lro_delay = kwargs.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, + network_security_group_name=network_security_group_name, + security_rule_name=security_rule_name, + security_rule_parameters=security_rule_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('SecurityRule', 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_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': 'azure-async-operation'}, 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.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def list( + self, + resource_group_name: str, + network_security_group_name: str, + **kwargs + ) -> AsyncIterable["_models.SecurityRuleListResult"]: + """Gets all security rules in a network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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 SecurityRuleListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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('SecurityRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_association_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_association_links_operations.py new file mode 100644 index 000000000000..aaa2b780a512 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_association_links_operations.py @@ -0,0 +1,103 @@ +# 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 ServiceAssociationLinksOperations: + """ServiceAssociationLinksOperations 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.network.v2020_08_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_group_name: str, + virtual_network_name: str, + subnet_name: str, + **kwargs + ) -> "_models.ServiceAssociationLinksListResult": + """Gets a list of service association links for a subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceAssociationLinksListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLinksListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceAssociationLinksListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceAssociationLinksListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/ServiceAssociationLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policies_operations.py new file mode 100644 index 000000000000..666d86159173 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policies_operations.py @@ -0,0 +1,546 @@ +# 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 ServiceEndpointPoliciesOperations: + """ServiceEndpointPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + service_endpoint_policy_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-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_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, + service_endpoint_policy_name=service_endpoint_policy_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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.ServiceEndpointPolicy": + """Gets the specified service Endpoint Policies in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + parameters: "_models.ServiceEndpointPolicy", + **kwargs + ) -> "_models.ServiceEndpointPolicy": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ServiceEndpointPolicy') + 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('ServiceEndpointPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + parameters: "_models.ServiceEndpointPolicy", + **kwargs + ) -> AsyncLROPoller["_models.ServiceEndpointPolicy"]: + """Creates or updates a service Endpoint Policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param parameters: Parameters supplied to the create or update service endpoint policy + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ServiceEndpointPolicy or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + lro_delay = kwargs.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, + service_endpoint_policy_name=service_endpoint_policy_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('ServiceEndpointPolicy', 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_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': 'azure-async-operation'}, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.ServiceEndpointPolicy": + """Updates tags of a service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param parameters: Parameters supplied to update service endpoint policy tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ServiceEndpointPolicyListResult"]: + """Gets all the service endpoint policies 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 ServiceEndpointPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ServiceEndpointPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/ServiceEndpointPolicies'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ServiceEndpointPolicyListResult"]: + """Gets all service endpoint Policies in a 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 ServiceEndpointPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ServiceEndpointPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/serviceEndpointPolicies'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policy_definitions_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policy_definitions_operations.py new file mode 100644 index 000000000000..f12c1882bc47 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_endpoint_policy_definitions_operations.py @@ -0,0 +1,435 @@ +# 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 ServiceEndpointPolicyDefinitionsOperations: + """ServiceEndpointPolicyDefinitionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + service_endpoint_policy_definition_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-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + service_endpoint_policy_definition_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified ServiceEndpoint policy definitions. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the Service Endpoint Policy. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition. + :type service_endpoint_policy_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 + 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, + service_endpoint_policy_name=service_endpoint_policy_name, + service_endpoint_policy_definition_name=service_endpoint_policy_definition_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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_policy_definition_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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + service_endpoint_policy_definition_name: str, + **kwargs + ) -> "_models.ServiceEndpointPolicyDefinition": + """Get the specified service endpoint policy definitions from service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy name. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition name. + :type service_endpoint_policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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('ServiceEndpointPolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + service_endpoint_policy_definition_name: str, + service_endpoint_policy_definitions: "_models.ServiceEndpointPolicyDefinition", + **kwargs + ) -> "_models.ServiceEndpointPolicyDefinition": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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(service_endpoint_policy_definitions, 'ServiceEndpointPolicyDefinition') + 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('ServiceEndpointPolicyDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ServiceEndpointPolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + service_endpoint_policy_definition_name: str, + service_endpoint_policy_definitions: "_models.ServiceEndpointPolicyDefinition", + **kwargs + ) -> AsyncLROPoller["_models.ServiceEndpointPolicyDefinition"]: + """Creates or updates a service endpoint policy definition in the specified service endpoint + policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition name. + :type service_endpoint_policy_definition_name: str + :param service_endpoint_policy_definitions: Parameters supplied to the create or update service + endpoint policy operation. + :type service_endpoint_policy_definitions: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ServiceEndpointPolicyDefinition or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + lro_delay = kwargs.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, + service_endpoint_policy_name=service_endpoint_policy_name, + service_endpoint_policy_definition_name=service_endpoint_policy_definition_name, + service_endpoint_policy_definitions=service_endpoint_policy_definitions, + 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('ServiceEndpointPolicyDefinition', 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_policy_definition_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': 'azure-async-operation'}, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + service_endpoint_policy_name: str, + **kwargs + ) -> AsyncIterable["_models.ServiceEndpointPolicyDefinitionListResult"]: + """Gets all service endpoint policy definitions in a service end point policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy name. + :type service_endpoint_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ServiceEndpointPolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ServiceEndpointPolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_tags_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_tags_operations.py new file mode 100644 index 000000000000..29025ada9165 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_service_tags_operations.py @@ -0,0 +1,97 @@ +# 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 ServiceTagsOperations: + """ServiceTagsOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> "_models.ServiceTagsListResult": + """Gets a list of service tag information resources. + + :param location: The location that will be used as a reference for version (not as a filter + based on location, you will get the list of service tags with prefix details across all regions + but limited to the cloud that your subscription belongs to). + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceTagsListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceTagsListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceTagsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.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['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceTagsListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/serviceTags'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_subnets_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_subnets_operations.py new file mode 100644 index 000000000000..81485b3937d0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_subnets_operations.py @@ -0,0 +1,687 @@ +# 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 SubnetsOperations: + """SubnetsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_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, + virtual_network_name=virtual_network_name, + subnet_name=subnet_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.Subnet": + """Gets the specified subnet by virtual network and resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Subnet, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Subnet + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('Subnet', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + subnet_parameters: "_models.Subnet", + **kwargs + ) -> "_models.Subnet": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(subnet_parameters, 'Subnet') + 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('Subnet', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('Subnet', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + subnet_parameters: "_models.Subnet", + **kwargs + ) -> AsyncLROPoller["_models.Subnet"]: + """Creates or updates a subnet in the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param subnet_parameters: Parameters supplied to the create or update subnet operation. + :type subnet_parameters: ~azure.mgmt.network.v2020_08_01.models.Subnet + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 Subnet or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.Subnet] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + subnet_parameters=subnet_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('Subnet', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + async def _prepare_network_policies_initial( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + prepare_network_policies_request_parameters: "_models.PrepareNetworkPoliciesRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._prepare_network_policies_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(prepare_network_policies_request_parameters, 'PrepareNetworkPoliciesRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _prepare_network_policies_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/PrepareNetworkPolicies'} # type: ignore + + async def begin_prepare_network_policies( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + prepare_network_policies_request_parameters: "_models.PrepareNetworkPoliciesRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Prepares a subnet by applying network intent policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param prepare_network_policies_request_parameters: Parameters supplied to prepare subnet by + applying network intent policies. + :type prepare_network_policies_request_parameters: ~azure.mgmt.network.v2020_08_01.models.PrepareNetworkPoliciesRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._prepare_network_policies_initial( + resource_group_name=resource_group_name, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + prepare_network_policies_request_parameters=prepare_network_policies_request_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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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_prepare_network_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/PrepareNetworkPolicies'} # type: ignore + + async def _unprepare_network_policies_initial( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + unprepare_network_policies_request_parameters: "_models.UnprepareNetworkPoliciesRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._unprepare_network_policies_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(unprepare_network_policies_request_parameters, 'UnprepareNetworkPoliciesRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _unprepare_network_policies_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/UnprepareNetworkPolicies'} # type: ignore + + async def begin_unprepare_network_policies( + self, + resource_group_name: str, + virtual_network_name: str, + subnet_name: str, + unprepare_network_policies_request_parameters: "_models.UnprepareNetworkPoliciesRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Unprepares a subnet by removing network intent policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param unprepare_network_policies_request_parameters: Parameters supplied to unprepare subnet + to remove network intent policies. + :type unprepare_network_policies_request_parameters: ~azure.mgmt.network.v2020_08_01.models.UnprepareNetworkPoliciesRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._unprepare_network_policies_initial( + resource_group_name=resource_group_name, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + unprepare_network_policies_request_parameters=unprepare_network_policies_request_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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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_unprepare_network_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/UnprepareNetworkPolicies'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_network_name: str, + **kwargs + ) -> AsyncIterable["_models.SubnetListResult"]: + """Gets all subnets in a virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SubnetListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.SubnetListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubnetListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SubnetListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_usages_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_usages_operations.py new file mode 100644 index 000000000000..c5f0a4709a45 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_usages_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 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 UsagesOperations: + """UsagesOperations 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.network.v2020_08_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, + location: str, + **kwargs + ) -> AsyncIterable["_models.UsagesListResult"]: + """List network usages for a subscription. + + :param location: The location where resource usage is queried. + :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 UsagesListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.UsagesListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsagesListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str', 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('UsagesListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/locations/{location}/usages'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_sites_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_sites_operations.py new file mode 100644 index 000000000000..92af8b48b1f0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_sites_operations.py @@ -0,0 +1,431 @@ +# 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 VirtualApplianceSitesOperations: + """VirtualApplianceSitesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + site_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-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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.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/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + site_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified site from a Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_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, + network_virtual_appliance_name=network_virtual_appliance_name, + site_name=site_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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'siteName': self._serialize.url("site_name", site_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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + site_name: str, + **kwargs + ) -> "_models.VirtualApplianceSite": + """Gets the specified Virtual Appliance Site. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualApplianceSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualApplianceSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + site_name: str, + parameters: "_models.VirtualApplianceSite", + **kwargs + ) -> "_models.VirtualApplianceSite": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualApplianceSite') + 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('VirtualApplianceSite', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualApplianceSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + site_name: str, + parameters: "_models.VirtualApplianceSite", + **kwargs + ) -> AsyncLROPoller["_models.VirtualApplianceSite"]: + """Creates or updates the specified Network Virtual Appliance Site. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance Site + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualApplianceSite or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_name, + site_name=site_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('VirtualApplianceSite', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'siteName': self._serialize.url("site_name", site_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def list( + self, + resource_group_name: str, + network_virtual_appliance_name: str, + **kwargs + ) -> AsyncIterable["_models.NetworkVirtualApplianceSiteListResult"]: + """Lists all Network Virtual Appliance Sites in a Network Virtual Appliance resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkVirtualApplianceSiteListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSiteListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSiteListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkVirtualApplianceSiteListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_skus_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_skus_operations.py new file mode 100644 index 000000000000..e6a9477a9af9 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_appliance_skus_operations.py @@ -0,0 +1,162 @@ +# 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 VirtualApplianceSkusOperations: + """VirtualApplianceSkusOperations 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.network.v2020_08_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.NetworkVirtualApplianceSkuListResult"]: + """List all SKUs available for a virtual appliance. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkVirtualApplianceSkuListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSkuListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSkuListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceSkuListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/networkVirtualApplianceSkus'} # type: ignore + + async def get( + self, + sku_name: str, + **kwargs + ) -> "_models.NetworkVirtualApplianceSku": + """Retrieves a single available sku for network virtual appliance. + + :param sku_name: Name of the Sku. + :type sku_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualApplianceSku, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSku + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSku"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'skuName': self._serialize.url("sku_name", sku_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('NetworkVirtualApplianceSku', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus/{skuName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connection_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connection_operations.py new file mode 100644 index 000000000000..de9174dc9b42 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connection_operations.py @@ -0,0 +1,356 @@ +# 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, Union +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.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 VirtualHubBgpConnectionOperations: + """VirtualHubBgpConnectionOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + **kwargs + ) -> "_models.BgpConnection": + """Retrieves the details of a Virtual Hub Bgp Connection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BgpConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BgpConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('BgpConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + parameters: "_models.BgpConnection", + **kwargs + ) -> "_models.BgpConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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, 'BgpConnection') + 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('BgpConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BgpConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + parameters: "_models.BgpConnection", + **kwargs + ) -> AsyncLROPoller["_models.BgpConnection"]: + """Creates a VirtualHubBgpConnection resource if it doesn't exist else updates the existing + VirtualHubBgpConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :param parameters: Parameters of Bgp connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BgpConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BgpConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.BgpConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + connection_name=connection_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('BgpConnection', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VirtualHubBgpConnection. + + :param resource_group_name: The resource group name of the VirtualHubBgpConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type 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 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, + virtual_hub_name=virtual_hub_name, + connection_name=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): + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connections_operations.py new file mode 100644 index 000000000000..bb394f98851f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_bgp_connections_operations.py @@ -0,0 +1,364 @@ +# 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 VirtualHubBgpConnectionsOperations: + """VirtualHubBgpConnectionsOperations 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.network.v2020_08_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, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVirtualHubBgpConnectionResults"]: + """Retrieves the details of all VirtualHubBgpConnections. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubBgpConnectionResults or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubBgpConnectionResults] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubBgpConnectionResults"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubBgpConnectionResults', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections'} # type: ignore + + async def _list_learned_routes_initial( + self, + resource_group_name: str, + hub_name: str, + connection_name: str, + **kwargs + ) -> Optional["_models.PeerRouteList"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PeerRouteList"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_learned_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PeerRouteList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_learned_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/learnedRoutes'} # type: ignore + + async def begin_list_learned_routes( + self, + resource_group_name: str, + hub_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller["_models.PeerRouteList"]: + """Retrieves a list of routes the virtual hub bgp connection has learned. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param hub_name: The name of the virtual hub. + :type hub_name: str + :param connection_name: The name of the virtual hub bgp connection. + :type 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 PeerRouteList or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PeerRouteList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerRouteList"] + lro_delay = kwargs.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_learned_routes_initial( + resource_group_name=resource_group_name, + hub_name=hub_name, + connection_name=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('PeerRouteList', 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'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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_list_learned_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/learnedRoutes'} # type: ignore + + async def _list_advertised_routes_initial( + self, + resource_group_name: str, + hub_name: str, + connection_name: str, + **kwargs + ) -> Optional["_models.PeerRouteList"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PeerRouteList"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_advertised_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PeerRouteList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_advertised_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/advertisedRoutes'} # type: ignore + + async def begin_list_advertised_routes( + self, + resource_group_name: str, + hub_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller["_models.PeerRouteList"]: + """Retrieves a list of routes the virtual hub bgp connection is advertising to the specified peer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param hub_name: The name of the virtual hub. + :type hub_name: str + :param connection_name: The name of the virtual hub bgp connection. + :type 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 PeerRouteList or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.PeerRouteList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerRouteList"] + lro_delay = kwargs.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_advertised_routes_initial( + resource_group_name=resource_group_name, + hub_name=hub_name, + connection_name=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('PeerRouteList', 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'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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_list_advertised_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/advertisedRoutes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_ip_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_ip_configuration_operations.py new file mode 100644 index 000000000000..75e575601e10 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_ip_configuration_operations.py @@ -0,0 +1,431 @@ +# 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 VirtualHubIpConfigurationOperations: + """VirtualHubIpConfigurationOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + virtual_hub_name: str, + ip_config_name: str, + **kwargs + ) -> "_models.HubIpConfiguration": + """Retrieves the details of a Virtual Hub Ip configuration. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubIpConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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('HubIpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + ip_config_name: str, + parameters: "_models.HubIpConfiguration", + **kwargs + ) -> "_models.HubIpConfiguration": + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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, 'HubIpConfiguration') + 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('HubIpConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubIpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + ip_config_name: str, + parameters: "_models.HubIpConfiguration", + **kwargs + ) -> AsyncLROPoller["_models.HubIpConfiguration"]: + """Creates a VirtualHubIpConfiguration resource if it doesn't exist else updates the existing + VirtualHubIpConfiguration. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_name: str + :param parameters: Hub Ip Configuration parameters. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubIpConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + ip_config_name=ip_config_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('HubIpConfiguration', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + ip_config_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + ip_config_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VirtualHubIpConfiguration. + + :param resource_group_name: The resource group name of the VirtualHubBgpConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_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, + virtual_hub_name=virtual_hub_name, + ip_config_name=ip_config_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVirtualHubIpConfigurationResults"]: + """Retrieves the details of all VirtualHubIpConfigurations. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubIpConfigurationResults or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubIpConfigurationResults] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubIpConfigurationResults"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubIpConfigurationResults', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_route_table_v2_s_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_route_table_v2_s_operations.py new file mode 100644 index 000000000000..19940e14ceb2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hub_route_table_v2_s_operations.py @@ -0,0 +1,435 @@ +# 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 VirtualHubRouteTableV2SOperations: + """VirtualHubRouteTableV2SOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + **kwargs + ) -> "_models.VirtualHubRouteTableV2": + """Retrieves the details of a VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHubRouteTableV2. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHubRouteTableV2, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + virtual_hub_route_table_v2_parameters: "_models.VirtualHubRouteTableV2", + **kwargs + ) -> "_models.VirtualHubRouteTableV2": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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(virtual_hub_route_table_v2_parameters, 'VirtualHubRouteTableV2') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + virtual_hub_route_table_v2_parameters: "_models.VirtualHubRouteTableV2", + **kwargs + ) -> AsyncLROPoller["_models.VirtualHubRouteTableV2"]: + """Creates a VirtualHubRouteTableV2 resource if it doesn't exist else updates the existing + VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_name: str + :param virtual_hub_route_table_v2_parameters: Parameters supplied to create or update + VirtualHubRouteTableV2. + :type virtual_hub_route_table_v2_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualHubRouteTableV2 or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_name, + virtual_hub_route_table_v2_parameters=virtual_hub_route_table_v2_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('VirtualHubRouteTableV2', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Error, 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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + route_table_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHubRouteTableV2. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVirtualHubRouteTableV2SResult"]: + """Retrieves the details of all VirtualHubRouteTableV2s. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubRouteTableV2SResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubRouteTableV2SResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubRouteTableV2SResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubRouteTableV2SResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hubs_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hubs_operations.py new file mode 100644 index 000000000000..fcb16bec7f72 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_hubs_operations.py @@ -0,0 +1,662 @@ +# 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 VirtualHubsOperations: + """VirtualHubsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> "_models.VirtualHub": + """Retrieves the details of a VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHub, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + virtual_hub_parameters: "_models.VirtualHub", + **kwargs + ) -> "_models.VirtualHub": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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(virtual_hub_parameters, 'VirtualHub') + 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('VirtualHub', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_hub_name: str, + virtual_hub_parameters: "_models.VirtualHub", + **kwargs + ) -> AsyncLROPoller["_models.VirtualHub"]: + """Creates a VirtualHub resource if it doesn't exist else updates the existing VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param virtual_hub_parameters: Parameters supplied to create or update VirtualHub. + :type virtual_hub_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualHub or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualHub] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + virtual_hub_parameters=virtual_hub_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('VirtualHub', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + virtual_hub_name: str, + virtual_hub_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VirtualHub": + """Updates VirtualHub tags. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param virtual_hub_parameters: Parameters supplied to update VirtualHub tags. + :type virtual_hub_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHub, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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(virtual_hub_parameters, 'TagsObject') + 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('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_hub_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_hub_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_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, + virtual_hub_name=virtual_hub_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVirtualHubsResult"]: + """Lists all the VirtualHubs in a resource group. + + :param resource_group_name: The resource group name of the VirtualHub. + :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 ListVirtualHubsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVirtualHubsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/virtualHubs'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListVirtualHubsResult"]: + """Lists all the VirtualHubs 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 ListVirtualHubsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVirtualHubsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/virtualHubs'} # type: ignore + + async def _get_effective_virtual_hub_routes_initial( + self, + resource_group_name: str, + virtual_hub_name: str, + effective_routes_parameters: Optional["_models.EffectiveRoutesParameters"] = 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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_effective_virtual_hub_routes_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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] + if effective_routes_parameters is not None: + body_content = self._serialize.body(effective_routes_parameters, 'EffectiveRoutesParameters') + else: + body_content = None + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _get_effective_virtual_hub_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/effectiveRoutes'} # type: ignore + + async def begin_get_effective_virtual_hub_routes( + self, + resource_group_name: str, + virtual_hub_name: str, + effective_routes_parameters: Optional["_models.EffectiveRoutesParameters"] = None, + **kwargs + ) -> AsyncLROPoller[None]: + """Gets the effective routes configured for the Virtual Hub resource or the specified resource . + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param effective_routes_parameters: Parameters supplied to get the effective routes for a + specific resource. + :type effective_routes_parameters: ~azure.mgmt.network.v2020_08_01.models.EffectiveRoutesParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._get_effective_virtual_hub_routes_initial( + resource_group_name=resource_group_name, + virtual_hub_name=virtual_hub_name, + effective_routes_parameters=effective_routes_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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_get_effective_virtual_hub_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/effectiveRoutes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateway_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateway_connections_operations.py new file mode 100644 index 000000000000..f2463d583829 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateway_connections_operations.py @@ -0,0 +1,1241 @@ +# 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 VirtualNetworkGatewayConnectionsOperations: + """VirtualNetworkGatewayConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.VirtualNetworkGatewayConnection", + **kwargs + ) -> "_models.VirtualNetworkGatewayConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VirtualNetworkGatewayConnection') + 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('VirtualNetworkGatewayConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.VirtualNetworkGatewayConnection", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkGatewayConnection"]: + """Creates or updates a virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the create or update virtual network gateway + connection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGatewayConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + lro_delay = kwargs.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, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('VirtualNetworkGatewayConnection', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + **kwargs + ) -> "_models.VirtualNetworkGatewayConnection": + """Gets the specified virtual network gateway connection by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkGatewayConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_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-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified virtual network Gateway connection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_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 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, + virtual_network_gateway_connection_name=virtual_network_gateway_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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.VirtualNetworkGatewayConnection"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGatewayConnection"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'TagsObject') + 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('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkGatewayConnection"]: + """Updates a virtual network gateway connection tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to update virtual network gateway connection tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGatewayConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('VirtualNetworkGatewayConnection', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + async def _set_shared_key_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.ConnectionSharedKey", + **kwargs + ) -> "_models.ConnectionSharedKey": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'ConnectionSharedKey') + 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('ConnectionSharedKey', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ConnectionSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + async def begin_set_shared_key( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.ConnectionSharedKey", + **kwargs + ) -> AsyncLROPoller["_models.ConnectionSharedKey"]: + """The Put VirtualNetworkGatewayConnectionSharedKey operation sets the virtual network gateway + connection shared key for passed virtual network gateway connection in the specified resource + group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection name. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the Begin Set Virtual Network Gateway connection + Shared key operation throughNetwork resource provider. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectionSharedKey or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + lro_delay = kwargs.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._set_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('ConnectionSharedKey', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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_set_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + async def get_shared_key( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + **kwargs + ) -> "_models.ConnectionSharedKey": + """The Get VirtualNetworkGatewayConnectionSharedKey operation retrieves information about the + specified virtual network gateway connection shared key through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection shared + key name. + :type virtual_network_gateway_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionSharedKey, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_shared_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkGatewayConnectionListResult"]: + """The List VirtualNetworkGatewayConnections operation retrieves all the virtual network gateways + connections created. + + :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 VirtualNetworkGatewayConnectionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/connections'} # type: ignore + + async def _reset_shared_key_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.ConnectionResetSharedKey", + **kwargs + ) -> Optional["_models.ConnectionResetSharedKey"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ConnectionResetSharedKey"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._reset_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'ConnectionResetSharedKey') + 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('ConnectionResetSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey/reset'} # type: ignore + + async def begin_reset_shared_key( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.ConnectionResetSharedKey", + **kwargs + ) -> AsyncLROPoller["_models.ConnectionResetSharedKey"]: + """The VirtualNetworkGatewayConnectionResetSharedKey operation resets the virtual network gateway + connection shared key for passed virtual network gateway connection in the specified resource + group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection reset + shared key Name. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the begin reset virtual network gateway connection + shared key operation through network resource provider. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionResetSharedKey + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectionResetSharedKey or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionResetSharedKey] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionResetSharedKey"] + lro_delay = kwargs.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._reset_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('ConnectionResetSharedKey', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_reset_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey/reset'} # type: ignore + + async def _start_packet_capture_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: Optional["_models.VpnPacketCaptureStartParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnPacketCaptureStartParameters') + else: + body_content = None + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/startPacketCapture'} # type: ignore + + async def begin_start_packet_capture( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: Optional["_models.VpnPacketCaptureStartParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Starts packet capture on virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to start packet + capture on gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/startPacketCapture'} # type: ignore + + async def _stop_packet_capture_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.VpnPacketCaptureStopParameters", + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VpnPacketCaptureStopParameters') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/stopPacketCapture'} # type: ignore + + async def begin_stop_packet_capture( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.VpnPacketCaptureStopParameters", + **kwargs + ) -> AsyncLROPoller[str]: + """Stops packet capture on virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + Connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to stop packet + capture on gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/stopPacketCapture'} # type: ignore + + async def _get_ike_sas_initial( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_ike_sas_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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.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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_ike_sas_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/getikesas'} # type: ignore + + async def begin_get_ike_sas( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + **kwargs + ) -> AsyncLROPoller[str]: + """Lists IKE Security Associations for the virtual network gateway connection in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + Connection. + :type virtual_network_gateway_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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._get_ike_sas_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_get_ike_sas.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/getikesas'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateways_operations.py new file mode 100644 index 000000000000..57bc6dce9602 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_gateways_operations.py @@ -0,0 +1,2440 @@ +# 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 VirtualNetworkGatewaysOperations: + """VirtualNetworkGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VirtualNetworkGateway", + **kwargs + ) -> "_models.VirtualNetworkGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VirtualNetworkGateway') + 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('VirtualNetworkGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VirtualNetworkGateway", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkGateway"]: + """Creates or updates a virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to create or update virtual network gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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, + virtual_network_gateway_name=virtual_network_gateway_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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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': 'azure-async-operation'}, 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.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> "_models.VirtualNetworkGateway": + """Gets the specified virtual network gateway by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_network_gateway_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-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified virtual network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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, + virtual_network_gateway_name=virtual_network_gateway_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.VirtualNetworkGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'TagsObject') + 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('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkGateway"]: + """Updates a virtual network gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to update virtual network gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkGatewayListResult"]: + """Gets all virtual network gateways by 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 VirtualNetworkGatewayListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualNetworkGateways'} # type: ignore + + def list_connections( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkGatewayListConnectionsResult"]: + """Gets all the connections in a virtual network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkGatewayListConnectionsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayListConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayListConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayListConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/connections'} # type: ignore + + async def _reset_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + gateway_vip: Optional[str] = None, + **kwargs + ) -> Optional["_models.VirtualNetworkGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if gateway_vip is not None: + query_parameters['gatewayVip'] = self._serialize.query("gateway_vip", gateway_vip, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/reset'} # type: ignore + + async def begin_reset( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + gateway_vip: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkGateway"]: + """Resets the primary of the virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param gateway_vip: Virtual network gateway vip address supplied to the begin reset of the + active-active feature enabled gateway. + :type gateway_vip: 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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + gateway_vip=gateway_vip, + 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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/reset'} # type: ignore + + async def _reset_vpn_client_shared_key_initial( + self, + resource_group_name: str, + virtual_network_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_vpn_client_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _reset_vpn_client_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/resetvpnclientsharedkey'} # type: ignore + + async def begin_reset_vpn_client_shared_key( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Resets the VPN client shared key of the virtual network gateway in the specified resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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._reset_vpn_client_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_reset_vpn_client_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/resetvpnclientsharedkey'} # type: ignore + + async def _generatevpnclientpackage_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnClientParameters", + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generatevpnclientpackage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnClientParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generatevpnclientpackage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'} # type: ignore + + async def begin_generatevpnclientpackage( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnClientParameters", + **kwargs + ) -> AsyncLROPoller[str]: + """Generates VPN client package for P2S client of the virtual network gateway in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to the generate virtual network gateway VPN client + package operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnClientParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._generatevpnclientpackage_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_generatevpnclientpackage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'} # type: ignore + + async def _generate_vpn_profile_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnClientParameters", + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generate_vpn_profile_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnClientParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generate_vpn_profile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnprofile'} # type: ignore + + async def begin_generate_vpn_profile( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnClientParameters", + **kwargs + ) -> AsyncLROPoller[str]: + """Generates VPN profile for P2S client of the virtual network gateway in the specified resource + group. Used for IKEV2 and radius based authentication. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to the generate virtual network gateway VPN client + package operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnClientParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._generate_vpn_profile_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_generate_vpn_profile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnprofile'} # type: ignore + + async def _get_vpn_profile_package_url_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpn_profile_package_url_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpn_profile_package_url_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnprofilepackageurl'} # type: ignore + + async def begin_get_vpn_profile_package_url( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller[str]: + """Gets pre-generated VPN profile for P2S client of the virtual network gateway in the specified + resource group. The profile needs to be generated first using generateVpnProfile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._get_vpn_profile_package_url_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpn_profile_package_url.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnprofilepackageurl'} # type: ignore + + async def _get_bgp_peer_status_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + peer: Optional[str] = None, + **kwargs + ) -> Optional["_models.BgpPeerStatusListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BgpPeerStatusListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_bgp_peer_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if peer is not None: + query_parameters['peer'] = self._serialize.query("peer", peer, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('BgpPeerStatusListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_bgp_peer_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getBgpPeerStatus'} # type: ignore + + async def begin_get_bgp_peer_status( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + peer: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller["_models.BgpPeerStatusListResult"]: + """The GetBgpPeerStatus operation retrieves the status of all BGP peers. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param peer: The IP address of the peer to retrieve the status of. + :type peer: 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 BgpPeerStatusListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.BgpPeerStatusListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpPeerStatusListResult"] + lro_delay = kwargs.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._get_bgp_peer_status_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + peer=peer, + 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('BgpPeerStatusListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_bgp_peer_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getBgpPeerStatus'} # type: ignore + + async def supported_vpn_devices( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> str: + """Gets a xml format representation for supported vpn devices. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self.supported_vpn_devices.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + supported_vpn_devices.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/supportedvpndevices'} # type: ignore + + async def _get_learned_routes_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> Optional["_models.GatewayRouteListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GatewayRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_learned_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GatewayRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_learned_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getLearnedRoutes'} # type: ignore + + async def begin_get_learned_routes( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.GatewayRouteListResult"]: + """This operation retrieves a list of routes the virtual network gateway has learned, including + routes learned from BGP peers. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 GatewayRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.GatewayRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GatewayRouteListResult"] + lro_delay = kwargs.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._get_learned_routes_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('GatewayRouteListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_learned_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getLearnedRoutes'} # type: ignore + + async def _get_advertised_routes_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + peer: str, + **kwargs + ) -> Optional["_models.GatewayRouteListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GatewayRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_advertised_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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['peer'] = self._serialize.query("peer", peer, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GatewayRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_advertised_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getAdvertisedRoutes'} # type: ignore + + async def begin_get_advertised_routes( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + peer: str, + **kwargs + ) -> AsyncLROPoller["_models.GatewayRouteListResult"]: + """This operation retrieves a list of routes the virtual network gateway is advertising to the + specified peer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param peer: The IP address of the peer. + :type peer: 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 GatewayRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.GatewayRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GatewayRouteListResult"] + lro_delay = kwargs.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._get_advertised_routes_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + peer=peer, + 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('GatewayRouteListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_advertised_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getAdvertisedRoutes'} # type: ignore + + async def _set_vpnclient_ipsec_parameters_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + vpnclient_ipsec_params: "_models.VpnClientIPsecParameters", + **kwargs + ) -> Optional["_models.VpnClientIPsecParameters"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnClientIPsecParameters"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_vpnclient_ipsec_parameters_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(vpnclient_ipsec_params, 'VpnClientIPsecParameters') + 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('VpnClientIPsecParameters', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_vpnclient_ipsec_parameters_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/setvpnclientipsecparameters'} # type: ignore + + async def begin_set_vpnclient_ipsec_parameters( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + vpnclient_ipsec_params: "_models.VpnClientIPsecParameters", + **kwargs + ) -> AsyncLROPoller["_models.VpnClientIPsecParameters"]: + """The Set VpnclientIpsecParameters operation sets the vpnclient ipsec policy for P2S client of + virtual network gateway in the specified resource group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param vpnclient_ipsec_params: Parameters supplied to the Begin Set vpnclient ipsec parameters + of Virtual Network Gateway P2S client operation through Network resource provider. + :type vpnclient_ipsec_params: ~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnClientIPsecParameters or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + lro_delay = kwargs.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._set_vpnclient_ipsec_parameters_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + vpnclient_ipsec_params=vpnclient_ipsec_params, + 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('VpnClientIPsecParameters', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_set_vpnclient_ipsec_parameters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/setvpnclientipsecparameters'} # type: ignore + + async def _get_vpnclient_ipsec_parameters_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> "_models.VpnClientIPsecParameters": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpnclient_ipsec_parameters_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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('VpnClientIPsecParameters', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpnclient_ipsec_parameters_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnclientipsecparameters'} # type: ignore + + async def begin_get_vpnclient_ipsec_parameters( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.VpnClientIPsecParameters"]: + """The Get VpnclientIpsecParameters operation retrieves information about the vpnclient ipsec + policy for P2S client of virtual network gateway in the specified resource group through + Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The virtual network gateway name. + :type virtual_network_gateway_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 VpnClientIPsecParameters or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + lro_delay = kwargs.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._get_vpnclient_ipsec_parameters_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VpnClientIPsecParameters', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpnclient_ipsec_parameters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnclientipsecparameters'} # type: ignore + + async def vpn_device_configuration_script( + self, + resource_group_name: str, + virtual_network_gateway_connection_name: str, + parameters: "_models.VpnDeviceScriptParameters", + **kwargs + ) -> str: + """Gets a xml format representation for vpn device configuration script. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection for which the configuration script is generated. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the generate vpn device script operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnDeviceScriptParameters + :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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.vpn_device_configuration_script.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VpnDeviceScriptParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + vpn_device_configuration_script.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/vpndeviceconfigurationscript'} # type: ignore + + async def _start_packet_capture_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: Optional["_models.VpnPacketCaptureStartParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnPacketCaptureStartParameters') + else: + body_content = None + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/startPacketCapture'} # type: ignore + + async def begin_start_packet_capture( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: Optional["_models.VpnPacketCaptureStartParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Starts packet capture on virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to start packet + capture on gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/startPacketCapture'} # type: ignore + + async def _stop_packet_capture_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnPacketCaptureStopParameters", + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnPacketCaptureStopParameters') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/stopPacketCapture'} # type: ignore + + async def begin_stop_packet_capture( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + parameters: "_models.VpnPacketCaptureStopParameters", + **kwargs + ) -> AsyncLROPoller[str]: + """Stops packet capture on virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to stop packet + capture on gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/stopPacketCapture'} # type: ignore + + async def _get_vpnclient_connection_health_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> Optional["_models.VpnClientConnectionHealthDetailListResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnClientConnectionHealthDetailListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpnclient_connection_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnClientConnectionHealthDetailListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpnclient_connection_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getVpnClientConnectionHealth'} # type: ignore + + async def begin_get_vpnclient_connection_health( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.VpnClientConnectionHealthDetailListResult"]: + """Get VPN client connection health detail per P2S client connection of the virtual network + gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 VpnClientConnectionHealthDetailListResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealthDetailListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientConnectionHealthDetailListResult"] + lro_delay = kwargs.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._get_vpnclient_connection_health_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VpnClientConnectionHealthDetailListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpnclient_connection_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getVpnClientConnectionHealth'} # type: ignore + + async def _disconnect_virtual_network_gateway_vpn_connections_initial( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + request: "_models.P2SVpnConnectionRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._disconnect_virtual_network_gateway_vpn_connections_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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(request, 'P2SVpnConnectionRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _disconnect_virtual_network_gateway_vpn_connections_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/disconnectVirtualNetworkGatewayVpnConnections'} # type: ignore + + async def begin_disconnect_virtual_network_gateway_vpn_connections( + self, + resource_group_name: str, + virtual_network_gateway_name: str, + request: "_models.P2SVpnConnectionRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Disconnect vpn connections of virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param request: The parameters are supplied to disconnect vpn connections. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._disconnect_virtual_network_gateway_vpn_connections_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_disconnect_virtual_network_gateway_vpn_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/disconnectVirtualNetworkGatewayVpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_peerings_operations.py new file mode 100644 index 000000000000..c66a31047413 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_peerings_operations.py @@ -0,0 +1,431 @@ +# 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 VirtualNetworkPeeringsOperations: + """VirtualNetworkPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_network_name: str, + virtual_network_peering_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_network_name: str, + virtual_network_peering_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified virtual network peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the virtual network peering. + :type virtual_network_peering_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, + virtual_network_name=virtual_network_name, + virtual_network_peering_name=virtual_network_peering_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_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.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_network_name: str, + virtual_network_peering_name: str, + **kwargs + ) -> "_models.VirtualNetworkPeering": + """Gets the specified virtual network peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the virtual network peering. + :type virtual_network_peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetworkPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_network_name: str, + virtual_network_peering_name: str, + virtual_network_peering_parameters: "_models.VirtualNetworkPeering", + **kwargs + ) -> "_models.VirtualNetworkPeering": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(virtual_network_peering_parameters, 'VirtualNetworkPeering') + 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('VirtualNetworkPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_network_name: str, + virtual_network_peering_name: str, + virtual_network_peering_parameters: "_models.VirtualNetworkPeering", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkPeering"]: + """Creates or updates a peering in the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the peering. + :type virtual_network_peering_name: str + :param virtual_network_peering_parameters: Parameters supplied to the create or update virtual + network peering operation. + :type virtual_network_peering_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkPeering or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_name, + virtual_network_peering_name=virtual_network_peering_name, + virtual_network_peering_parameters=virtual_network_peering_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('VirtualNetworkPeering', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_network_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkPeeringListResult"]: + """Gets all virtual network peerings in a virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkPeeringListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_taps_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_taps_operations.py new file mode 100644 index 000000000000..9c2d512bd174 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_network_taps_operations.py @@ -0,0 +1,540 @@ +# 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 VirtualNetworkTapsOperations: + """VirtualNetworkTapsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + tap_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-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + tap_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified virtual network tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the virtual network tap. + :type tap_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, + tap_name=tap_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'), + 'tapName': self._serialize.url("tap_name", tap_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.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + tap_name: str, + **kwargs + ) -> "_models.VirtualNetworkTap": + """Gets information about the specified virtual network tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of virtual network tap. + :type tap_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkTap, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + tap_name: str, + parameters: "_models.VirtualNetworkTap", + **kwargs + ) -> "_models.VirtualNetworkTap": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualNetworkTap') + 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('VirtualNetworkTap', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + tap_name: str, + parameters: "_models.VirtualNetworkTap", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetworkTap"]: + """Creates or updates a Virtual Network Tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the virtual network tap. + :type tap_name: str + :param parameters: Parameters supplied to the create or update virtual network tap operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkTap or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + lro_delay = kwargs.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, + tap_name=tap_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('VirtualNetworkTap', 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'), + 'tapName': self._serialize.url("tap_name", tap_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': 'azure-async-operation'}, 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.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + tap_name: str, + tap_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VirtualNetworkTap": + """Updates an VirtualNetworkTap tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the tap. + :type tap_name: str + :param tap_parameters: Parameters supplied to update VirtualNetworkTap tags. + :type tap_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkTap, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(tap_parameters, 'TagsObject') + 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('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkTapListResult"]: + """Gets all the VirtualNetworkTaps 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 VirtualNetworkTapListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTapListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTapListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('VirtualNetworkTapListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/virtualNetworkTaps'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkTapListResult"]: + """Gets all the VirtualNetworkTaps in a subscription. + + :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 VirtualNetworkTapListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTapListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTapListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualNetworkTapListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/virtualNetworkTaps'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_networks_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_networks_operations.py new file mode 100644 index 000000000000..6a3a86bf2f56 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_networks_operations.py @@ -0,0 +1,681 @@ +# 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 VirtualNetworksOperations: + """VirtualNetworksOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_network_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_network_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_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, + virtual_network_name=virtual_network_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_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.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_network_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.VirtualNetwork": + """Gets the specified virtual network by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_network_name: str, + parameters: "_models.VirtualNetwork", + **kwargs + ) -> "_models.VirtualNetwork": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualNetwork') + 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('VirtualNetwork', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_network_name: str, + parameters: "_models.VirtualNetwork", + **kwargs + ) -> AsyncLROPoller["_models.VirtualNetwork"]: + """Creates or updates a virtual network in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param parameters: Parameters supplied to the create or update virtual network operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetwork or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetwork] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_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('VirtualNetwork', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + virtual_network_name: str, + parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VirtualNetwork": + """Updates a virtual network tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param parameters: Parameters supplied to update virtual network tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkListResult"]: + """Gets all virtual networks 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 VirtualNetworkListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('VirtualNetworkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/virtualNetworks'} # type: ignore + + def list( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkListResult"]: + """Gets all virtual networks in a 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 VirtualNetworkListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/virtualNetworks'} # type: ignore + + async def check_ip_address_availability( + self, + resource_group_name: str, + virtual_network_name: str, + ip_address: str, + **kwargs + ) -> "_models.IPAddressAvailabilityResult": + """Checks whether a private IP address is available for use. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param ip_address: The private IP address to be verified. + :type ip_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IPAddressAvailabilityResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IPAddressAvailabilityResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IPAddressAvailabilityResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.check_ip_address_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['ipAddress'] = self._serialize.query("ip_address", ip_address, '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('IPAddressAvailabilityResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_ip_address_availability.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/CheckIPAddressAvailability'} # type: ignore + + def list_usage( + self, + resource_group_name: str, + virtual_network_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualNetworkListUsageResult"]: + """Lists usage stats. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkListUsageResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListUsageResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListUsageResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usage.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkListUsageResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_usage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/usages'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_router_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_router_peerings_operations.py new file mode 100644 index 000000000000..8823e2c910be --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_router_peerings_operations.py @@ -0,0 +1,435 @@ +# 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 VirtualRouterPeeringsOperations: + """VirtualRouterPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_router_name: str, + peering_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-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_router_name: str, + peering_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified peering from a Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the peering. + :type peering_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, + virtual_router_name=virtual_router_name, + peering_name=peering_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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_router_name: str, + peering_name: str, + **kwargs + ) -> "_models.VirtualRouterPeering": + """Gets the specified Virtual Router Peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the Virtual Router Peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualRouterPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_router_name: str, + peering_name: str, + parameters: "_models.VirtualRouterPeering", + **kwargs + ) -> "_models.VirtualRouterPeering": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualRouterPeering') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_router_name: str, + peering_name: str, + parameters: "_models.VirtualRouterPeering", + **kwargs + ) -> AsyncLROPoller["_models.VirtualRouterPeering"]: + """Creates or updates the specified Virtual Router Peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the Virtual Router Peering. + :type peering_name: str + :param parameters: Parameters supplied to the create or update Virtual Router Peering + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualRouterPeering or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + lro_delay = kwargs.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, + virtual_router_name=virtual_router_name, + peering_name=peering_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('VirtualRouterPeering', 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def list( + self, + resource_group_name: str, + virtual_router_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualRouterPeeringListResult"]: + """Lists all Virtual Router Peerings in a Virtual Router resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualRouterPeeringListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualRouterPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters/{virtualRouterName}/peerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_routers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_routers_operations.py new file mode 100644 index 000000000000..71e914f97729 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_routers_operations.py @@ -0,0 +1,484 @@ +# 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 VirtualRoutersOperations: + """VirtualRoutersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_router_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-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_router_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_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, + virtual_router_name=virtual_router_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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + virtual_router_name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.VirtualRouter": + """Gets the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualRouter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualRouter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_router_name: str, + parameters: "_models.VirtualRouter", + **kwargs + ) -> "_models.VirtualRouter": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualRouter') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_router_name: str, + parameters: "_models.VirtualRouter", + **kwargs + ) -> AsyncLROPoller["_models.VirtualRouter"]: + """Creates or updates the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param parameters: Parameters supplied to the create or update Virtual Router. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualRouter + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualRouter or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualRouter] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + lro_delay = kwargs.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, + virtual_router_name=virtual_router_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('VirtualRouter', 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_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': 'azure-async-operation'}, 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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.VirtualRouterListResult"]: + """Lists all Virtual Routers in a 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 VirtualRouterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualRouterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.VirtualRouterListResult"]: + """Gets all the Virtual Routers 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 VirtualRouterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualRouterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_wans_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_wans_operations.py new file mode 100644 index 000000000000..b1b2a8513937 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_virtual_wans_operations.py @@ -0,0 +1,540 @@ +# 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 VirtualWansOperations: + """VirtualWansOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + virtual_wan_name: str, + **kwargs + ) -> "_models.VirtualWAN": + """Retrieves the details of a VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being retrieved. + :type virtual_wan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWAN, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + virtual_wan_name: str, + wan_parameters: "_models.VirtualWAN", + **kwargs + ) -> "_models.VirtualWAN": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(wan_parameters, 'VirtualWAN') + 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('VirtualWAN', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + virtual_wan_name: str, + wan_parameters: "_models.VirtualWAN", + **kwargs + ) -> AsyncLROPoller["_models.VirtualWAN"]: + """Creates a VirtualWAN resource if it doesn't exist else updates the existing VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being created or updated. + :type virtual_wan_name: str + :param wan_parameters: Parameters supplied to create or update VirtualWAN. + :type wan_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualWAN or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualWAN] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + lro_delay = kwargs.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, + virtual_wan_name=virtual_wan_name, + wan_parameters=wan_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('VirtualWAN', 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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualWans/{VirtualWANName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + virtual_wan_name: str, + wan_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VirtualWAN": + """Updates a VirtualWAN tags. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being updated. + :type virtual_wan_name: str + :param wan_parameters: Parameters supplied to Update VirtualWAN tags. + :type wan_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWAN, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(wan_parameters, 'TagsObject') + 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('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + virtual_wan_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-08-01" + 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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + virtual_wan_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being deleted. + :type virtual_wan_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, + virtual_wan_name=virtual_wan_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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVirtualWANsResult"]: + """Lists all the VirtualWANs in a resource group. + + :param resource_group_name: The resource group name of the VirtualWan. + :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 ListVirtualWANsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualWANsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualWANsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVirtualWANsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/virtualWans'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListVirtualWANsResult"]: + """Lists all the VirtualWANs 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 ListVirtualWANsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualWANsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualWANsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVirtualWANsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/virtualWans'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_connections_operations.py new file mode 100644 index 000000000000..60a677fa6390 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_connections_operations.py @@ -0,0 +1,705 @@ +# 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 VpnConnectionsOperations: + """VpnConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + **kwargs + ) -> "_models.VpnConnection": + """Retrieves the details of a vpn connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('VpnConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + vpn_connection_parameters: "_models.VpnConnection", + **kwargs + ) -> "_models.VpnConnection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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(vpn_connection_parameters, 'VpnConnection') + 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('VpnConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + vpn_connection_parameters: "_models.VpnConnection", + **kwargs + ) -> AsyncLROPoller["_models.VpnConnection"]: + """Creates a vpn connection to a scalable vpn gateway if it doesn't exist else updates the + existing connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :param vpn_connection_parameters: Parameters supplied to create or Update a VPN Connection. + :type vpn_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnConnection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + connection_name=connection_name, + vpn_connection_parameters=vpn_connection_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('VpnConnection', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + gateway_name: str, + connection_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a vpn connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the connection. + :type 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 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, + gateway_name=gateway_name, + connection_name=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): + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + async def _start_packet_capture_initial( + self, + resource_group_name: str, + gateway_name: str, + vpn_connection_name: str, + parameters: Optional["_models.VpnConnectionPacketCaptureStartParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnConnectionPacketCaptureStartParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/startpacketcapture'} # type: ignore + + async def begin_start_packet_capture( + self, + resource_group_name: str, + gateway_name: str, + vpn_connection_name: str, + parameters: Optional["_models.VpnConnectionPacketCaptureStartParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Starts packet capture on Vpn connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_connection_name: The name of the vpn connection. + :type vpn_connection_name: str + :param parameters: Vpn Connection packet capture parameters supplied to start packet capture on + gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnectionPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_connection_name=vpn_connection_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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, 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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/startpacketcapture'} # type: ignore + + async def _stop_packet_capture_initial( + self, + resource_group_name: str, + gateway_name: str, + vpn_connection_name: str, + parameters: Optional["_models.VpnConnectionPacketCaptureStopParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnConnectionPacketCaptureStopParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/stoppacketcapture'} # type: ignore + + async def begin_stop_packet_capture( + self, + resource_group_name: str, + gateway_name: str, + vpn_connection_name: str, + parameters: Optional["_models.VpnConnectionPacketCaptureStopParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Stops packet capture on Vpn connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_connection_name: The name of the vpn connection. + :type vpn_connection_name: str + :param parameters: Vpn Connection packet capture parameters supplied to stop packet capture on + gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnectionPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_connection_name=vpn_connection_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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, 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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/stoppacketcapture'} # type: ignore + + def list_by_vpn_gateway( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnConnectionsResult"]: + """Retrieves all vpn connections for a particular virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnConnectionsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_gateway.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('ListVpnConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_vpn_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_gateways_operations.py new file mode 100644 index 000000000000..120567abb145 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_gateways_operations.py @@ -0,0 +1,977 @@ +# 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 VpnGatewaysOperations: + """VpnGatewaysOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> "_models.VpnGateway": + """Retrieves the details of a virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + gateway_name: str, + vpn_gateway_parameters: "_models.VpnGateway", + **kwargs + ) -> "_models.VpnGateway": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(vpn_gateway_parameters, 'VpnGateway') + 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('VpnGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + gateway_name: str, + vpn_gateway_parameters: "_models.VpnGateway", + **kwargs + ) -> AsyncLROPoller["_models.VpnGateway"]: + """Creates a virtual wan vpn gateway if it doesn't exist else updates the existing gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_gateway_parameters: Parameters supplied to create or Update a virtual wan vpn + gateway. + :type vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + vpn_gateway_parameters=vpn_gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def _update_tags_initial( + self, + resource_group_name: str, + gateway_name: str, + vpn_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> Optional["_models.VpnGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(vpn_gateway_parameters, 'TagsObject') + 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('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def begin_update_tags( + self, + resource_group_name: str, + gateway_name: str, + vpn_gateway_parameters: "_models.TagsObject", + **kwargs + ) -> AsyncLROPoller["_models.VpnGateway"]: + """Updates virtual wan vpn gateway tags. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_gateway_parameters: Parameters supplied to update a virtual wan vpn gateway tags. + :type vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_gateway_parameters=vpn_gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + gateway_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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, + gateway_name=gateway_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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.Network/vpnGateways/{gatewayName}'} # type: ignore + + async def _reset_initial( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> Optional["_models.VpnGateway"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/reset'} # type: ignore + + async def begin_reset( + self, + resource_group_name: str, + gateway_name: str, + **kwargs + ) -> AsyncLROPoller["_models.VpnGateway"]: + """Resets the primary of the vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/reset'} # type: ignore + + async def _start_packet_capture_initial( + self, + resource_group_name: str, + gateway_name: str, + parameters: Optional["_models.VpnGatewayPacketCaptureStartParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnGatewayPacketCaptureStartParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/startpacketcapture'} # type: ignore + + async def begin_start_packet_capture( + self, + resource_group_name: str, + gateway_name: str, + parameters: Optional["_models.VpnGatewayPacketCaptureStartParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Starts packet capture on vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param parameters: Vpn gateway packet capture parameters supplied to start packet capture on + vpn gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/startpacketcapture'} # type: ignore + + async def _stop_packet_capture_initial( + self, + resource_group_name: str, + gateway_name: str, + parameters: Optional["_models.VpnGatewayPacketCaptureStopParameters"] = None, + **kwargs + ) -> Optional[str]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnGatewayPacketCaptureStopParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/stoppacketcapture'} # type: ignore + + async def begin_stop_packet_capture( + self, + resource_group_name: str, + gateway_name: str, + parameters: Optional["_models.VpnGatewayPacketCaptureStopParameters"] = None, + **kwargs + ) -> AsyncLROPoller[str]: + """Stops packet capture on vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param parameters: Vpn gateway packet capture parameters supplied to stop packet capture on vpn + gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/stoppacketcapture'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnGatewaysResult"]: + """Lists all the VpnGateways in a resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :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 ListVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnGateways'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListVpnGatewaysResult"]: + """Lists all the VpnGateways 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 ListVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_link_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_link_connections_operations.py new file mode 100644 index 000000000000..5dd3bed73bcd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_link_connections_operations.py @@ -0,0 +1,121 @@ +# 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 VpnLinkConnectionsOperations: + """VpnLinkConnectionsOperations 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.network.v2020_08_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_vpn_connection( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnSiteLinkConnectionsResult"]: + """Retrieves all vpn site link connections for a particular virtual wan vpn gateway vpn + connection. + + :param resource_group_name: The resource group name of the vpn gateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnSiteLinkConnectionsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSiteLinkConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSiteLinkConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_connection.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('ListVpnSiteLinkConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_vpn_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}/vpnLinkConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.py new file mode 100644 index 000000000000..51cd89eb8b49 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.py @@ -0,0 +1,160 @@ +# 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, Union +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.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 VpnServerConfigurationsAssociatedWithVirtualWanOperations: + """VpnServerConfigurationsAssociatedWithVirtualWanOperations 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.network.v2020_08_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_initial( + self, + resource_group_name: str, + virtual_wan_name: str, + **kwargs + ) -> Optional["_models.VpnServerConfigurationsResponse"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnServerConfigurationsResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnServerConfigurationsResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnServerConfigurations'} # type: ignore + + async def begin_list( + self, + resource_group_name: str, + virtual_wan_name: str, + **kwargs + ) -> AsyncLROPoller["_models.VpnServerConfigurationsResponse"]: + """Gives the list of VpnServerConfigurations associated with Virtual Wan in a resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is + needed. + :type virtual_wan_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 VpnServerConfigurationsResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigurationsResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfigurationsResponse"] + lro_delay = kwargs.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_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_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('VpnServerConfigurationsResponse', 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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnServerConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_operations.py new file mode 100644 index 000000000000..895e722732b0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_server_configurations_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 VpnServerConfigurationsOperations: + """VpnServerConfigurationsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + vpn_server_configuration_name: str, + **kwargs + ) -> "_models.VpnServerConfiguration": + """Retrieves the details of a VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being retrieved. + :type vpn_server_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnServerConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + vpn_server_configuration_name: str, + vpn_server_configuration_parameters: "_models.VpnServerConfiguration", + **kwargs + ) -> "_models.VpnServerConfiguration": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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(vpn_server_configuration_parameters, 'VpnServerConfiguration') + 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('VpnServerConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + vpn_server_configuration_name: str, + vpn_server_configuration_parameters: "_models.VpnServerConfiguration", + **kwargs + ) -> AsyncLROPoller["_models.VpnServerConfiguration"]: + """Creates a VpnServerConfiguration resource if it doesn't exist else updates the existing + VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being created or + updated. + :type vpn_server_configuration_name: str + :param vpn_server_configuration_parameters: Parameters supplied to create or update + VpnServerConfiguration. + :type vpn_server_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnServerConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + lro_delay = kwargs.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, + vpn_server_configuration_name=vpn_server_configuration_name, + vpn_server_configuration_parameters=vpn_server_configuration_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('VpnServerConfiguration', 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + vpn_server_configuration_name: str, + vpn_server_configuration_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VpnServerConfiguration": + """Updates VpnServerConfiguration tags. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being updated. + :type vpn_server_configuration_name: str + :param vpn_server_configuration_parameters: Parameters supplied to update + VpnServerConfiguration tags. + :type vpn_server_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnServerConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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(vpn_server_configuration_parameters, 'TagsObject') + 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('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + vpn_server_configuration_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-08-01" + 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + vpn_server_configuration_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being deleted. + :type vpn_server_configuration_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, + vpn_server_configuration_name=vpn_server_configuration_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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnServerConfigurationsResult"]: + """Lists all the vpnServerConfigurations in a resource group. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :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 ListVpnServerConfigurationsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnServerConfigurationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnServerConfigurationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnServerConfigurationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnServerConfigurations'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListVpnServerConfigurationsResult"]: + """Lists all the VpnServerConfigurations 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 ListVpnServerConfigurationsResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnServerConfigurationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnServerConfigurationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnServerConfigurationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnServerConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_link_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_link_connections_operations.py new file mode 100644 index 000000000000..fb46cd3fadfa --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_link_connections_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, 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 VpnSiteLinkConnectionsOperations: + """VpnSiteLinkConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + gateway_name: str, + connection_name: str, + link_connection_name: str, + **kwargs + ) -> "_models.VpnSiteLinkConnection": + """Retrieves the details of a vpn site link connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :param link_connection_name: The name of the vpn connection. + :type link_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSiteLinkConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSiteLinkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + 'linkConnectionName': self._serialize.url("link_connection_name", link_connection_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('VpnSiteLinkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}/vpnLinkConnections/{linkConnectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_links_operations.py new file mode 100644 index 000000000000..49ebab5bd845 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_site_links_operations.py @@ -0,0 +1,178 @@ +# 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 VpnSiteLinksOperations: + """VpnSiteLinksOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + vpn_site_name: str, + vpn_site_link_name: str, + **kwargs + ) -> "_models.VpnSiteLink": + """Retrieves the details of a VPN site link. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite. + :type vpn_site_name: str + :param vpn_site_link_name: The name of the VpnSiteLink being retrieved. + :type vpn_site_link_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSiteLink, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSiteLink + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSiteLink"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_name, 'str'), + 'vpnSiteLinkName': self._serialize.url("vpn_site_link_name", vpn_site_link_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('VpnSiteLink', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}/vpnSiteLinks/{vpnSiteLinkName}'} # type: ignore + + def list_by_vpn_site( + self, + resource_group_name: str, + vpn_site_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnSiteLinksResult"]: + """Lists all the vpnSiteLinks in a resource group for a vpn site. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite. + :type vpn_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 ListVpnSiteLinksResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSiteLinksResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSiteLinksResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_site.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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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('ListVpnSiteLinksResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_vpn_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}/vpnSiteLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_configuration_operations.py new file mode 100644 index 000000000000..24c4527deae8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_configuration_operations.py @@ -0,0 +1,162 @@ +# 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, Union +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.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 VpnSitesConfigurationOperations: + """VpnSitesConfigurationOperations 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.network.v2020_08_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 _download_initial( + self, + resource_group_name: str, + virtual_wan_name: str, + request: "_models.GetVpnSitesConfigurationRequest", + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._download_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(request, 'GetVpnSitesConfigurationRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _download_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnConfiguration'} # type: ignore + + async def begin_download( + self, + resource_group_name: str, + virtual_wan_name: str, + request: "_models.GetVpnSitesConfigurationRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Gives the sas-url to download the configurations for vpn-sites in a resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN for which configuration of all vpn-sites is + needed. + :type virtual_wan_name: str + :param request: Parameters supplied to download vpn-sites configuration. + :type request: ~azure.mgmt.network.v2020_08_01.models.GetVpnSitesConfigurationRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._download_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_download.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnConfiguration'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_operations.py new file mode 100644 index 000000000000..56e24734bb85 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_vpn_sites_operations.py @@ -0,0 +1,540 @@ +# 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 VpnSitesOperations: + """VpnSitesOperations 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.network.v2020_08_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( + self, + resource_group_name: str, + vpn_site_name: str, + **kwargs + ) -> "_models.VpnSite": + """Retrieves the details of a VPN site. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being retrieved. + :type vpn_site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + vpn_site_name: str, + vpn_site_parameters: "_models.VpnSite", + **kwargs + ) -> "_models.VpnSite": + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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(vpn_site_parameters, 'VpnSite') + 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('VpnSite', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + vpn_site_name: str, + vpn_site_parameters: "_models.VpnSite", + **kwargs + ) -> AsyncLROPoller["_models.VpnSite"]: + """Creates a VpnSite resource if it doesn't exist else updates the existing VpnSite. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being created or updated. + :type vpn_site_name: str + :param vpn_site_parameters: Parameters supplied to create or update VpnSite. + :type vpn_site_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnSite or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.network.v2020_08_01.models.VpnSite] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + lro_delay = kwargs.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, + vpn_site_name=vpn_site_name, + vpn_site_parameters=vpn_site_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('VpnSite', 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnSites/{vpnSiteName}'} # type: ignore + + async def update_tags( + self, + resource_group_name: str, + vpn_site_name: str, + vpn_site_parameters: "_models.TagsObject", + **kwargs + ) -> "_models.VpnSite": + """Updates VpnSite tags. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being updated. + :type vpn_site_name: str + :param vpn_site_parameters: Parameters supplied to update VpnSite tags. + :type vpn_site_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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(vpn_site_parameters, 'TagsObject') + 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('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + vpn_site_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-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + vpn_site_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a VpnSite. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being deleted. + :type vpn_site_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, + vpn_site_name=vpn_site_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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ListVpnSitesResult"]: + """Lists all the vpnSites in a resource group. + + :param resource_group_name: The resource group name of the VpnSite. + :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 ListVpnSitesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSitesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSitesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnSitesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnSites'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ListVpnSitesResult"]: + """Lists all the VpnSites 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 ListVpnSitesResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSitesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSitesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnSitesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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.Network/vpnSites'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_application_firewall_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_application_firewall_policies_operations.py new file mode 100644 index 000000000000..9da95ae1b568 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_application_firewall_policies_operations.py @@ -0,0 +1,416 @@ +# 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 WebApplicationFirewallPoliciesOperations: + """WebApplicationFirewallPoliciesOperations 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.network.v2020_08_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, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.WebApplicationFirewallPolicyListResult"]: + """Lists all of the protection policies within a 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 WebApplicationFirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebApplicationFirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies'} # type: ignore + + def list_all( + self, + **kwargs + ) -> AsyncIterable["_models.WebApplicationFirewallPolicyListResult"]: + """Gets all the WAF policies 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 WebApplicationFirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('WebApplicationFirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies'} # type: ignore + + async def get( + self, + resource_group_name: str, + policy_name: str, + **kwargs + ) -> "_models.WebApplicationFirewallPolicy": + """Retrieve protection policy with specified name within a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebApplicationFirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('WebApplicationFirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + policy_name: str, + parameters: "_models.WebApplicationFirewallPolicy", + **kwargs + ) -> "_models.WebApplicationFirewallPolicy": + """Creates or update policy with specified rule set name within a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_name: str + :param parameters: Policy to be created. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebApplicationFirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'WebApplicationFirewallPolicy') + 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('WebApplicationFirewallPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('WebApplicationFirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + policy_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-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + policy_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_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, + policy_name=policy_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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + '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.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_categories_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_categories_operations.py new file mode 100644 index 000000000000..a3e6b3df10de --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/aio/operations/_web_categories_operations.py @@ -0,0 +1,167 @@ +# 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 WebCategoriesOperations: + """WebCategoriesOperations 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.network.v2020_08_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( + self, + name: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.AzureWebCategory": + """Gets the specified Azure Web Category. + + :param name: The name of the azureWebCategory. + :type name: str + :param expand: Expands resourceIds back referenced by the azureWebCategory resource. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureWebCategory, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.AzureWebCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureWebCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('AzureWebCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureWebCategories/{name}'} # type: ignore + + def list_by_subscription( + self, + **kwargs + ) -> AsyncIterable["_models.AzureWebCategoryListResult"]: + """Gets all the Azure Web Categories 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 AzureWebCategoryListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureWebCategoryListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureWebCategoryListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('AzureWebCategoryListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_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_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureWebCategories'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/__init__.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/__init__.py new file mode 100644 index 000000000000..fbfdb02e261f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/__init__.py @@ -0,0 +1,1979 @@ +# 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 AadAuthenticationParameters + from ._models_py3 import AddressSpace + from ._models_py3 import ApplicationGateway + from ._models_py3 import ApplicationGatewayAuthenticationCertificate + from ._models_py3 import ApplicationGatewayAutoscaleConfiguration + from ._models_py3 import ApplicationGatewayAvailableSslOptions + from ._models_py3 import ApplicationGatewayAvailableSslPredefinedPolicies + from ._models_py3 import ApplicationGatewayAvailableWafRuleSetsResult + from ._models_py3 import ApplicationGatewayBackendAddress + from ._models_py3 import ApplicationGatewayBackendAddressPool + from ._models_py3 import ApplicationGatewayBackendHealth + from ._models_py3 import ApplicationGatewayBackendHealthHttpSettings + from ._models_py3 import ApplicationGatewayBackendHealthOnDemand + from ._models_py3 import ApplicationGatewayBackendHealthPool + from ._models_py3 import ApplicationGatewayBackendHealthServer + from ._models_py3 import ApplicationGatewayBackendHttpSettings + from ._models_py3 import ApplicationGatewayClientAuthConfiguration + from ._models_py3 import ApplicationGatewayConnectionDraining + from ._models_py3 import ApplicationGatewayCustomError + from ._models_py3 import ApplicationGatewayFirewallDisabledRuleGroup + from ._models_py3 import ApplicationGatewayFirewallExclusion + from ._models_py3 import ApplicationGatewayFirewallRule + from ._models_py3 import ApplicationGatewayFirewallRuleGroup + from ._models_py3 import ApplicationGatewayFirewallRuleSet + from ._models_py3 import ApplicationGatewayFrontendIPConfiguration + from ._models_py3 import ApplicationGatewayFrontendPort + from ._models_py3 import ApplicationGatewayHeaderConfiguration + from ._models_py3 import ApplicationGatewayHttpListener + from ._models_py3 import ApplicationGatewayIPConfiguration + from ._models_py3 import ApplicationGatewayListResult + from ._models_py3 import ApplicationGatewayOnDemandProbe + from ._models_py3 import ApplicationGatewayPathRule + from ._models_py3 import ApplicationGatewayPrivateEndpointConnection + from ._models_py3 import ApplicationGatewayPrivateEndpointConnectionListResult + from ._models_py3 import ApplicationGatewayPrivateLinkConfiguration + from ._models_py3 import ApplicationGatewayPrivateLinkIpConfiguration + from ._models_py3 import ApplicationGatewayPrivateLinkResource + from ._models_py3 import ApplicationGatewayPrivateLinkResourceListResult + from ._models_py3 import ApplicationGatewayProbe + from ._models_py3 import ApplicationGatewayProbeHealthResponseMatch + from ._models_py3 import ApplicationGatewayRedirectConfiguration + from ._models_py3 import ApplicationGatewayRequestRoutingRule + from ._models_py3 import ApplicationGatewayRewriteRule + from ._models_py3 import ApplicationGatewayRewriteRuleActionSet + from ._models_py3 import ApplicationGatewayRewriteRuleCondition + from ._models_py3 import ApplicationGatewayRewriteRuleSet + from ._models_py3 import ApplicationGatewaySku + from ._models_py3 import ApplicationGatewaySslCertificate + from ._models_py3 import ApplicationGatewaySslPolicy + from ._models_py3 import ApplicationGatewaySslPredefinedPolicy + from ._models_py3 import ApplicationGatewaySslProfile + from ._models_py3 import ApplicationGatewayTrustedClientCertificate + from ._models_py3 import ApplicationGatewayTrustedRootCertificate + from ._models_py3 import ApplicationGatewayUrlConfiguration + from ._models_py3 import ApplicationGatewayUrlPathMap + from ._models_py3 import ApplicationGatewayWebApplicationFirewallConfiguration + from ._models_py3 import ApplicationRule + from ._models_py3 import ApplicationSecurityGroup + from ._models_py3 import ApplicationSecurityGroupListResult + from ._models_py3 import AuthorizationListResult + from ._models_py3 import AutoApprovedPrivateLinkService + from ._models_py3 import AutoApprovedPrivateLinkServicesResult + from ._models_py3 import Availability + from ._models_py3 import AvailableDelegation + from ._models_py3 import AvailableDelegationsResult + from ._models_py3 import AvailablePrivateEndpointType + from ._models_py3 import AvailablePrivateEndpointTypesResult + from ._models_py3 import AvailableProvidersList + from ._models_py3 import AvailableProvidersListCity + from ._models_py3 import AvailableProvidersListCountry + from ._models_py3 import AvailableProvidersListParameters + from ._models_py3 import AvailableProvidersListState + from ._models_py3 import AvailableServiceAlias + from ._models_py3 import AvailableServiceAliasesResult + from ._models_py3 import AzureAsyncOperationResult + from ._models_py3 import AzureFirewall + from ._models_py3 import AzureFirewallApplicationRule + from ._models_py3 import AzureFirewallApplicationRuleCollection + from ._models_py3 import AzureFirewallApplicationRuleProtocol + from ._models_py3 import AzureFirewallFqdnTag + from ._models_py3 import AzureFirewallFqdnTagListResult + from ._models_py3 import AzureFirewallIPConfiguration + from ._models_py3 import AzureFirewallIpGroups + from ._models_py3 import AzureFirewallListResult + from ._models_py3 import AzureFirewallNatRCAction + from ._models_py3 import AzureFirewallNatRule + from ._models_py3 import AzureFirewallNatRuleCollection + from ._models_py3 import AzureFirewallNetworkRule + from ._models_py3 import AzureFirewallNetworkRuleCollection + from ._models_py3 import AzureFirewallPublicIPAddress + from ._models_py3 import AzureFirewallRCAction + from ._models_py3 import AzureFirewallSku + from ._models_py3 import AzureReachabilityReport + from ._models_py3 import AzureReachabilityReportItem + from ._models_py3 import AzureReachabilityReportLatencyInfo + from ._models_py3 import AzureReachabilityReportLocation + from ._models_py3 import AzureReachabilityReportParameters + from ._models_py3 import AzureWebCategory + from ._models_py3 import AzureWebCategoryListResult + from ._models_py3 import BGPCommunity + from ._models_py3 import BackendAddressPool + from ._models_py3 import BastionActiveSession + from ._models_py3 import BastionActiveSessionListResult + from ._models_py3 import BastionHost + from ._models_py3 import BastionHostIPConfiguration + from ._models_py3 import BastionHostListResult + from ._models_py3 import BastionSessionDeleteResult + from ._models_py3 import BastionSessionState + from ._models_py3 import BastionShareableLink + from ._models_py3 import BastionShareableLinkListRequest + from ._models_py3 import BastionShareableLinkListResult + from ._models_py3 import BgpConnection + from ._models_py3 import BgpPeerStatus + from ._models_py3 import BgpPeerStatusListResult + from ._models_py3 import BgpServiceCommunity + from ._models_py3 import BgpServiceCommunityListResult + from ._models_py3 import BgpSettings + from ._models_py3 import BreakOutCategoryPolicies + from ._models_py3 import CheckPrivateLinkServiceVisibilityRequest + from ._models_py3 import CloudErrorBody + from ._models_py3 import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties + from ._models_py3 import ConnectionMonitor + from ._models_py3 import ConnectionMonitorDestination + from ._models_py3 import ConnectionMonitorEndpoint + from ._models_py3 import ConnectionMonitorEndpointFilter + from ._models_py3 import ConnectionMonitorEndpointFilterItem + from ._models_py3 import ConnectionMonitorEndpointScope + from ._models_py3 import ConnectionMonitorEndpointScopeItem + from ._models_py3 import ConnectionMonitorHttpConfiguration + from ._models_py3 import ConnectionMonitorIcmpConfiguration + from ._models_py3 import ConnectionMonitorListResult + from ._models_py3 import ConnectionMonitorOutput + from ._models_py3 import ConnectionMonitorParameters + from ._models_py3 import ConnectionMonitorQueryResult + from ._models_py3 import ConnectionMonitorResult + from ._models_py3 import ConnectionMonitorResultProperties + from ._models_py3 import ConnectionMonitorSource + from ._models_py3 import ConnectionMonitorSuccessThreshold + from ._models_py3 import ConnectionMonitorTcpConfiguration + from ._models_py3 import ConnectionMonitorTestConfiguration + from ._models_py3 import ConnectionMonitorTestGroup + from ._models_py3 import ConnectionMonitorWorkspaceSettings + from ._models_py3 import ConnectionResetSharedKey + from ._models_py3 import ConnectionSharedKey + from ._models_py3 import ConnectionStateSnapshot + from ._models_py3 import ConnectivityDestination + from ._models_py3 import ConnectivityHop + from ._models_py3 import ConnectivityInformation + from ._models_py3 import ConnectivityIssue + from ._models_py3 import ConnectivityParameters + from ._models_py3 import ConnectivitySource + from ._models_py3 import Container + from ._models_py3 import ContainerNetworkInterface + from ._models_py3 import ContainerNetworkInterfaceConfiguration + from ._models_py3 import ContainerNetworkInterfaceIpConfiguration + from ._models_py3 import CustomDnsConfigPropertiesFormat + from ._models_py3 import CustomIpPrefix + from ._models_py3 import CustomIpPrefixListResult + from ._models_py3 import DdosCustomPolicy + from ._models_py3 import DdosProtectionPlan + from ._models_py3 import DdosProtectionPlanListResult + from ._models_py3 import DdosSettings + from ._models_py3 import Delegation + from ._models_py3 import DeviceProperties + from ._models_py3 import DhcpOptions + from ._models_py3 import Dimension + from ._models_py3 import DnsNameAvailabilityResult + from ._models_py3 import DnsSettings + from ._models_py3 import DscpConfiguration + from ._models_py3 import DscpConfigurationListResult + from ._models_py3 import EffectiveNetworkSecurityGroup + from ._models_py3 import EffectiveNetworkSecurityGroupAssociation + from ._models_py3 import EffectiveNetworkSecurityGroupListResult + from ._models_py3 import EffectiveNetworkSecurityRule + from ._models_py3 import EffectiveRoute + from ._models_py3 import EffectiveRouteListResult + from ._models_py3 import EffectiveRoutesParameters + from ._models_py3 import EndpointServiceResult + from ._models_py3 import EndpointServicesListResult + from ._models_py3 import Error + from ._models_py3 import ErrorDetails + from ._models_py3 import ErrorResponse + from ._models_py3 import EvaluatedNetworkSecurityGroup + from ._models_py3 import ExpressRouteCircuit + from ._models_py3 import ExpressRouteCircuitArpTable + from ._models_py3 import ExpressRouteCircuitAuthorization + from ._models_py3 import ExpressRouteCircuitConnection + from ._models_py3 import ExpressRouteCircuitConnectionListResult + from ._models_py3 import ExpressRouteCircuitListResult + from ._models_py3 import ExpressRouteCircuitPeering + from ._models_py3 import ExpressRouteCircuitPeeringConfig + from ._models_py3 import ExpressRouteCircuitPeeringId + from ._models_py3 import ExpressRouteCircuitPeeringListResult + from ._models_py3 import ExpressRouteCircuitReference + from ._models_py3 import ExpressRouteCircuitRoutesTable + from ._models_py3 import ExpressRouteCircuitRoutesTableSummary + from ._models_py3 import ExpressRouteCircuitServiceProviderProperties + from ._models_py3 import ExpressRouteCircuitSku + from ._models_py3 import ExpressRouteCircuitStats + from ._models_py3 import ExpressRouteCircuitsArpTableListResult + from ._models_py3 import ExpressRouteCircuitsRoutesTableListResult + from ._models_py3 import ExpressRouteCircuitsRoutesTableSummaryListResult + from ._models_py3 import ExpressRouteConnection + from ._models_py3 import ExpressRouteConnectionId + from ._models_py3 import ExpressRouteConnectionList + from ._models_py3 import ExpressRouteCrossConnection + from ._models_py3 import ExpressRouteCrossConnectionListResult + from ._models_py3 import ExpressRouteCrossConnectionPeering + from ._models_py3 import ExpressRouteCrossConnectionPeeringList + from ._models_py3 import ExpressRouteCrossConnectionRoutesTableSummary + from ._models_py3 import ExpressRouteCrossConnectionsRoutesTableSummaryListResult + from ._models_py3 import ExpressRouteGateway + from ._models_py3 import ExpressRouteGatewayList + from ._models_py3 import ExpressRouteGatewayPropertiesAutoScaleConfiguration + from ._models_py3 import ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds + from ._models_py3 import ExpressRouteLink + from ._models_py3 import ExpressRouteLinkListResult + from ._models_py3 import ExpressRouteLinkMacSecConfig + from ._models_py3 import ExpressRoutePort + from ._models_py3 import ExpressRoutePortListResult + from ._models_py3 import ExpressRoutePortsLocation + from ._models_py3 import ExpressRoutePortsLocationBandwidths + from ._models_py3 import ExpressRoutePortsLocationListResult + from ._models_py3 import ExpressRouteServiceProvider + from ._models_py3 import ExpressRouteServiceProviderBandwidthsOffered + from ._models_py3 import ExpressRouteServiceProviderListResult + from ._models_py3 import ExtendedLocation + from ._models_py3 import FirewallPolicy + from ._models_py3 import FirewallPolicyCertificateAuthority + from ._models_py3 import FirewallPolicyFilterRuleCollection + from ._models_py3 import FirewallPolicyFilterRuleCollectionAction + from ._models_py3 import FirewallPolicyIntrusionDetection + from ._models_py3 import FirewallPolicyIntrusionDetectionBypassTrafficSpecifications + from ._models_py3 import FirewallPolicyIntrusionDetectionConfiguration + from ._models_py3 import FirewallPolicyIntrusionDetectionSignatureSpecification + from ._models_py3 import FirewallPolicyListResult + from ._models_py3 import FirewallPolicyNatRuleCollection + from ._models_py3 import FirewallPolicyNatRuleCollectionAction + from ._models_py3 import FirewallPolicyRule + from ._models_py3 import FirewallPolicyRuleApplicationProtocol + from ._models_py3 import FirewallPolicyRuleCollection + from ._models_py3 import FirewallPolicyRuleCollectionGroup + from ._models_py3 import FirewallPolicyRuleCollectionGroupListResult + from ._models_py3 import FirewallPolicySku + from ._models_py3 import FirewallPolicyThreatIntelWhitelist + from ._models_py3 import FirewallPolicyTransportSecurity + from ._models_py3 import FlowLog + from ._models_py3 import FlowLogFormatParameters + from ._models_py3 import FlowLogInformation + from ._models_py3 import FlowLogListResult + from ._models_py3 import FlowLogStatusParameters + from ._models_py3 import FrontendIPConfiguration + from ._models_py3 import GatewayRoute + from ._models_py3 import GatewayRouteListResult + from ._models_py3 import GenerateExpressRoutePortsLOARequest + from ._models_py3 import GenerateExpressRoutePortsLOAResult + from ._models_py3 import GetVpnSitesConfigurationRequest + from ._models_py3 import HTTPConfiguration + from ._models_py3 import HTTPHeader + from ._models_py3 import HopLink + from ._models_py3 import HubIPAddresses + from ._models_py3 import HubIpConfiguration + from ._models_py3 import HubPublicIPAddresses + from ._models_py3 import HubRoute + from ._models_py3 import HubRouteTable + from ._models_py3 import HubVirtualNetworkConnection + from ._models_py3 import IPAddressAvailabilityResult + from ._models_py3 import IPConfiguration + from ._models_py3 import IPConfigurationBgpPeeringAddress + from ._models_py3 import IPConfigurationProfile + from ._models_py3 import InboundNatPool + from ._models_py3 import InboundNatRule + from ._models_py3 import InboundNatRuleListResult + from ._models_py3 import InboundSecurityRule + from ._models_py3 import InboundSecurityRules + from ._models_py3 import IpAllocation + from ._models_py3 import IpAllocationListResult + from ._models_py3 import IpGroup + from ._models_py3 import IpGroupListResult + from ._models_py3 import IpTag + from ._models_py3 import IpsecPolicy + from ._models_py3 import Ipv6CircuitConnectionConfig + from ._models_py3 import Ipv6ExpressRouteCircuitPeeringConfig + from ._models_py3 import ListHubRouteTablesResult + from ._models_py3 import ListHubVirtualNetworkConnectionsResult + from ._models_py3 import ListP2SVpnGatewaysResult + from ._models_py3 import ListVirtualHubBgpConnectionResults + from ._models_py3 import ListVirtualHubIpConfigurationResults + from ._models_py3 import ListVirtualHubRouteTableV2SResult + from ._models_py3 import ListVirtualHubsResult + from ._models_py3 import ListVirtualWANsResult + from ._models_py3 import ListVpnConnectionsResult + from ._models_py3 import ListVpnGatewayNatRulesResult + from ._models_py3 import ListVpnGatewaysResult + from ._models_py3 import ListVpnServerConfigurationsResult + from ._models_py3 import ListVpnSiteLinkConnectionsResult + from ._models_py3 import ListVpnSiteLinksResult + from ._models_py3 import ListVpnSitesResult + from ._models_py3 import LoadBalancer + from ._models_py3 import LoadBalancerBackendAddress + from ._models_py3 import LoadBalancerBackendAddressPoolListResult + from ._models_py3 import LoadBalancerFrontendIPConfigurationListResult + from ._models_py3 import LoadBalancerListResult + from ._models_py3 import LoadBalancerLoadBalancingRuleListResult + from ._models_py3 import LoadBalancerOutboundRuleListResult + from ._models_py3 import LoadBalancerProbeListResult + from ._models_py3 import LoadBalancerSku + from ._models_py3 import LoadBalancingRule + from ._models_py3 import LocalNetworkGateway + from ._models_py3 import LocalNetworkGatewayListResult + from ._models_py3 import LogSpecification + from ._models_py3 import ManagedRuleGroupOverride + from ._models_py3 import ManagedRuleOverride + from ._models_py3 import ManagedRuleSet + from ._models_py3 import ManagedRulesDefinition + from ._models_py3 import ManagedServiceIdentity + from ._models_py3 import MatchCondition + from ._models_py3 import MatchVariable + from ._models_py3 import MatchedRule + from ._models_py3 import MetricSpecification + from ._models_py3 import NatGateway + from ._models_py3 import NatGatewayListResult + from ._models_py3 import NatGatewaySku + from ._models_py3 import NatRule + from ._models_py3 import NetworkConfigurationDiagnosticParameters + from ._models_py3 import NetworkConfigurationDiagnosticProfile + from ._models_py3 import NetworkConfigurationDiagnosticResponse + from ._models_py3 import NetworkConfigurationDiagnosticResult + from ._models_py3 import NetworkIntentPolicy + from ._models_py3 import NetworkIntentPolicyConfiguration + from ._models_py3 import NetworkInterface + from ._models_py3 import NetworkInterfaceAssociation + from ._models_py3 import NetworkInterfaceDnsSettings + from ._models_py3 import NetworkInterfaceIPConfiguration + from ._models_py3 import NetworkInterfaceIPConfigurationListResult + from ._models_py3 import NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties + from ._models_py3 import NetworkInterfaceListResult + from ._models_py3 import NetworkInterfaceLoadBalancerListResult + from ._models_py3 import NetworkInterfaceTapConfiguration + from ._models_py3 import NetworkInterfaceTapConfigurationListResult + from ._models_py3 import NetworkProfile + from ._models_py3 import NetworkProfileListResult + from ._models_py3 import NetworkRule + from ._models_py3 import NetworkSecurityGroup + from ._models_py3 import NetworkSecurityGroupListResult + from ._models_py3 import NetworkSecurityGroupResult + from ._models_py3 import NetworkSecurityRulesEvaluationResult + from ._models_py3 import NetworkVirtualAppliance + from ._models_py3 import NetworkVirtualApplianceListResult + from ._models_py3 import NetworkVirtualApplianceSiteListResult + from ._models_py3 import NetworkVirtualApplianceSku + from ._models_py3 import NetworkVirtualApplianceSkuInstances + from ._models_py3 import NetworkVirtualApplianceSkuListResult + from ._models_py3 import NetworkWatcher + from ._models_py3 import NetworkWatcherListResult + from ._models_py3 import NextHopParameters + from ._models_py3 import NextHopResult + from ._models_py3 import O365BreakOutCategoryPolicies + from ._models_py3 import O365PolicyProperties + from ._models_py3 import Office365PolicyProperties + from ._models_py3 import Operation + from ._models_py3 import OperationDisplay + from ._models_py3 import OperationListResult + from ._models_py3 import OperationPropertiesFormatServiceSpecification + from ._models_py3 import OutboundRule + from ._models_py3 import OwaspCrsExclusionEntry + from ._models_py3 import P2SConnectionConfiguration + from ._models_py3 import P2SVpnConnectionHealth + from ._models_py3 import P2SVpnConnectionHealthRequest + from ._models_py3 import P2SVpnConnectionRequest + from ._models_py3 import P2SVpnGateway + from ._models_py3 import P2SVpnProfileParameters + from ._models_py3 import PacketCapture + from ._models_py3 import PacketCaptureFilter + from ._models_py3 import PacketCaptureListResult + from ._models_py3 import PacketCaptureParameters + from ._models_py3 import PacketCaptureQueryStatusResult + from ._models_py3 import PacketCaptureResult + from ._models_py3 import PacketCaptureResultProperties + from ._models_py3 import PacketCaptureStorageLocation + from ._models_py3 import PatchRouteFilter + from ._models_py3 import PatchRouteFilterRule + from ._models_py3 import PeerExpressRouteCircuitConnection + from ._models_py3 import PeerExpressRouteCircuitConnectionListResult + from ._models_py3 import PeerRoute + from ._models_py3 import PeerRouteList + from ._models_py3 import PolicySettings + from ._models_py3 import PrepareNetworkPoliciesRequest + from ._models_py3 import PrivateDnsZoneConfig + from ._models_py3 import PrivateDnsZoneGroup + from ._models_py3 import PrivateDnsZoneGroupListResult + from ._models_py3 import PrivateEndpoint + from ._models_py3 import PrivateEndpointConnection + from ._models_py3 import PrivateEndpointConnectionListResult + from ._models_py3 import PrivateEndpointListResult + from ._models_py3 import PrivateLinkService + from ._models_py3 import PrivateLinkServiceConnection + from ._models_py3 import PrivateLinkServiceConnectionState + from ._models_py3 import PrivateLinkServiceIpConfiguration + from ._models_py3 import PrivateLinkServiceListResult + from ._models_py3 import PrivateLinkServicePropertiesAutoApproval + from ._models_py3 import PrivateLinkServicePropertiesVisibility + from ._models_py3 import PrivateLinkServiceVisibility + from ._models_py3 import Probe + from ._models_py3 import PropagatedRouteTable + from ._models_py3 import ProtocolConfiguration + from ._models_py3 import ProtocolCustomSettingsFormat + from ._models_py3 import PublicIPAddress + from ._models_py3 import PublicIPAddressDnsSettings + from ._models_py3 import PublicIPAddressListResult + from ._models_py3 import PublicIPAddressSku + from ._models_py3 import PublicIPPrefix + from ._models_py3 import PublicIPPrefixListResult + from ._models_py3 import PublicIPPrefixSku + from ._models_py3 import QosIpRange + from ._models_py3 import QosPortRange + from ._models_py3 import QueryTroubleshootingParameters + from ._models_py3 import RadiusServer + from ._models_py3 import RecordSet + from ._models_py3 import ReferencedPublicIpAddress + from ._models_py3 import Resource + from ._models_py3 import ResourceNavigationLink + from ._models_py3 import ResourceNavigationLinksListResult + from ._models_py3 import ResourceSet + from ._models_py3 import RetentionPolicyParameters + from ._models_py3 import Route + from ._models_py3 import RouteFilter + from ._models_py3 import RouteFilterListResult + from ._models_py3 import RouteFilterRule + from ._models_py3 import RouteFilterRuleListResult + from ._models_py3 import RouteListResult + from ._models_py3 import RouteTable + from ._models_py3 import RouteTableListResult + from ._models_py3 import RoutingConfiguration + from ._models_py3 import SecurityGroupNetworkInterface + from ._models_py3 import SecurityGroupViewParameters + from ._models_py3 import SecurityGroupViewResult + from ._models_py3 import SecurityPartnerProvider + from ._models_py3 import SecurityPartnerProviderListResult + from ._models_py3 import SecurityRule + from ._models_py3 import SecurityRuleAssociations + from ._models_py3 import SecurityRuleListResult + from ._models_py3 import ServiceAssociationLink + from ._models_py3 import ServiceAssociationLinksListResult + from ._models_py3 import ServiceEndpointPolicy + from ._models_py3 import ServiceEndpointPolicyDefinition + from ._models_py3 import ServiceEndpointPolicyDefinitionListResult + from ._models_py3 import ServiceEndpointPolicyListResult + from ._models_py3 import ServiceEndpointPropertiesFormat + from ._models_py3 import ServiceTagInformation + from ._models_py3 import ServiceTagInformationPropertiesFormat + from ._models_py3 import ServiceTagsListResult + from ._models_py3 import SessionIds + from ._models_py3 import StaticRoute + from ._models_py3 import SubResource + from ._models_py3 import Subnet + from ._models_py3 import SubnetAssociation + from ._models_py3 import SubnetListResult + from ._models_py3 import TagsObject + from ._models_py3 import Topology + from ._models_py3 import TopologyAssociation + from ._models_py3 import TopologyParameters + from ._models_py3 import TopologyResource + from ._models_py3 import TrafficAnalyticsConfigurationProperties + from ._models_py3 import TrafficAnalyticsProperties + from ._models_py3 import TrafficSelectorPolicy + from ._models_py3 import TroubleshootingDetails + from ._models_py3 import TroubleshootingParameters + from ._models_py3 import TroubleshootingRecommendedActions + from ._models_py3 import TroubleshootingResult + from ._models_py3 import TunnelConnectionHealth + from ._models_py3 import UnprepareNetworkPoliciesRequest + from ._models_py3 import Usage + from ._models_py3 import UsageName + from ._models_py3 import UsagesListResult + from ._models_py3 import VM + from ._models_py3 import VerificationIPFlowParameters + from ._models_py3 import VerificationIPFlowResult + from ._models_py3 import VirtualApplianceNicProperties + from ._models_py3 import VirtualApplianceSite + from ._models_py3 import VirtualApplianceSkuProperties + from ._models_py3 import VirtualHub + from ._models_py3 import VirtualHubEffectiveRoute + from ._models_py3 import VirtualHubEffectiveRouteList + from ._models_py3 import VirtualHubId + from ._models_py3 import VirtualHubRoute + from ._models_py3 import VirtualHubRouteTable + from ._models_py3 import VirtualHubRouteTableV2 + from ._models_py3 import VirtualHubRouteV2 + from ._models_py3 import VirtualNetwork + from ._models_py3 import VirtualNetworkBgpCommunities + from ._models_py3 import VirtualNetworkConnectionGatewayReference + from ._models_py3 import VirtualNetworkGateway + from ._models_py3 import VirtualNetworkGatewayConnection + from ._models_py3 import VirtualNetworkGatewayConnectionListEntity + from ._models_py3 import VirtualNetworkGatewayConnectionListResult + from ._models_py3 import VirtualNetworkGatewayIPConfiguration + from ._models_py3 import VirtualNetworkGatewayListConnectionsResult + from ._models_py3 import VirtualNetworkGatewayListResult + from ._models_py3 import VirtualNetworkGatewaySku + from ._models_py3 import VirtualNetworkListResult + from ._models_py3 import VirtualNetworkListUsageResult + from ._models_py3 import VirtualNetworkPeering + from ._models_py3 import VirtualNetworkPeeringListResult + from ._models_py3 import VirtualNetworkTap + from ._models_py3 import VirtualNetworkTapListResult + from ._models_py3 import VirtualNetworkUsage + from ._models_py3 import VirtualNetworkUsageName + from ._models_py3 import VirtualRouter + from ._models_py3 import VirtualRouterListResult + from ._models_py3 import VirtualRouterPeering + from ._models_py3 import VirtualRouterPeeringListResult + from ._models_py3 import VirtualWAN + from ._models_py3 import VirtualWanSecurityProvider + from ._models_py3 import VirtualWanSecurityProviders + from ._models_py3 import VirtualWanVpnProfileParameters + from ._models_py3 import VnetRoute + from ._models_py3 import VpnClientConfiguration + from ._models_py3 import VpnClientConnectionHealth + from ._models_py3 import VpnClientConnectionHealthDetail + from ._models_py3 import VpnClientConnectionHealthDetailListResult + from ._models_py3 import VpnClientIPsecParameters + from ._models_py3 import VpnClientParameters + from ._models_py3 import VpnClientRevokedCertificate + from ._models_py3 import VpnClientRootCertificate + from ._models_py3 import VpnConnection + from ._models_py3 import VpnConnectionPacketCaptureStartParameters + from ._models_py3 import VpnConnectionPacketCaptureStopParameters + from ._models_py3 import VpnDeviceScriptParameters + from ._models_py3 import VpnGateway + from ._models_py3 import VpnGatewayIpConfiguration + from ._models_py3 import VpnGatewayNatRule + from ._models_py3 import VpnGatewayPacketCaptureStartParameters + from ._models_py3 import VpnGatewayPacketCaptureStopParameters + from ._models_py3 import VpnLinkBgpSettings + from ._models_py3 import VpnLinkProviderProperties + from ._models_py3 import VpnNatRuleMapping + from ._models_py3 import VpnPacketCaptureStartParameters + from ._models_py3 import VpnPacketCaptureStopParameters + from ._models_py3 import VpnProfileResponse + from ._models_py3 import VpnServerConfigRadiusClientRootCertificate + from ._models_py3 import VpnServerConfigRadiusServerRootCertificate + from ._models_py3 import VpnServerConfigVpnClientRevokedCertificate + from ._models_py3 import VpnServerConfigVpnClientRootCertificate + from ._models_py3 import VpnServerConfiguration + from ._models_py3 import VpnServerConfigurationsResponse + from ._models_py3 import VpnSite + from ._models_py3 import VpnSiteId + from ._models_py3 import VpnSiteLink + from ._models_py3 import VpnSiteLinkConnection + from ._models_py3 import WebApplicationFirewallCustomRule + from ._models_py3 import WebApplicationFirewallPolicy + from ._models_py3 import WebApplicationFirewallPolicyListResult +except (SyntaxError, ImportError): + from ._models import AadAuthenticationParameters # type: ignore + from ._models import AddressSpace # type: ignore + from ._models import ApplicationGateway # type: ignore + from ._models import ApplicationGatewayAuthenticationCertificate # type: ignore + from ._models import ApplicationGatewayAutoscaleConfiguration # type: ignore + from ._models import ApplicationGatewayAvailableSslOptions # type: ignore + from ._models import ApplicationGatewayAvailableSslPredefinedPolicies # type: ignore + from ._models import ApplicationGatewayAvailableWafRuleSetsResult # type: ignore + from ._models import ApplicationGatewayBackendAddress # type: ignore + from ._models import ApplicationGatewayBackendAddressPool # type: ignore + from ._models import ApplicationGatewayBackendHealth # type: ignore + from ._models import ApplicationGatewayBackendHealthHttpSettings # type: ignore + from ._models import ApplicationGatewayBackendHealthOnDemand # type: ignore + from ._models import ApplicationGatewayBackendHealthPool # type: ignore + from ._models import ApplicationGatewayBackendHealthServer # type: ignore + from ._models import ApplicationGatewayBackendHttpSettings # type: ignore + from ._models import ApplicationGatewayClientAuthConfiguration # type: ignore + from ._models import ApplicationGatewayConnectionDraining # type: ignore + from ._models import ApplicationGatewayCustomError # type: ignore + from ._models import ApplicationGatewayFirewallDisabledRuleGroup # type: ignore + from ._models import ApplicationGatewayFirewallExclusion # type: ignore + from ._models import ApplicationGatewayFirewallRule # type: ignore + from ._models import ApplicationGatewayFirewallRuleGroup # type: ignore + from ._models import ApplicationGatewayFirewallRuleSet # type: ignore + from ._models import ApplicationGatewayFrontendIPConfiguration # type: ignore + from ._models import ApplicationGatewayFrontendPort # type: ignore + from ._models import ApplicationGatewayHeaderConfiguration # type: ignore + from ._models import ApplicationGatewayHttpListener # type: ignore + from ._models import ApplicationGatewayIPConfiguration # type: ignore + from ._models import ApplicationGatewayListResult # type: ignore + from ._models import ApplicationGatewayOnDemandProbe # type: ignore + from ._models import ApplicationGatewayPathRule # type: ignore + from ._models import ApplicationGatewayPrivateEndpointConnection # type: ignore + from ._models import ApplicationGatewayPrivateEndpointConnectionListResult # type: ignore + from ._models import ApplicationGatewayPrivateLinkConfiguration # type: ignore + from ._models import ApplicationGatewayPrivateLinkIpConfiguration # type: ignore + from ._models import ApplicationGatewayPrivateLinkResource # type: ignore + from ._models import ApplicationGatewayPrivateLinkResourceListResult # type: ignore + from ._models import ApplicationGatewayProbe # type: ignore + from ._models import ApplicationGatewayProbeHealthResponseMatch # type: ignore + from ._models import ApplicationGatewayRedirectConfiguration # type: ignore + from ._models import ApplicationGatewayRequestRoutingRule # type: ignore + from ._models import ApplicationGatewayRewriteRule # type: ignore + from ._models import ApplicationGatewayRewriteRuleActionSet # type: ignore + from ._models import ApplicationGatewayRewriteRuleCondition # type: ignore + from ._models import ApplicationGatewayRewriteRuleSet # type: ignore + from ._models import ApplicationGatewaySku # type: ignore + from ._models import ApplicationGatewaySslCertificate # type: ignore + from ._models import ApplicationGatewaySslPolicy # type: ignore + from ._models import ApplicationGatewaySslPredefinedPolicy # type: ignore + from ._models import ApplicationGatewaySslProfile # type: ignore + from ._models import ApplicationGatewayTrustedClientCertificate # type: ignore + from ._models import ApplicationGatewayTrustedRootCertificate # type: ignore + from ._models import ApplicationGatewayUrlConfiguration # type: ignore + from ._models import ApplicationGatewayUrlPathMap # type: ignore + from ._models import ApplicationGatewayWebApplicationFirewallConfiguration # type: ignore + from ._models import ApplicationRule # type: ignore + from ._models import ApplicationSecurityGroup # type: ignore + from ._models import ApplicationSecurityGroupListResult # type: ignore + from ._models import AuthorizationListResult # type: ignore + from ._models import AutoApprovedPrivateLinkService # type: ignore + from ._models import AutoApprovedPrivateLinkServicesResult # type: ignore + from ._models import Availability # type: ignore + from ._models import AvailableDelegation # type: ignore + from ._models import AvailableDelegationsResult # type: ignore + from ._models import AvailablePrivateEndpointType # type: ignore + from ._models import AvailablePrivateEndpointTypesResult # type: ignore + from ._models import AvailableProvidersList # type: ignore + from ._models import AvailableProvidersListCity # type: ignore + from ._models import AvailableProvidersListCountry # type: ignore + from ._models import AvailableProvidersListParameters # type: ignore + from ._models import AvailableProvidersListState # type: ignore + from ._models import AvailableServiceAlias # type: ignore + from ._models import AvailableServiceAliasesResult # type: ignore + from ._models import AzureAsyncOperationResult # type: ignore + from ._models import AzureFirewall # type: ignore + from ._models import AzureFirewallApplicationRule # type: ignore + from ._models import AzureFirewallApplicationRuleCollection # type: ignore + from ._models import AzureFirewallApplicationRuleProtocol # type: ignore + from ._models import AzureFirewallFqdnTag # type: ignore + from ._models import AzureFirewallFqdnTagListResult # type: ignore + from ._models import AzureFirewallIPConfiguration # type: ignore + from ._models import AzureFirewallIpGroups # type: ignore + from ._models import AzureFirewallListResult # type: ignore + from ._models import AzureFirewallNatRCAction # type: ignore + from ._models import AzureFirewallNatRule # type: ignore + from ._models import AzureFirewallNatRuleCollection # type: ignore + from ._models import AzureFirewallNetworkRule # type: ignore + from ._models import AzureFirewallNetworkRuleCollection # type: ignore + from ._models import AzureFirewallPublicIPAddress # type: ignore + from ._models import AzureFirewallRCAction # type: ignore + from ._models import AzureFirewallSku # type: ignore + from ._models import AzureReachabilityReport # type: ignore + from ._models import AzureReachabilityReportItem # type: ignore + from ._models import AzureReachabilityReportLatencyInfo # type: ignore + from ._models import AzureReachabilityReportLocation # type: ignore + from ._models import AzureReachabilityReportParameters # type: ignore + from ._models import AzureWebCategory # type: ignore + from ._models import AzureWebCategoryListResult # type: ignore + from ._models import BGPCommunity # type: ignore + from ._models import BackendAddressPool # type: ignore + from ._models import BastionActiveSession # type: ignore + from ._models import BastionActiveSessionListResult # type: ignore + from ._models import BastionHost # type: ignore + from ._models import BastionHostIPConfiguration # type: ignore + from ._models import BastionHostListResult # type: ignore + from ._models import BastionSessionDeleteResult # type: ignore + from ._models import BastionSessionState # type: ignore + from ._models import BastionShareableLink # type: ignore + from ._models import BastionShareableLinkListRequest # type: ignore + from ._models import BastionShareableLinkListResult # type: ignore + from ._models import BgpConnection # type: ignore + from ._models import BgpPeerStatus # type: ignore + from ._models import BgpPeerStatusListResult # type: ignore + from ._models import BgpServiceCommunity # type: ignore + from ._models import BgpServiceCommunityListResult # type: ignore + from ._models import BgpSettings # type: ignore + from ._models import BreakOutCategoryPolicies # type: ignore + from ._models import CheckPrivateLinkServiceVisibilityRequest # type: ignore + from ._models import CloudErrorBody # type: ignore + from ._models import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties # type: ignore + from ._models import ConnectionMonitor # type: ignore + from ._models import ConnectionMonitorDestination # type: ignore + from ._models import ConnectionMonitorEndpoint # type: ignore + from ._models import ConnectionMonitorEndpointFilter # type: ignore + from ._models import ConnectionMonitorEndpointFilterItem # type: ignore + from ._models import ConnectionMonitorEndpointScope # type: ignore + from ._models import ConnectionMonitorEndpointScopeItem # type: ignore + from ._models import ConnectionMonitorHttpConfiguration # type: ignore + from ._models import ConnectionMonitorIcmpConfiguration # type: ignore + from ._models import ConnectionMonitorListResult # type: ignore + from ._models import ConnectionMonitorOutput # type: ignore + from ._models import ConnectionMonitorParameters # type: ignore + from ._models import ConnectionMonitorQueryResult # type: ignore + from ._models import ConnectionMonitorResult # type: ignore + from ._models import ConnectionMonitorResultProperties # type: ignore + from ._models import ConnectionMonitorSource # type: ignore + from ._models import ConnectionMonitorSuccessThreshold # type: ignore + from ._models import ConnectionMonitorTcpConfiguration # type: ignore + from ._models import ConnectionMonitorTestConfiguration # type: ignore + from ._models import ConnectionMonitorTestGroup # type: ignore + from ._models import ConnectionMonitorWorkspaceSettings # type: ignore + from ._models import ConnectionResetSharedKey # type: ignore + from ._models import ConnectionSharedKey # type: ignore + from ._models import ConnectionStateSnapshot # type: ignore + from ._models import ConnectivityDestination # type: ignore + from ._models import ConnectivityHop # type: ignore + from ._models import ConnectivityInformation # type: ignore + from ._models import ConnectivityIssue # type: ignore + from ._models import ConnectivityParameters # type: ignore + from ._models import ConnectivitySource # type: ignore + from ._models import Container # type: ignore + from ._models import ContainerNetworkInterface # type: ignore + from ._models import ContainerNetworkInterfaceConfiguration # type: ignore + from ._models import ContainerNetworkInterfaceIpConfiguration # type: ignore + from ._models import CustomDnsConfigPropertiesFormat # type: ignore + from ._models import CustomIpPrefix # type: ignore + from ._models import CustomIpPrefixListResult # type: ignore + from ._models import DdosCustomPolicy # type: ignore + from ._models import DdosProtectionPlan # type: ignore + from ._models import DdosProtectionPlanListResult # type: ignore + from ._models import DdosSettings # type: ignore + from ._models import Delegation # type: ignore + from ._models import DeviceProperties # type: ignore + from ._models import DhcpOptions # type: ignore + from ._models import Dimension # type: ignore + from ._models import DnsNameAvailabilityResult # type: ignore + from ._models import DnsSettings # type: ignore + from ._models import DscpConfiguration # type: ignore + from ._models import DscpConfigurationListResult # type: ignore + from ._models import EffectiveNetworkSecurityGroup # type: ignore + from ._models import EffectiveNetworkSecurityGroupAssociation # type: ignore + from ._models import EffectiveNetworkSecurityGroupListResult # type: ignore + from ._models import EffectiveNetworkSecurityRule # type: ignore + from ._models import EffectiveRoute # type: ignore + from ._models import EffectiveRouteListResult # type: ignore + from ._models import EffectiveRoutesParameters # type: ignore + from ._models import EndpointServiceResult # type: ignore + from ._models import EndpointServicesListResult # type: ignore + from ._models import Error # type: ignore + from ._models import ErrorDetails # type: ignore + from ._models import ErrorResponse # type: ignore + from ._models import EvaluatedNetworkSecurityGroup # type: ignore + from ._models import ExpressRouteCircuit # type: ignore + from ._models import ExpressRouteCircuitArpTable # type: ignore + from ._models import ExpressRouteCircuitAuthorization # type: ignore + from ._models import ExpressRouteCircuitConnection # type: ignore + from ._models import ExpressRouteCircuitConnectionListResult # type: ignore + from ._models import ExpressRouteCircuitListResult # type: ignore + from ._models import ExpressRouteCircuitPeering # type: ignore + from ._models import ExpressRouteCircuitPeeringConfig # type: ignore + from ._models import ExpressRouteCircuitPeeringId # type: ignore + from ._models import ExpressRouteCircuitPeeringListResult # type: ignore + from ._models import ExpressRouteCircuitReference # type: ignore + from ._models import ExpressRouteCircuitRoutesTable # type: ignore + from ._models import ExpressRouteCircuitRoutesTableSummary # type: ignore + from ._models import ExpressRouteCircuitServiceProviderProperties # type: ignore + from ._models import ExpressRouteCircuitSku # type: ignore + from ._models import ExpressRouteCircuitStats # type: ignore + from ._models import ExpressRouteCircuitsArpTableListResult # type: ignore + from ._models import ExpressRouteCircuitsRoutesTableListResult # type: ignore + from ._models import ExpressRouteCircuitsRoutesTableSummaryListResult # type: ignore + from ._models import ExpressRouteConnection # type: ignore + from ._models import ExpressRouteConnectionId # type: ignore + from ._models import ExpressRouteConnectionList # type: ignore + from ._models import ExpressRouteCrossConnection # type: ignore + from ._models import ExpressRouteCrossConnectionListResult # type: ignore + from ._models import ExpressRouteCrossConnectionPeering # type: ignore + from ._models import ExpressRouteCrossConnectionPeeringList # type: ignore + from ._models import ExpressRouteCrossConnectionRoutesTableSummary # type: ignore + from ._models import ExpressRouteCrossConnectionsRoutesTableSummaryListResult # type: ignore + from ._models import ExpressRouteGateway # type: ignore + from ._models import ExpressRouteGatewayList # type: ignore + from ._models import ExpressRouteGatewayPropertiesAutoScaleConfiguration # type: ignore + from ._models import ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds # type: ignore + from ._models import ExpressRouteLink # type: ignore + from ._models import ExpressRouteLinkListResult # type: ignore + from ._models import ExpressRouteLinkMacSecConfig # type: ignore + from ._models import ExpressRoutePort # type: ignore + from ._models import ExpressRoutePortListResult # type: ignore + from ._models import ExpressRoutePortsLocation # type: ignore + from ._models import ExpressRoutePortsLocationBandwidths # type: ignore + from ._models import ExpressRoutePortsLocationListResult # type: ignore + from ._models import ExpressRouteServiceProvider # type: ignore + from ._models import ExpressRouteServiceProviderBandwidthsOffered # type: ignore + from ._models import ExpressRouteServiceProviderListResult # type: ignore + from ._models import ExtendedLocation # type: ignore + from ._models import FirewallPolicy # type: ignore + from ._models import FirewallPolicyCertificateAuthority # type: ignore + from ._models import FirewallPolicyFilterRuleCollection # type: ignore + from ._models import FirewallPolicyFilterRuleCollectionAction # type: ignore + from ._models import FirewallPolicyIntrusionDetection # type: ignore + from ._models import FirewallPolicyIntrusionDetectionBypassTrafficSpecifications # type: ignore + from ._models import FirewallPolicyIntrusionDetectionConfiguration # type: ignore + from ._models import FirewallPolicyIntrusionDetectionSignatureSpecification # type: ignore + from ._models import FirewallPolicyListResult # type: ignore + from ._models import FirewallPolicyNatRuleCollection # type: ignore + from ._models import FirewallPolicyNatRuleCollectionAction # type: ignore + from ._models import FirewallPolicyRule # type: ignore + from ._models import FirewallPolicyRuleApplicationProtocol # type: ignore + from ._models import FirewallPolicyRuleCollection # type: ignore + from ._models import FirewallPolicyRuleCollectionGroup # type: ignore + from ._models import FirewallPolicyRuleCollectionGroupListResult # type: ignore + from ._models import FirewallPolicySku # type: ignore + from ._models import FirewallPolicyThreatIntelWhitelist # type: ignore + from ._models import FirewallPolicyTransportSecurity # type: ignore + from ._models import FlowLog # type: ignore + from ._models import FlowLogFormatParameters # type: ignore + from ._models import FlowLogInformation # type: ignore + from ._models import FlowLogListResult # type: ignore + from ._models import FlowLogStatusParameters # type: ignore + from ._models import FrontendIPConfiguration # type: ignore + from ._models import GatewayRoute # type: ignore + from ._models import GatewayRouteListResult # type: ignore + from ._models import GenerateExpressRoutePortsLOARequest # type: ignore + from ._models import GenerateExpressRoutePortsLOAResult # type: ignore + from ._models import GetVpnSitesConfigurationRequest # type: ignore + from ._models import HTTPConfiguration # type: ignore + from ._models import HTTPHeader # type: ignore + from ._models import HopLink # type: ignore + from ._models import HubIPAddresses # type: ignore + from ._models import HubIpConfiguration # type: ignore + from ._models import HubPublicIPAddresses # type: ignore + from ._models import HubRoute # type: ignore + from ._models import HubRouteTable # type: ignore + from ._models import HubVirtualNetworkConnection # type: ignore + from ._models import IPAddressAvailabilityResult # type: ignore + from ._models import IPConfiguration # type: ignore + from ._models import IPConfigurationBgpPeeringAddress # type: ignore + from ._models import IPConfigurationProfile # type: ignore + from ._models import InboundNatPool # type: ignore + from ._models import InboundNatRule # type: ignore + from ._models import InboundNatRuleListResult # type: ignore + from ._models import InboundSecurityRule # type: ignore + from ._models import InboundSecurityRules # type: ignore + from ._models import IpAllocation # type: ignore + from ._models import IpAllocationListResult # type: ignore + from ._models import IpGroup # type: ignore + from ._models import IpGroupListResult # type: ignore + from ._models import IpTag # type: ignore + from ._models import IpsecPolicy # type: ignore + from ._models import Ipv6CircuitConnectionConfig # type: ignore + from ._models import Ipv6ExpressRouteCircuitPeeringConfig # type: ignore + from ._models import ListHubRouteTablesResult # type: ignore + from ._models import ListHubVirtualNetworkConnectionsResult # type: ignore + from ._models import ListP2SVpnGatewaysResult # type: ignore + from ._models import ListVirtualHubBgpConnectionResults # type: ignore + from ._models import ListVirtualHubIpConfigurationResults # type: ignore + from ._models import ListVirtualHubRouteTableV2SResult # type: ignore + from ._models import ListVirtualHubsResult # type: ignore + from ._models import ListVirtualWANsResult # type: ignore + from ._models import ListVpnConnectionsResult # type: ignore + from ._models import ListVpnGatewayNatRulesResult # type: ignore + from ._models import ListVpnGatewaysResult # type: ignore + from ._models import ListVpnServerConfigurationsResult # type: ignore + from ._models import ListVpnSiteLinkConnectionsResult # type: ignore + from ._models import ListVpnSiteLinksResult # type: ignore + from ._models import ListVpnSitesResult # type: ignore + from ._models import LoadBalancer # type: ignore + from ._models import LoadBalancerBackendAddress # type: ignore + from ._models import LoadBalancerBackendAddressPoolListResult # type: ignore + from ._models import LoadBalancerFrontendIPConfigurationListResult # type: ignore + from ._models import LoadBalancerListResult # type: ignore + from ._models import LoadBalancerLoadBalancingRuleListResult # type: ignore + from ._models import LoadBalancerOutboundRuleListResult # type: ignore + from ._models import LoadBalancerProbeListResult # type: ignore + from ._models import LoadBalancerSku # type: ignore + from ._models import LoadBalancingRule # type: ignore + from ._models import LocalNetworkGateway # type: ignore + from ._models import LocalNetworkGatewayListResult # type: ignore + from ._models import LogSpecification # type: ignore + from ._models import ManagedRuleGroupOverride # type: ignore + from ._models import ManagedRuleOverride # type: ignore + from ._models import ManagedRuleSet # type: ignore + from ._models import ManagedRulesDefinition # type: ignore + from ._models import ManagedServiceIdentity # type: ignore + from ._models import MatchCondition # type: ignore + from ._models import MatchVariable # type: ignore + from ._models import MatchedRule # type: ignore + from ._models import MetricSpecification # type: ignore + from ._models import NatGateway # type: ignore + from ._models import NatGatewayListResult # type: ignore + from ._models import NatGatewaySku # type: ignore + from ._models import NatRule # type: ignore + from ._models import NetworkConfigurationDiagnosticParameters # type: ignore + from ._models import NetworkConfigurationDiagnosticProfile # type: ignore + from ._models import NetworkConfigurationDiagnosticResponse # type: ignore + from ._models import NetworkConfigurationDiagnosticResult # type: ignore + from ._models import NetworkIntentPolicy # type: ignore + from ._models import NetworkIntentPolicyConfiguration # type: ignore + from ._models import NetworkInterface # type: ignore + from ._models import NetworkInterfaceAssociation # type: ignore + from ._models import NetworkInterfaceDnsSettings # type: ignore + from ._models import NetworkInterfaceIPConfiguration # type: ignore + from ._models import NetworkInterfaceIPConfigurationListResult # type: ignore + from ._models import NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties # type: ignore + from ._models import NetworkInterfaceListResult # type: ignore + from ._models import NetworkInterfaceLoadBalancerListResult # type: ignore + from ._models import NetworkInterfaceTapConfiguration # type: ignore + from ._models import NetworkInterfaceTapConfigurationListResult # type: ignore + from ._models import NetworkProfile # type: ignore + from ._models import NetworkProfileListResult # type: ignore + from ._models import NetworkRule # type: ignore + from ._models import NetworkSecurityGroup # type: ignore + from ._models import NetworkSecurityGroupListResult # type: ignore + from ._models import NetworkSecurityGroupResult # type: ignore + from ._models import NetworkSecurityRulesEvaluationResult # type: ignore + from ._models import NetworkVirtualAppliance # type: ignore + from ._models import NetworkVirtualApplianceListResult # type: ignore + from ._models import NetworkVirtualApplianceSiteListResult # type: ignore + from ._models import NetworkVirtualApplianceSku # type: ignore + from ._models import NetworkVirtualApplianceSkuInstances # type: ignore + from ._models import NetworkVirtualApplianceSkuListResult # type: ignore + from ._models import NetworkWatcher # type: ignore + from ._models import NetworkWatcherListResult # type: ignore + from ._models import NextHopParameters # type: ignore + from ._models import NextHopResult # type: ignore + from ._models import O365BreakOutCategoryPolicies # type: ignore + from ._models import O365PolicyProperties # type: ignore + from ._models import Office365PolicyProperties # type: ignore + from ._models import Operation # type: ignore + from ._models import OperationDisplay # type: ignore + from ._models import OperationListResult # type: ignore + from ._models import OperationPropertiesFormatServiceSpecification # type: ignore + from ._models import OutboundRule # type: ignore + from ._models import OwaspCrsExclusionEntry # type: ignore + from ._models import P2SConnectionConfiguration # type: ignore + from ._models import P2SVpnConnectionHealth # type: ignore + from ._models import P2SVpnConnectionHealthRequest # type: ignore + from ._models import P2SVpnConnectionRequest # type: ignore + from ._models import P2SVpnGateway # type: ignore + from ._models import P2SVpnProfileParameters # type: ignore + from ._models import PacketCapture # type: ignore + from ._models import PacketCaptureFilter # type: ignore + from ._models import PacketCaptureListResult # type: ignore + from ._models import PacketCaptureParameters # type: ignore + from ._models import PacketCaptureQueryStatusResult # type: ignore + from ._models import PacketCaptureResult # type: ignore + from ._models import PacketCaptureResultProperties # type: ignore + from ._models import PacketCaptureStorageLocation # type: ignore + from ._models import PatchRouteFilter # type: ignore + from ._models import PatchRouteFilterRule # type: ignore + from ._models import PeerExpressRouteCircuitConnection # type: ignore + from ._models import PeerExpressRouteCircuitConnectionListResult # type: ignore + from ._models import PeerRoute # type: ignore + from ._models import PeerRouteList # type: ignore + from ._models import PolicySettings # type: ignore + from ._models import PrepareNetworkPoliciesRequest # type: ignore + from ._models import PrivateDnsZoneConfig # type: ignore + from ._models import PrivateDnsZoneGroup # type: ignore + from ._models import PrivateDnsZoneGroupListResult # type: ignore + from ._models import PrivateEndpoint # type: ignore + from ._models import PrivateEndpointConnection # type: ignore + from ._models import PrivateEndpointConnectionListResult # type: ignore + from ._models import PrivateEndpointListResult # type: ignore + from ._models import PrivateLinkService # type: ignore + from ._models import PrivateLinkServiceConnection # type: ignore + from ._models import PrivateLinkServiceConnectionState # type: ignore + from ._models import PrivateLinkServiceIpConfiguration # type: ignore + from ._models import PrivateLinkServiceListResult # type: ignore + from ._models import PrivateLinkServicePropertiesAutoApproval # type: ignore + from ._models import PrivateLinkServicePropertiesVisibility # type: ignore + from ._models import PrivateLinkServiceVisibility # type: ignore + from ._models import Probe # type: ignore + from ._models import PropagatedRouteTable # type: ignore + from ._models import ProtocolConfiguration # type: ignore + from ._models import ProtocolCustomSettingsFormat # type: ignore + from ._models import PublicIPAddress # type: ignore + from ._models import PublicIPAddressDnsSettings # type: ignore + from ._models import PublicIPAddressListResult # type: ignore + from ._models import PublicIPAddressSku # type: ignore + from ._models import PublicIPPrefix # type: ignore + from ._models import PublicIPPrefixListResult # type: ignore + from ._models import PublicIPPrefixSku # type: ignore + from ._models import QosIpRange # type: ignore + from ._models import QosPortRange # type: ignore + from ._models import QueryTroubleshootingParameters # type: ignore + from ._models import RadiusServer # type: ignore + from ._models import RecordSet # type: ignore + from ._models import ReferencedPublicIpAddress # type: ignore + from ._models import Resource # type: ignore + from ._models import ResourceNavigationLink # type: ignore + from ._models import ResourceNavigationLinksListResult # type: ignore + from ._models import ResourceSet # type: ignore + from ._models import RetentionPolicyParameters # type: ignore + from ._models import Route # type: ignore + from ._models import RouteFilter # type: ignore + from ._models import RouteFilterListResult # type: ignore + from ._models import RouteFilterRule # type: ignore + from ._models import RouteFilterRuleListResult # type: ignore + from ._models import RouteListResult # type: ignore + from ._models import RouteTable # type: ignore + from ._models import RouteTableListResult # type: ignore + from ._models import RoutingConfiguration # type: ignore + from ._models import SecurityGroupNetworkInterface # type: ignore + from ._models import SecurityGroupViewParameters # type: ignore + from ._models import SecurityGroupViewResult # type: ignore + from ._models import SecurityPartnerProvider # type: ignore + from ._models import SecurityPartnerProviderListResult # type: ignore + from ._models import SecurityRule # type: ignore + from ._models import SecurityRuleAssociations # type: ignore + from ._models import SecurityRuleListResult # type: ignore + from ._models import ServiceAssociationLink # type: ignore + from ._models import ServiceAssociationLinksListResult # type: ignore + from ._models import ServiceEndpointPolicy # type: ignore + from ._models import ServiceEndpointPolicyDefinition # type: ignore + from ._models import ServiceEndpointPolicyDefinitionListResult # type: ignore + from ._models import ServiceEndpointPolicyListResult # type: ignore + from ._models import ServiceEndpointPropertiesFormat # type: ignore + from ._models import ServiceTagInformation # type: ignore + from ._models import ServiceTagInformationPropertiesFormat # type: ignore + from ._models import ServiceTagsListResult # type: ignore + from ._models import SessionIds # type: ignore + from ._models import StaticRoute # type: ignore + from ._models import SubResource # type: ignore + from ._models import Subnet # type: ignore + from ._models import SubnetAssociation # type: ignore + from ._models import SubnetListResult # type: ignore + from ._models import TagsObject # type: ignore + from ._models import Topology # type: ignore + from ._models import TopologyAssociation # type: ignore + from ._models import TopologyParameters # type: ignore + from ._models import TopologyResource # type: ignore + from ._models import TrafficAnalyticsConfigurationProperties # type: ignore + from ._models import TrafficAnalyticsProperties # type: ignore + from ._models import TrafficSelectorPolicy # type: ignore + from ._models import TroubleshootingDetails # type: ignore + from ._models import TroubleshootingParameters # type: ignore + from ._models import TroubleshootingRecommendedActions # type: ignore + from ._models import TroubleshootingResult # type: ignore + from ._models import TunnelConnectionHealth # type: ignore + from ._models import UnprepareNetworkPoliciesRequest # type: ignore + from ._models import Usage # type: ignore + from ._models import UsageName # type: ignore + from ._models import UsagesListResult # type: ignore + from ._models import VM # type: ignore + from ._models import VerificationIPFlowParameters # type: ignore + from ._models import VerificationIPFlowResult # type: ignore + from ._models import VirtualApplianceNicProperties # type: ignore + from ._models import VirtualApplianceSite # type: ignore + from ._models import VirtualApplianceSkuProperties # type: ignore + from ._models import VirtualHub # type: ignore + from ._models import VirtualHubEffectiveRoute # type: ignore + from ._models import VirtualHubEffectiveRouteList # type: ignore + from ._models import VirtualHubId # type: ignore + from ._models import VirtualHubRoute # type: ignore + from ._models import VirtualHubRouteTable # type: ignore + from ._models import VirtualHubRouteTableV2 # type: ignore + from ._models import VirtualHubRouteV2 # type: ignore + from ._models import VirtualNetwork # type: ignore + from ._models import VirtualNetworkBgpCommunities # type: ignore + from ._models import VirtualNetworkConnectionGatewayReference # type: ignore + from ._models import VirtualNetworkGateway # type: ignore + from ._models import VirtualNetworkGatewayConnection # type: ignore + from ._models import VirtualNetworkGatewayConnectionListEntity # type: ignore + from ._models import VirtualNetworkGatewayConnectionListResult # type: ignore + from ._models import VirtualNetworkGatewayIPConfiguration # type: ignore + from ._models import VirtualNetworkGatewayListConnectionsResult # type: ignore + from ._models import VirtualNetworkGatewayListResult # type: ignore + from ._models import VirtualNetworkGatewaySku # type: ignore + from ._models import VirtualNetworkListResult # type: ignore + from ._models import VirtualNetworkListUsageResult # type: ignore + from ._models import VirtualNetworkPeering # type: ignore + from ._models import VirtualNetworkPeeringListResult # type: ignore + from ._models import VirtualNetworkTap # type: ignore + from ._models import VirtualNetworkTapListResult # type: ignore + from ._models import VirtualNetworkUsage # type: ignore + from ._models import VirtualNetworkUsageName # type: ignore + from ._models import VirtualRouter # type: ignore + from ._models import VirtualRouterListResult # type: ignore + from ._models import VirtualRouterPeering # type: ignore + from ._models import VirtualRouterPeeringListResult # type: ignore + from ._models import VirtualWAN # type: ignore + from ._models import VirtualWanSecurityProvider # type: ignore + from ._models import VirtualWanSecurityProviders # type: ignore + from ._models import VirtualWanVpnProfileParameters # type: ignore + from ._models import VnetRoute # type: ignore + from ._models import VpnClientConfiguration # type: ignore + from ._models import VpnClientConnectionHealth # type: ignore + from ._models import VpnClientConnectionHealthDetail # type: ignore + from ._models import VpnClientConnectionHealthDetailListResult # type: ignore + from ._models import VpnClientIPsecParameters # type: ignore + from ._models import VpnClientParameters # type: ignore + from ._models import VpnClientRevokedCertificate # type: ignore + from ._models import VpnClientRootCertificate # type: ignore + from ._models import VpnConnection # type: ignore + from ._models import VpnConnectionPacketCaptureStartParameters # type: ignore + from ._models import VpnConnectionPacketCaptureStopParameters # type: ignore + from ._models import VpnDeviceScriptParameters # type: ignore + from ._models import VpnGateway # type: ignore + from ._models import VpnGatewayIpConfiguration # type: ignore + from ._models import VpnGatewayNatRule # type: ignore + from ._models import VpnGatewayPacketCaptureStartParameters # type: ignore + from ._models import VpnGatewayPacketCaptureStopParameters # type: ignore + from ._models import VpnLinkBgpSettings # type: ignore + from ._models import VpnLinkProviderProperties # type: ignore + from ._models import VpnNatRuleMapping # type: ignore + from ._models import VpnPacketCaptureStartParameters # type: ignore + from ._models import VpnPacketCaptureStopParameters # type: ignore + from ._models import VpnProfileResponse # type: ignore + from ._models import VpnServerConfigRadiusClientRootCertificate # type: ignore + from ._models import VpnServerConfigRadiusServerRootCertificate # type: ignore + from ._models import VpnServerConfigVpnClientRevokedCertificate # type: ignore + from ._models import VpnServerConfigVpnClientRootCertificate # type: ignore + from ._models import VpnServerConfiguration # type: ignore + from ._models import VpnServerConfigurationsResponse # type: ignore + from ._models import VpnSite # type: ignore + from ._models import VpnSiteId # type: ignore + from ._models import VpnSiteLink # type: ignore + from ._models import VpnSiteLinkConnection # type: ignore + from ._models import WebApplicationFirewallCustomRule # type: ignore + from ._models import WebApplicationFirewallPolicy # type: ignore + from ._models import WebApplicationFirewallPolicyListResult # type: ignore + +from ._network_management_client_enums import ( + Access, + ApplicationGatewayBackendHealthServerHealth, + ApplicationGatewayCookieBasedAffinity, + ApplicationGatewayCustomErrorStatusCode, + ApplicationGatewayFirewallMode, + ApplicationGatewayOperationalState, + ApplicationGatewayProtocol, + ApplicationGatewayRedirectType, + ApplicationGatewayRequestRoutingRuleType, + ApplicationGatewaySkuName, + ApplicationGatewaySslCipherSuite, + ApplicationGatewaySslPolicyName, + ApplicationGatewaySslPolicyType, + ApplicationGatewaySslProtocol, + ApplicationGatewayTier, + AssociationType, + AuthenticationMethod, + AuthorizationUseStatus, + AzureFirewallApplicationRuleProtocolType, + AzureFirewallNatRCActionType, + AzureFirewallNetworkRuleProtocol, + AzureFirewallRCActionType, + AzureFirewallSkuName, + AzureFirewallSkuTier, + AzureFirewallThreatIntelMode, + BastionConnectProtocol, + BgpPeerState, + CircuitConnectionStatus, + CommissionedState, + ConnectionMonitorEndpointFilterItemType, + ConnectionMonitorEndpointFilterType, + ConnectionMonitorSourceStatus, + ConnectionMonitorTestConfigurationProtocol, + ConnectionMonitorType, + ConnectionState, + ConnectionStatus, + CoverageLevel, + DdosCustomPolicyProtocol, + DdosCustomPolicyTriggerSensitivityOverride, + DdosSettingsProtectionCoverage, + DestinationPortBehavior, + DhGroup, + Direction, + EffectiveRouteSource, + EffectiveRouteState, + EffectiveSecurityRuleProtocol, + EndpointType, + EvaluationState, + ExpressRouteCircuitPeeringAdvertisedPublicPrefixState, + ExpressRouteCircuitPeeringState, + ExpressRouteCircuitSkuFamily, + ExpressRouteCircuitSkuTier, + ExpressRouteLinkAdminState, + ExpressRouteLinkConnectorType, + ExpressRouteLinkMacSecCipher, + ExpressRouteLinkMacSecSciState, + ExpressRoutePeeringState, + ExpressRoutePeeringType, + ExpressRoutePortsEncapsulation, + ExtendedLocationTypes, + FirewallPolicyFilterRuleCollectionActionType, + FirewallPolicyIntrusionDetectionProtocol, + FirewallPolicyIntrusionDetectionStateType, + FirewallPolicyNatRuleCollectionActionType, + FirewallPolicyRuleApplicationProtocolType, + FirewallPolicyRuleCollectionType, + FirewallPolicyRuleNetworkProtocol, + FirewallPolicyRuleType, + FirewallPolicySkuTier, + FlowLogFormatType, + HTTPConfigurationMethod, + HTTPMethod, + HubBgpConnectionStatus, + HubVirtualNetworkConnectionStatus, + IPAllocationMethod, + IPVersion, + IkeEncryption, + IkeIntegrity, + InboundSecurityRulesProtocol, + IpAllocationType, + IpFlowProtocol, + IpsecEncryption, + IpsecIntegrity, + IssueType, + LoadBalancerOutboundRuleProtocol, + LoadBalancerSkuName, + LoadBalancerSkuTier, + LoadDistribution, + ManagedRuleEnabledState, + NatGatewaySkuName, + NetworkOperationStatus, + NextHopType, + OfficeTrafficCategory, + Origin, + OutputType, + OwaspCrsExclusionEntryMatchVariable, + OwaspCrsExclusionEntrySelectorMatchOperator, + PcError, + PcProtocol, + PcStatus, + PfsGroup, + PreferredIPVersion, + ProbeProtocol, + ProcessorArchitecture, + Protocol, + ProtocolType, + ProvisioningState, + PublicIPAddressSkuName, + PublicIPAddressSkuTier, + PublicIPPrefixSkuName, + PublicIPPrefixSkuTier, + ResourceIdentityType, + RouteFilterRuleType, + RouteNextHopType, + RoutingState, + SecurityPartnerProviderConnectionStatus, + SecurityProviderName, + SecurityRuleAccess, + SecurityRuleDirection, + SecurityRuleProtocol, + ServiceProviderProvisioningState, + Severity, + TransportProtocol, + TunnelConnectionStatus, + UsageUnit, + VerbosityLevel, + VirtualNetworkGatewayConnectionMode, + VirtualNetworkGatewayConnectionProtocol, + VirtualNetworkGatewayConnectionStatus, + VirtualNetworkGatewayConnectionType, + VirtualNetworkGatewaySkuName, + VirtualNetworkGatewaySkuTier, + VirtualNetworkGatewayType, + VirtualNetworkPeeringState, + VirtualWanSecurityProviderType, + VpnAuthenticationType, + VpnClientProtocol, + VpnConnectionStatus, + VpnGatewayGeneration, + VpnGatewayTunnelingProtocol, + VpnLinkConnectionMode, + VpnNatRuleMode, + VpnNatRuleType, + VpnType, + WebApplicationFirewallAction, + WebApplicationFirewallEnabledState, + WebApplicationFirewallMatchVariable, + WebApplicationFirewallMode, + WebApplicationFirewallOperator, + WebApplicationFirewallPolicyResourceState, + WebApplicationFirewallRuleType, + WebApplicationFirewallTransform, +) + +__all__ = [ + 'AadAuthenticationParameters', + 'AddressSpace', + 'ApplicationGateway', + 'ApplicationGatewayAuthenticationCertificate', + 'ApplicationGatewayAutoscaleConfiguration', + 'ApplicationGatewayAvailableSslOptions', + 'ApplicationGatewayAvailableSslPredefinedPolicies', + 'ApplicationGatewayAvailableWafRuleSetsResult', + 'ApplicationGatewayBackendAddress', + 'ApplicationGatewayBackendAddressPool', + 'ApplicationGatewayBackendHealth', + 'ApplicationGatewayBackendHealthHttpSettings', + 'ApplicationGatewayBackendHealthOnDemand', + 'ApplicationGatewayBackendHealthPool', + 'ApplicationGatewayBackendHealthServer', + 'ApplicationGatewayBackendHttpSettings', + 'ApplicationGatewayClientAuthConfiguration', + 'ApplicationGatewayConnectionDraining', + 'ApplicationGatewayCustomError', + 'ApplicationGatewayFirewallDisabledRuleGroup', + 'ApplicationGatewayFirewallExclusion', + 'ApplicationGatewayFirewallRule', + 'ApplicationGatewayFirewallRuleGroup', + 'ApplicationGatewayFirewallRuleSet', + 'ApplicationGatewayFrontendIPConfiguration', + 'ApplicationGatewayFrontendPort', + 'ApplicationGatewayHeaderConfiguration', + 'ApplicationGatewayHttpListener', + 'ApplicationGatewayIPConfiguration', + 'ApplicationGatewayListResult', + 'ApplicationGatewayOnDemandProbe', + 'ApplicationGatewayPathRule', + 'ApplicationGatewayPrivateEndpointConnection', + 'ApplicationGatewayPrivateEndpointConnectionListResult', + 'ApplicationGatewayPrivateLinkConfiguration', + 'ApplicationGatewayPrivateLinkIpConfiguration', + 'ApplicationGatewayPrivateLinkResource', + 'ApplicationGatewayPrivateLinkResourceListResult', + 'ApplicationGatewayProbe', + 'ApplicationGatewayProbeHealthResponseMatch', + 'ApplicationGatewayRedirectConfiguration', + 'ApplicationGatewayRequestRoutingRule', + 'ApplicationGatewayRewriteRule', + 'ApplicationGatewayRewriteRuleActionSet', + 'ApplicationGatewayRewriteRuleCondition', + 'ApplicationGatewayRewriteRuleSet', + 'ApplicationGatewaySku', + 'ApplicationGatewaySslCertificate', + 'ApplicationGatewaySslPolicy', + 'ApplicationGatewaySslPredefinedPolicy', + 'ApplicationGatewaySslProfile', + 'ApplicationGatewayTrustedClientCertificate', + 'ApplicationGatewayTrustedRootCertificate', + 'ApplicationGatewayUrlConfiguration', + 'ApplicationGatewayUrlPathMap', + 'ApplicationGatewayWebApplicationFirewallConfiguration', + 'ApplicationRule', + 'ApplicationSecurityGroup', + 'ApplicationSecurityGroupListResult', + 'AuthorizationListResult', + 'AutoApprovedPrivateLinkService', + 'AutoApprovedPrivateLinkServicesResult', + 'Availability', + 'AvailableDelegation', + 'AvailableDelegationsResult', + 'AvailablePrivateEndpointType', + 'AvailablePrivateEndpointTypesResult', + 'AvailableProvidersList', + 'AvailableProvidersListCity', + 'AvailableProvidersListCountry', + 'AvailableProvidersListParameters', + 'AvailableProvidersListState', + 'AvailableServiceAlias', + 'AvailableServiceAliasesResult', + 'AzureAsyncOperationResult', + 'AzureFirewall', + 'AzureFirewallApplicationRule', + 'AzureFirewallApplicationRuleCollection', + 'AzureFirewallApplicationRuleProtocol', + 'AzureFirewallFqdnTag', + 'AzureFirewallFqdnTagListResult', + 'AzureFirewallIPConfiguration', + 'AzureFirewallIpGroups', + 'AzureFirewallListResult', + 'AzureFirewallNatRCAction', + 'AzureFirewallNatRule', + 'AzureFirewallNatRuleCollection', + 'AzureFirewallNetworkRule', + 'AzureFirewallNetworkRuleCollection', + 'AzureFirewallPublicIPAddress', + 'AzureFirewallRCAction', + 'AzureFirewallSku', + 'AzureReachabilityReport', + 'AzureReachabilityReportItem', + 'AzureReachabilityReportLatencyInfo', + 'AzureReachabilityReportLocation', + 'AzureReachabilityReportParameters', + 'AzureWebCategory', + 'AzureWebCategoryListResult', + 'BGPCommunity', + 'BackendAddressPool', + 'BastionActiveSession', + 'BastionActiveSessionListResult', + 'BastionHost', + 'BastionHostIPConfiguration', + 'BastionHostListResult', + 'BastionSessionDeleteResult', + 'BastionSessionState', + 'BastionShareableLink', + 'BastionShareableLinkListRequest', + 'BastionShareableLinkListResult', + 'BgpConnection', + 'BgpPeerStatus', + 'BgpPeerStatusListResult', + 'BgpServiceCommunity', + 'BgpServiceCommunityListResult', + 'BgpSettings', + 'BreakOutCategoryPolicies', + 'CheckPrivateLinkServiceVisibilityRequest', + 'CloudErrorBody', + 'Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties', + 'ConnectionMonitor', + 'ConnectionMonitorDestination', + 'ConnectionMonitorEndpoint', + 'ConnectionMonitorEndpointFilter', + 'ConnectionMonitorEndpointFilterItem', + 'ConnectionMonitorEndpointScope', + 'ConnectionMonitorEndpointScopeItem', + 'ConnectionMonitorHttpConfiguration', + 'ConnectionMonitorIcmpConfiguration', + 'ConnectionMonitorListResult', + 'ConnectionMonitorOutput', + 'ConnectionMonitorParameters', + 'ConnectionMonitorQueryResult', + 'ConnectionMonitorResult', + 'ConnectionMonitorResultProperties', + 'ConnectionMonitorSource', + 'ConnectionMonitorSuccessThreshold', + 'ConnectionMonitorTcpConfiguration', + 'ConnectionMonitorTestConfiguration', + 'ConnectionMonitorTestGroup', + 'ConnectionMonitorWorkspaceSettings', + 'ConnectionResetSharedKey', + 'ConnectionSharedKey', + 'ConnectionStateSnapshot', + 'ConnectivityDestination', + 'ConnectivityHop', + 'ConnectivityInformation', + 'ConnectivityIssue', + 'ConnectivityParameters', + 'ConnectivitySource', + 'Container', + 'ContainerNetworkInterface', + 'ContainerNetworkInterfaceConfiguration', + 'ContainerNetworkInterfaceIpConfiguration', + 'CustomDnsConfigPropertiesFormat', + 'CustomIpPrefix', + 'CustomIpPrefixListResult', + 'DdosCustomPolicy', + 'DdosProtectionPlan', + 'DdosProtectionPlanListResult', + 'DdosSettings', + 'Delegation', + 'DeviceProperties', + 'DhcpOptions', + 'Dimension', + 'DnsNameAvailabilityResult', + 'DnsSettings', + 'DscpConfiguration', + 'DscpConfigurationListResult', + 'EffectiveNetworkSecurityGroup', + 'EffectiveNetworkSecurityGroupAssociation', + 'EffectiveNetworkSecurityGroupListResult', + 'EffectiveNetworkSecurityRule', + 'EffectiveRoute', + 'EffectiveRouteListResult', + 'EffectiveRoutesParameters', + 'EndpointServiceResult', + 'EndpointServicesListResult', + 'Error', + 'ErrorDetails', + 'ErrorResponse', + 'EvaluatedNetworkSecurityGroup', + 'ExpressRouteCircuit', + 'ExpressRouteCircuitArpTable', + 'ExpressRouteCircuitAuthorization', + 'ExpressRouteCircuitConnection', + 'ExpressRouteCircuitConnectionListResult', + 'ExpressRouteCircuitListResult', + 'ExpressRouteCircuitPeering', + 'ExpressRouteCircuitPeeringConfig', + 'ExpressRouteCircuitPeeringId', + 'ExpressRouteCircuitPeeringListResult', + 'ExpressRouteCircuitReference', + 'ExpressRouteCircuitRoutesTable', + 'ExpressRouteCircuitRoutesTableSummary', + 'ExpressRouteCircuitServiceProviderProperties', + 'ExpressRouteCircuitSku', + 'ExpressRouteCircuitStats', + 'ExpressRouteCircuitsArpTableListResult', + 'ExpressRouteCircuitsRoutesTableListResult', + 'ExpressRouteCircuitsRoutesTableSummaryListResult', + 'ExpressRouteConnection', + 'ExpressRouteConnectionId', + 'ExpressRouteConnectionList', + 'ExpressRouteCrossConnection', + 'ExpressRouteCrossConnectionListResult', + 'ExpressRouteCrossConnectionPeering', + 'ExpressRouteCrossConnectionPeeringList', + 'ExpressRouteCrossConnectionRoutesTableSummary', + 'ExpressRouteCrossConnectionsRoutesTableSummaryListResult', + 'ExpressRouteGateway', + 'ExpressRouteGatewayList', + 'ExpressRouteGatewayPropertiesAutoScaleConfiguration', + 'ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds', + 'ExpressRouteLink', + 'ExpressRouteLinkListResult', + 'ExpressRouteLinkMacSecConfig', + 'ExpressRoutePort', + 'ExpressRoutePortListResult', + 'ExpressRoutePortsLocation', + 'ExpressRoutePortsLocationBandwidths', + 'ExpressRoutePortsLocationListResult', + 'ExpressRouteServiceProvider', + 'ExpressRouteServiceProviderBandwidthsOffered', + 'ExpressRouteServiceProviderListResult', + 'ExtendedLocation', + 'FirewallPolicy', + 'FirewallPolicyCertificateAuthority', + 'FirewallPolicyFilterRuleCollection', + 'FirewallPolicyFilterRuleCollectionAction', + 'FirewallPolicyIntrusionDetection', + 'FirewallPolicyIntrusionDetectionBypassTrafficSpecifications', + 'FirewallPolicyIntrusionDetectionConfiguration', + 'FirewallPolicyIntrusionDetectionSignatureSpecification', + 'FirewallPolicyListResult', + 'FirewallPolicyNatRuleCollection', + 'FirewallPolicyNatRuleCollectionAction', + 'FirewallPolicyRule', + 'FirewallPolicyRuleApplicationProtocol', + 'FirewallPolicyRuleCollection', + 'FirewallPolicyRuleCollectionGroup', + 'FirewallPolicyRuleCollectionGroupListResult', + 'FirewallPolicySku', + 'FirewallPolicyThreatIntelWhitelist', + 'FirewallPolicyTransportSecurity', + 'FlowLog', + 'FlowLogFormatParameters', + 'FlowLogInformation', + 'FlowLogListResult', + 'FlowLogStatusParameters', + 'FrontendIPConfiguration', + 'GatewayRoute', + 'GatewayRouteListResult', + 'GenerateExpressRoutePortsLOARequest', + 'GenerateExpressRoutePortsLOAResult', + 'GetVpnSitesConfigurationRequest', + 'HTTPConfiguration', + 'HTTPHeader', + 'HopLink', + 'HubIPAddresses', + 'HubIpConfiguration', + 'HubPublicIPAddresses', + 'HubRoute', + 'HubRouteTable', + 'HubVirtualNetworkConnection', + 'IPAddressAvailabilityResult', + 'IPConfiguration', + 'IPConfigurationBgpPeeringAddress', + 'IPConfigurationProfile', + 'InboundNatPool', + 'InboundNatRule', + 'InboundNatRuleListResult', + 'InboundSecurityRule', + 'InboundSecurityRules', + 'IpAllocation', + 'IpAllocationListResult', + 'IpGroup', + 'IpGroupListResult', + 'IpTag', + 'IpsecPolicy', + 'Ipv6CircuitConnectionConfig', + 'Ipv6ExpressRouteCircuitPeeringConfig', + 'ListHubRouteTablesResult', + 'ListHubVirtualNetworkConnectionsResult', + 'ListP2SVpnGatewaysResult', + 'ListVirtualHubBgpConnectionResults', + 'ListVirtualHubIpConfigurationResults', + 'ListVirtualHubRouteTableV2SResult', + 'ListVirtualHubsResult', + 'ListVirtualWANsResult', + 'ListVpnConnectionsResult', + 'ListVpnGatewayNatRulesResult', + 'ListVpnGatewaysResult', + 'ListVpnServerConfigurationsResult', + 'ListVpnSiteLinkConnectionsResult', + 'ListVpnSiteLinksResult', + 'ListVpnSitesResult', + 'LoadBalancer', + 'LoadBalancerBackendAddress', + 'LoadBalancerBackendAddressPoolListResult', + 'LoadBalancerFrontendIPConfigurationListResult', + 'LoadBalancerListResult', + 'LoadBalancerLoadBalancingRuleListResult', + 'LoadBalancerOutboundRuleListResult', + 'LoadBalancerProbeListResult', + 'LoadBalancerSku', + 'LoadBalancingRule', + 'LocalNetworkGateway', + 'LocalNetworkGatewayListResult', + 'LogSpecification', + 'ManagedRuleGroupOverride', + 'ManagedRuleOverride', + 'ManagedRuleSet', + 'ManagedRulesDefinition', + 'ManagedServiceIdentity', + 'MatchCondition', + 'MatchVariable', + 'MatchedRule', + 'MetricSpecification', + 'NatGateway', + 'NatGatewayListResult', + 'NatGatewaySku', + 'NatRule', + 'NetworkConfigurationDiagnosticParameters', + 'NetworkConfigurationDiagnosticProfile', + 'NetworkConfigurationDiagnosticResponse', + 'NetworkConfigurationDiagnosticResult', + 'NetworkIntentPolicy', + 'NetworkIntentPolicyConfiguration', + 'NetworkInterface', + 'NetworkInterfaceAssociation', + 'NetworkInterfaceDnsSettings', + 'NetworkInterfaceIPConfiguration', + 'NetworkInterfaceIPConfigurationListResult', + 'NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties', + 'NetworkInterfaceListResult', + 'NetworkInterfaceLoadBalancerListResult', + 'NetworkInterfaceTapConfiguration', + 'NetworkInterfaceTapConfigurationListResult', + 'NetworkProfile', + 'NetworkProfileListResult', + 'NetworkRule', + 'NetworkSecurityGroup', + 'NetworkSecurityGroupListResult', + 'NetworkSecurityGroupResult', + 'NetworkSecurityRulesEvaluationResult', + 'NetworkVirtualAppliance', + 'NetworkVirtualApplianceListResult', + 'NetworkVirtualApplianceSiteListResult', + 'NetworkVirtualApplianceSku', + 'NetworkVirtualApplianceSkuInstances', + 'NetworkVirtualApplianceSkuListResult', + 'NetworkWatcher', + 'NetworkWatcherListResult', + 'NextHopParameters', + 'NextHopResult', + 'O365BreakOutCategoryPolicies', + 'O365PolicyProperties', + 'Office365PolicyProperties', + 'Operation', + 'OperationDisplay', + 'OperationListResult', + 'OperationPropertiesFormatServiceSpecification', + 'OutboundRule', + 'OwaspCrsExclusionEntry', + 'P2SConnectionConfiguration', + 'P2SVpnConnectionHealth', + 'P2SVpnConnectionHealthRequest', + 'P2SVpnConnectionRequest', + 'P2SVpnGateway', + 'P2SVpnProfileParameters', + 'PacketCapture', + 'PacketCaptureFilter', + 'PacketCaptureListResult', + 'PacketCaptureParameters', + 'PacketCaptureQueryStatusResult', + 'PacketCaptureResult', + 'PacketCaptureResultProperties', + 'PacketCaptureStorageLocation', + 'PatchRouteFilter', + 'PatchRouteFilterRule', + 'PeerExpressRouteCircuitConnection', + 'PeerExpressRouteCircuitConnectionListResult', + 'PeerRoute', + 'PeerRouteList', + 'PolicySettings', + 'PrepareNetworkPoliciesRequest', + 'PrivateDnsZoneConfig', + 'PrivateDnsZoneGroup', + 'PrivateDnsZoneGroupListResult', + 'PrivateEndpoint', + 'PrivateEndpointConnection', + 'PrivateEndpointConnectionListResult', + 'PrivateEndpointListResult', + 'PrivateLinkService', + 'PrivateLinkServiceConnection', + 'PrivateLinkServiceConnectionState', + 'PrivateLinkServiceIpConfiguration', + 'PrivateLinkServiceListResult', + 'PrivateLinkServicePropertiesAutoApproval', + 'PrivateLinkServicePropertiesVisibility', + 'PrivateLinkServiceVisibility', + 'Probe', + 'PropagatedRouteTable', + 'ProtocolConfiguration', + 'ProtocolCustomSettingsFormat', + 'PublicIPAddress', + 'PublicIPAddressDnsSettings', + 'PublicIPAddressListResult', + 'PublicIPAddressSku', + 'PublicIPPrefix', + 'PublicIPPrefixListResult', + 'PublicIPPrefixSku', + 'QosIpRange', + 'QosPortRange', + 'QueryTroubleshootingParameters', + 'RadiusServer', + 'RecordSet', + 'ReferencedPublicIpAddress', + 'Resource', + 'ResourceNavigationLink', + 'ResourceNavigationLinksListResult', + 'ResourceSet', + 'RetentionPolicyParameters', + 'Route', + 'RouteFilter', + 'RouteFilterListResult', + 'RouteFilterRule', + 'RouteFilterRuleListResult', + 'RouteListResult', + 'RouteTable', + 'RouteTableListResult', + 'RoutingConfiguration', + 'SecurityGroupNetworkInterface', + 'SecurityGroupViewParameters', + 'SecurityGroupViewResult', + 'SecurityPartnerProvider', + 'SecurityPartnerProviderListResult', + 'SecurityRule', + 'SecurityRuleAssociations', + 'SecurityRuleListResult', + 'ServiceAssociationLink', + 'ServiceAssociationLinksListResult', + 'ServiceEndpointPolicy', + 'ServiceEndpointPolicyDefinition', + 'ServiceEndpointPolicyDefinitionListResult', + 'ServiceEndpointPolicyListResult', + 'ServiceEndpointPropertiesFormat', + 'ServiceTagInformation', + 'ServiceTagInformationPropertiesFormat', + 'ServiceTagsListResult', + 'SessionIds', + 'StaticRoute', + 'SubResource', + 'Subnet', + 'SubnetAssociation', + 'SubnetListResult', + 'TagsObject', + 'Topology', + 'TopologyAssociation', + 'TopologyParameters', + 'TopologyResource', + 'TrafficAnalyticsConfigurationProperties', + 'TrafficAnalyticsProperties', + 'TrafficSelectorPolicy', + 'TroubleshootingDetails', + 'TroubleshootingParameters', + 'TroubleshootingRecommendedActions', + 'TroubleshootingResult', + 'TunnelConnectionHealth', + 'UnprepareNetworkPoliciesRequest', + 'Usage', + 'UsageName', + 'UsagesListResult', + 'VM', + 'VerificationIPFlowParameters', + 'VerificationIPFlowResult', + 'VirtualApplianceNicProperties', + 'VirtualApplianceSite', + 'VirtualApplianceSkuProperties', + 'VirtualHub', + 'VirtualHubEffectiveRoute', + 'VirtualHubEffectiveRouteList', + 'VirtualHubId', + 'VirtualHubRoute', + 'VirtualHubRouteTable', + 'VirtualHubRouteTableV2', + 'VirtualHubRouteV2', + 'VirtualNetwork', + 'VirtualNetworkBgpCommunities', + 'VirtualNetworkConnectionGatewayReference', + 'VirtualNetworkGateway', + 'VirtualNetworkGatewayConnection', + 'VirtualNetworkGatewayConnectionListEntity', + 'VirtualNetworkGatewayConnectionListResult', + 'VirtualNetworkGatewayIPConfiguration', + 'VirtualNetworkGatewayListConnectionsResult', + 'VirtualNetworkGatewayListResult', + 'VirtualNetworkGatewaySku', + 'VirtualNetworkListResult', + 'VirtualNetworkListUsageResult', + 'VirtualNetworkPeering', + 'VirtualNetworkPeeringListResult', + 'VirtualNetworkTap', + 'VirtualNetworkTapListResult', + 'VirtualNetworkUsage', + 'VirtualNetworkUsageName', + 'VirtualRouter', + 'VirtualRouterListResult', + 'VirtualRouterPeering', + 'VirtualRouterPeeringListResult', + 'VirtualWAN', + 'VirtualWanSecurityProvider', + 'VirtualWanSecurityProviders', + 'VirtualWanVpnProfileParameters', + 'VnetRoute', + 'VpnClientConfiguration', + 'VpnClientConnectionHealth', + 'VpnClientConnectionHealthDetail', + 'VpnClientConnectionHealthDetailListResult', + 'VpnClientIPsecParameters', + 'VpnClientParameters', + 'VpnClientRevokedCertificate', + 'VpnClientRootCertificate', + 'VpnConnection', + 'VpnConnectionPacketCaptureStartParameters', + 'VpnConnectionPacketCaptureStopParameters', + 'VpnDeviceScriptParameters', + 'VpnGateway', + 'VpnGatewayIpConfiguration', + 'VpnGatewayNatRule', + 'VpnGatewayPacketCaptureStartParameters', + 'VpnGatewayPacketCaptureStopParameters', + 'VpnLinkBgpSettings', + 'VpnLinkProviderProperties', + 'VpnNatRuleMapping', + 'VpnPacketCaptureStartParameters', + 'VpnPacketCaptureStopParameters', + 'VpnProfileResponse', + 'VpnServerConfigRadiusClientRootCertificate', + 'VpnServerConfigRadiusServerRootCertificate', + 'VpnServerConfigVpnClientRevokedCertificate', + 'VpnServerConfigVpnClientRootCertificate', + 'VpnServerConfiguration', + 'VpnServerConfigurationsResponse', + 'VpnSite', + 'VpnSiteId', + 'VpnSiteLink', + 'VpnSiteLinkConnection', + 'WebApplicationFirewallCustomRule', + 'WebApplicationFirewallPolicy', + 'WebApplicationFirewallPolicyListResult', + 'Access', + 'ApplicationGatewayBackendHealthServerHealth', + 'ApplicationGatewayCookieBasedAffinity', + 'ApplicationGatewayCustomErrorStatusCode', + 'ApplicationGatewayFirewallMode', + 'ApplicationGatewayOperationalState', + 'ApplicationGatewayProtocol', + 'ApplicationGatewayRedirectType', + 'ApplicationGatewayRequestRoutingRuleType', + 'ApplicationGatewaySkuName', + 'ApplicationGatewaySslCipherSuite', + 'ApplicationGatewaySslPolicyName', + 'ApplicationGatewaySslPolicyType', + 'ApplicationGatewaySslProtocol', + 'ApplicationGatewayTier', + 'AssociationType', + 'AuthenticationMethod', + 'AuthorizationUseStatus', + 'AzureFirewallApplicationRuleProtocolType', + 'AzureFirewallNatRCActionType', + 'AzureFirewallNetworkRuleProtocol', + 'AzureFirewallRCActionType', + 'AzureFirewallSkuName', + 'AzureFirewallSkuTier', + 'AzureFirewallThreatIntelMode', + 'BastionConnectProtocol', + 'BgpPeerState', + 'CircuitConnectionStatus', + 'CommissionedState', + 'ConnectionMonitorEndpointFilterItemType', + 'ConnectionMonitorEndpointFilterType', + 'ConnectionMonitorSourceStatus', + 'ConnectionMonitorTestConfigurationProtocol', + 'ConnectionMonitorType', + 'ConnectionState', + 'ConnectionStatus', + 'CoverageLevel', + 'DdosCustomPolicyProtocol', + 'DdosCustomPolicyTriggerSensitivityOverride', + 'DdosSettingsProtectionCoverage', + 'DestinationPortBehavior', + 'DhGroup', + 'Direction', + 'EffectiveRouteSource', + 'EffectiveRouteState', + 'EffectiveSecurityRuleProtocol', + 'EndpointType', + 'EvaluationState', + 'ExpressRouteCircuitPeeringAdvertisedPublicPrefixState', + 'ExpressRouteCircuitPeeringState', + 'ExpressRouteCircuitSkuFamily', + 'ExpressRouteCircuitSkuTier', + 'ExpressRouteLinkAdminState', + 'ExpressRouteLinkConnectorType', + 'ExpressRouteLinkMacSecCipher', + 'ExpressRouteLinkMacSecSciState', + 'ExpressRoutePeeringState', + 'ExpressRoutePeeringType', + 'ExpressRoutePortsEncapsulation', + 'ExtendedLocationTypes', + 'FirewallPolicyFilterRuleCollectionActionType', + 'FirewallPolicyIntrusionDetectionProtocol', + 'FirewallPolicyIntrusionDetectionStateType', + 'FirewallPolicyNatRuleCollectionActionType', + 'FirewallPolicyRuleApplicationProtocolType', + 'FirewallPolicyRuleCollectionType', + 'FirewallPolicyRuleNetworkProtocol', + 'FirewallPolicyRuleType', + 'FirewallPolicySkuTier', + 'FlowLogFormatType', + 'HTTPConfigurationMethod', + 'HTTPMethod', + 'HubBgpConnectionStatus', + 'HubVirtualNetworkConnectionStatus', + 'IPAllocationMethod', + 'IPVersion', + 'IkeEncryption', + 'IkeIntegrity', + 'InboundSecurityRulesProtocol', + 'IpAllocationType', + 'IpFlowProtocol', + 'IpsecEncryption', + 'IpsecIntegrity', + 'IssueType', + 'LoadBalancerOutboundRuleProtocol', + 'LoadBalancerSkuName', + 'LoadBalancerSkuTier', + 'LoadDistribution', + 'ManagedRuleEnabledState', + 'NatGatewaySkuName', + 'NetworkOperationStatus', + 'NextHopType', + 'OfficeTrafficCategory', + 'Origin', + 'OutputType', + 'OwaspCrsExclusionEntryMatchVariable', + 'OwaspCrsExclusionEntrySelectorMatchOperator', + 'PcError', + 'PcProtocol', + 'PcStatus', + 'PfsGroup', + 'PreferredIPVersion', + 'ProbeProtocol', + 'ProcessorArchitecture', + 'Protocol', + 'ProtocolType', + 'ProvisioningState', + 'PublicIPAddressSkuName', + 'PublicIPAddressSkuTier', + 'PublicIPPrefixSkuName', + 'PublicIPPrefixSkuTier', + 'ResourceIdentityType', + 'RouteFilterRuleType', + 'RouteNextHopType', + 'RoutingState', + 'SecurityPartnerProviderConnectionStatus', + 'SecurityProviderName', + 'SecurityRuleAccess', + 'SecurityRuleDirection', + 'SecurityRuleProtocol', + 'ServiceProviderProvisioningState', + 'Severity', + 'TransportProtocol', + 'TunnelConnectionStatus', + 'UsageUnit', + 'VerbosityLevel', + 'VirtualNetworkGatewayConnectionMode', + 'VirtualNetworkGatewayConnectionProtocol', + 'VirtualNetworkGatewayConnectionStatus', + 'VirtualNetworkGatewayConnectionType', + 'VirtualNetworkGatewaySkuName', + 'VirtualNetworkGatewaySkuTier', + 'VirtualNetworkGatewayType', + 'VirtualNetworkPeeringState', + 'VirtualWanSecurityProviderType', + 'VpnAuthenticationType', + 'VpnClientProtocol', + 'VpnConnectionStatus', + 'VpnGatewayGeneration', + 'VpnGatewayTunnelingProtocol', + 'VpnLinkConnectionMode', + 'VpnNatRuleMode', + 'VpnNatRuleType', + 'VpnType', + 'WebApplicationFirewallAction', + 'WebApplicationFirewallEnabledState', + 'WebApplicationFirewallMatchVariable', + 'WebApplicationFirewallMode', + 'WebApplicationFirewallOperator', + 'WebApplicationFirewallPolicyResourceState', + 'WebApplicationFirewallRuleType', + 'WebApplicationFirewallTransform', +] diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models.py new file mode 100644 index 000000000000..fdd9f587d1b8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models.py @@ -0,0 +1,22632 @@ +# 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 AadAuthenticationParameters(msrest.serialization.Model): + """AAD Vpn authentication type related parameters. + + :param aad_tenant: AAD Vpn authentication parameter AAD tenant. + :type aad_tenant: str + :param aad_audience: AAD Vpn authentication parameter AAD audience. + :type aad_audience: str + :param aad_issuer: AAD Vpn authentication parameter AAD issuer. + :type aad_issuer: str + """ + + _attribute_map = { + 'aad_tenant': {'key': 'aadTenant', 'type': 'str'}, + 'aad_audience': {'key': 'aadAudience', 'type': 'str'}, + 'aad_issuer': {'key': 'aadIssuer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AadAuthenticationParameters, self).__init__(**kwargs) + self.aad_tenant = kwargs.get('aad_tenant', None) + self.aad_audience = kwargs.get('aad_audience', None) + self.aad_issuer = kwargs.get('aad_issuer', None) + + +class AddressSpace(msrest.serialization.Model): + """AddressSpace contains an array of IP address ranges that can be used by subnets of the virtual network. + + :param address_prefixes: A list of address blocks reserved for this virtual network in CIDR + notation. + :type address_prefixes: list[str] + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AddressSpace, self).__init__(**kwargs) + self.address_prefixes = kwargs.get('address_prefixes', None) + + +class Resource(msrest.serialization.Model): + """Common resource representation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 = { + '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 = kwargs.get('id', None) + self.name = None + self.type = None + self.location = kwargs.get('location', None) + self.tags = kwargs.get('tags', None) + + +class ApplicationGateway(Resource): + """Application gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting where the resource needs to come from. + :type zones: list[str] + :param identity: The identity of the application gateway, if configured. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :param sku: SKU of the application gateway resource. + :type sku: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySku + :param ssl_policy: SSL policy of the application gateway resource. + :type ssl_policy: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicy + :ivar operational_state: Operational state of the application gateway resource. Possible values + include: "Stopped", "Starting", "Running", "Stopping". + :vartype operational_state: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayOperationalState + :param gateway_ip_configurations: Subnets of the application gateway resource. For default + limits, see `Application Gateway limits `_. + :type gateway_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayIPConfiguration] + :param authentication_certificates: Authentication certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type authentication_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAuthenticationCertificate] + :param trusted_root_certificates: Trusted Root certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type trusted_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTrustedRootCertificate] + :param trusted_client_certificates: Trusted client certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type trusted_client_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTrustedClientCertificate] + :param ssl_certificates: SSL certificates of the application gateway resource. For default + limits, see `Application Gateway limits `_. + :type ssl_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCertificate] + :param frontend_ip_configurations: Frontend IP addresses of the application gateway resource. + For default limits, see `Application Gateway limits `_. + :type frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFrontendIPConfiguration] + :param frontend_ports: Frontend ports of the application gateway resource. For default limits, + see `Application Gateway limits `_. + :type frontend_ports: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFrontendPort] + :param probes: Probes of the application gateway resource. + :type probes: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbe] + :param backend_address_pools: Backend address pool of the application gateway resource. For + default limits, see `Application Gateway limits `_. + :type backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool] + :param backend_http_settings_collection: Backend http settings of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type backend_http_settings_collection: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHttpSettings] + :param http_listeners: Http listeners of the application gateway resource. For default limits, + see `Application Gateway limits `_. + :type http_listeners: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHttpListener] + :param ssl_profiles: SSL profiles of the application gateway resource. For default limits, see + `Application Gateway limits `_. + :type ssl_profiles: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProfile] + :param url_path_maps: URL path map of the application gateway resource. For default limits, see + `Application Gateway limits `_. + :type url_path_maps: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayUrlPathMap] + :param request_routing_rules: Request routing rules of the application gateway resource. + :type request_routing_rules: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRequestRoutingRule] + :param rewrite_rule_sets: Rewrite rules for the application gateway resource. + :type rewrite_rule_sets: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleSet] + :param redirect_configurations: Redirect configurations of the application gateway resource. + For default limits, see `Application Gateway limits `_. + :type redirect_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRedirectConfiguration] + :param web_application_firewall_configuration: Web application firewall configuration. + :type web_application_firewall_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayWebApplicationFirewallConfiguration + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_http2: Whether HTTP2 is enabled on the application gateway resource. + :type enable_http2: bool + :param enable_fips: Whether FIPS is enabled on the application gateway resource. + :type enable_fips: bool + :param autoscale_configuration: Autoscale Configuration. + :type autoscale_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAutoscaleConfiguration + :param private_link_configurations: PrivateLink configurations on application gateway. + :type private_link_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkConfiguration] + :ivar private_endpoint_connections: Private Endpoint connections on application gateway. + :vartype private_endpoint_connections: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :ivar resource_guid: The resource GUID property of the application gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the application gateway resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param custom_error_configurations: Custom error configurations of the application gateway + resource. + :type custom_error_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomError] + :param force_firewall_policy_association: If true, associates a firewall policy with an + application gateway regardless whether the policy differs from the WAF Config. + :type force_firewall_policy_association: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'operational_state': {'readonly': True}, + 'private_endpoint_connections': {'readonly': True}, + 'resource_guid': {'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'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'sku': {'key': 'properties.sku', 'type': 'ApplicationGatewaySku'}, + 'ssl_policy': {'key': 'properties.sslPolicy', 'type': 'ApplicationGatewaySslPolicy'}, + 'operational_state': {'key': 'properties.operationalState', 'type': 'str'}, + 'gateway_ip_configurations': {'key': 'properties.gatewayIPConfigurations', 'type': '[ApplicationGatewayIPConfiguration]'}, + 'authentication_certificates': {'key': 'properties.authenticationCertificates', 'type': '[ApplicationGatewayAuthenticationCertificate]'}, + 'trusted_root_certificates': {'key': 'properties.trustedRootCertificates', 'type': '[ApplicationGatewayTrustedRootCertificate]'}, + 'trusted_client_certificates': {'key': 'properties.trustedClientCertificates', 'type': '[ApplicationGatewayTrustedClientCertificate]'}, + 'ssl_certificates': {'key': 'properties.sslCertificates', 'type': '[ApplicationGatewaySslCertificate]'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[ApplicationGatewayFrontendIPConfiguration]'}, + 'frontend_ports': {'key': 'properties.frontendPorts', 'type': '[ApplicationGatewayFrontendPort]'}, + 'probes': {'key': 'properties.probes', 'type': '[ApplicationGatewayProbe]'}, + 'backend_address_pools': {'key': 'properties.backendAddressPools', 'type': '[ApplicationGatewayBackendAddressPool]'}, + 'backend_http_settings_collection': {'key': 'properties.backendHttpSettingsCollection', 'type': '[ApplicationGatewayBackendHttpSettings]'}, + 'http_listeners': {'key': 'properties.httpListeners', 'type': '[ApplicationGatewayHttpListener]'}, + 'ssl_profiles': {'key': 'properties.sslProfiles', 'type': '[ApplicationGatewaySslProfile]'}, + 'url_path_maps': {'key': 'properties.urlPathMaps', 'type': '[ApplicationGatewayUrlPathMap]'}, + 'request_routing_rules': {'key': 'properties.requestRoutingRules', 'type': '[ApplicationGatewayRequestRoutingRule]'}, + 'rewrite_rule_sets': {'key': 'properties.rewriteRuleSets', 'type': '[ApplicationGatewayRewriteRuleSet]'}, + 'redirect_configurations': {'key': 'properties.redirectConfigurations', 'type': '[ApplicationGatewayRedirectConfiguration]'}, + 'web_application_firewall_configuration': {'key': 'properties.webApplicationFirewallConfiguration', 'type': 'ApplicationGatewayWebApplicationFirewallConfiguration'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'enable_http2': {'key': 'properties.enableHttp2', 'type': 'bool'}, + 'enable_fips': {'key': 'properties.enableFips', 'type': 'bool'}, + 'autoscale_configuration': {'key': 'properties.autoscaleConfiguration', 'type': 'ApplicationGatewayAutoscaleConfiguration'}, + 'private_link_configurations': {'key': 'properties.privateLinkConfigurations', 'type': '[ApplicationGatewayPrivateLinkConfiguration]'}, + 'private_endpoint_connections': {'key': 'properties.privateEndpointConnections', 'type': '[ApplicationGatewayPrivateEndpointConnection]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'custom_error_configurations': {'key': 'properties.customErrorConfigurations', 'type': '[ApplicationGatewayCustomError]'}, + 'force_firewall_policy_association': {'key': 'properties.forceFirewallPolicyAssociation', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGateway, self).__init__(**kwargs) + self.etag = None + self.zones = kwargs.get('zones', None) + self.identity = kwargs.get('identity', None) + self.sku = kwargs.get('sku', None) + self.ssl_policy = kwargs.get('ssl_policy', None) + self.operational_state = None + self.gateway_ip_configurations = kwargs.get('gateway_ip_configurations', None) + self.authentication_certificates = kwargs.get('authentication_certificates', None) + self.trusted_root_certificates = kwargs.get('trusted_root_certificates', None) + self.trusted_client_certificates = kwargs.get('trusted_client_certificates', None) + self.ssl_certificates = kwargs.get('ssl_certificates', None) + self.frontend_ip_configurations = kwargs.get('frontend_ip_configurations', None) + self.frontend_ports = kwargs.get('frontend_ports', None) + self.probes = kwargs.get('probes', None) + self.backend_address_pools = kwargs.get('backend_address_pools', None) + self.backend_http_settings_collection = kwargs.get('backend_http_settings_collection', None) + self.http_listeners = kwargs.get('http_listeners', None) + self.ssl_profiles = kwargs.get('ssl_profiles', None) + self.url_path_maps = kwargs.get('url_path_maps', None) + self.request_routing_rules = kwargs.get('request_routing_rules', None) + self.rewrite_rule_sets = kwargs.get('rewrite_rule_sets', None) + self.redirect_configurations = kwargs.get('redirect_configurations', None) + self.web_application_firewall_configuration = kwargs.get('web_application_firewall_configuration', None) + self.firewall_policy = kwargs.get('firewall_policy', None) + self.enable_http2 = kwargs.get('enable_http2', None) + self.enable_fips = kwargs.get('enable_fips', None) + self.autoscale_configuration = kwargs.get('autoscale_configuration', None) + self.private_link_configurations = kwargs.get('private_link_configurations', None) + self.private_endpoint_connections = None + self.resource_guid = None + self.provisioning_state = None + self.custom_error_configurations = kwargs.get('custom_error_configurations', None) + self.force_firewall_policy_association = kwargs.get('force_firewall_policy_association', None) + + +class SubResource(msrest.serialization.Model): + """Reference to another subresource. + + :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 ApplicationGatewayAuthenticationCertificate(SubResource): + """Authentication certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the authentication certificate that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :ivar provisioning_state: The provisioning state of the authentication certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayAuthenticationCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.data = kwargs.get('data', None) + self.provisioning_state = None + + +class ApplicationGatewayAutoscaleConfiguration(msrest.serialization.Model): + """Application Gateway autoscale configuration. + + All required parameters must be populated in order to send to Azure. + + :param min_capacity: Required. Lower bound on number of Application Gateway capacity. + :type min_capacity: int + :param max_capacity: Upper bound on number of Application Gateway capacity. + :type max_capacity: int + """ + + _validation = { + 'min_capacity': {'required': True, 'minimum': 0}, + 'max_capacity': {'minimum': 2}, + } + + _attribute_map = { + 'min_capacity': {'key': 'minCapacity', 'type': 'int'}, + 'max_capacity': {'key': 'maxCapacity', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayAutoscaleConfiguration, self).__init__(**kwargs) + self.min_capacity = kwargs['min_capacity'] + self.max_capacity = kwargs.get('max_capacity', None) + + +class ApplicationGatewayAvailableSslOptions(Resource): + """Response for ApplicationGatewayAvailableSslOptions API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 predefined_policies: List of available Ssl predefined policy. + :type predefined_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param default_policy: Name of the Ssl predefined policy applied by default to application + gateway. Possible values include: "AppGwSslPolicy20150501", "AppGwSslPolicy20170401", + "AppGwSslPolicy20170401S". + :type default_policy: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyName + :param available_cipher_suites: List of available Ssl cipher suites. + :type available_cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param available_protocols: List of available Ssl protocols. + :type available_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol] + """ + + _validation = { + '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}'}, + 'predefined_policies': {'key': 'properties.predefinedPolicies', 'type': '[SubResource]'}, + 'default_policy': {'key': 'properties.defaultPolicy', 'type': 'str'}, + 'available_cipher_suites': {'key': 'properties.availableCipherSuites', 'type': '[str]'}, + 'available_protocols': {'key': 'properties.availableProtocols', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayAvailableSslOptions, self).__init__(**kwargs) + self.predefined_policies = kwargs.get('predefined_policies', None) + self.default_policy = kwargs.get('default_policy', None) + self.available_cipher_suites = kwargs.get('available_cipher_suites', None) + self.available_protocols = kwargs.get('available_protocols', None) + + +class ApplicationGatewayAvailableSslPredefinedPolicies(msrest.serialization.Model): + """Response for ApplicationGatewayAvailableSslOptions API service call. + + :param value: List of available Ssl predefined policy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPredefinedPolicy] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewaySslPredefinedPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayAvailableSslPredefinedPolicies, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ApplicationGatewayAvailableWafRuleSetsResult(msrest.serialization.Model): + """Response for ApplicationGatewayAvailableWafRuleSets API service call. + + :param value: The list of application gateway rule sets. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRuleSet] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayFirewallRuleSet]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayAvailableWafRuleSetsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class ApplicationGatewayBackendAddress(msrest.serialization.Model): + """Backend address of an application gateway. + + :param fqdn: Fully qualified domain name (FQDN). + :type fqdn: str + :param ip_address: IP address. + :type ip_address: str + """ + + _attribute_map = { + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendAddress, self).__init__(**kwargs) + self.fqdn = kwargs.get('fqdn', None) + self.ip_address = kwargs.get('ip_address', None) + + +class ApplicationGatewayBackendAddressPool(SubResource): + """Backend Address Pool of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the backend address pool that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar backend_ip_configurations: Collection of references to IPs defined in network interfaces. + :vartype backend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :param backend_addresses: Backend addresses. + :type backend_addresses: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddress] + :ivar provisioning_state: The provisioning state of the backend address pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configurations': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backend_ip_configurations': {'key': 'properties.backendIPConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'backend_addresses': {'key': 'properties.backendAddresses', 'type': '[ApplicationGatewayBackendAddress]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendAddressPool, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.backend_ip_configurations = None + self.backend_addresses = kwargs.get('backend_addresses', None) + self.provisioning_state = None + + +class ApplicationGatewayBackendHealth(msrest.serialization.Model): + """Response for ApplicationGatewayBackendHealth API service call. + + :param backend_address_pools: A list of ApplicationGatewayBackendHealthPool resources. + :type backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthPool] + """ + + _attribute_map = { + 'backend_address_pools': {'key': 'backendAddressPools', 'type': '[ApplicationGatewayBackendHealthPool]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHealth, self).__init__(**kwargs) + self.backend_address_pools = kwargs.get('backend_address_pools', None) + + +class ApplicationGatewayBackendHealthHttpSettings(msrest.serialization.Model): + """Application gateway BackendHealthHttp settings. + + :param backend_http_settings: Reference to an ApplicationGatewayBackendHttpSettings resource. + :type backend_http_settings: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHttpSettings + :param servers: List of ApplicationGatewayBackendHealthServer resources. + :type servers: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthServer] + """ + + _attribute_map = { + 'backend_http_settings': {'key': 'backendHttpSettings', 'type': 'ApplicationGatewayBackendHttpSettings'}, + 'servers': {'key': 'servers', 'type': '[ApplicationGatewayBackendHealthServer]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHealthHttpSettings, self).__init__(**kwargs) + self.backend_http_settings = kwargs.get('backend_http_settings', None) + self.servers = kwargs.get('servers', None) + + +class ApplicationGatewayBackendHealthOnDemand(msrest.serialization.Model): + """Result of on demand test probe. + + :param backend_address_pool: Reference to an ApplicationGatewayBackendAddressPool resource. + :type backend_address_pool: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool + :param backend_health_http_settings: Application gateway BackendHealthHttp settings. + :type backend_health_http_settings: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthHttpSettings + """ + + _attribute_map = { + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'ApplicationGatewayBackendAddressPool'}, + 'backend_health_http_settings': {'key': 'backendHealthHttpSettings', 'type': 'ApplicationGatewayBackendHealthHttpSettings'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHealthOnDemand, self).__init__(**kwargs) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.backend_health_http_settings = kwargs.get('backend_health_http_settings', None) + + +class ApplicationGatewayBackendHealthPool(msrest.serialization.Model): + """Application gateway BackendHealth pool. + + :param backend_address_pool: Reference to an ApplicationGatewayBackendAddressPool resource. + :type backend_address_pool: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool + :param backend_http_settings_collection: List of ApplicationGatewayBackendHealthHttpSettings + resources. + :type backend_http_settings_collection: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthHttpSettings] + """ + + _attribute_map = { + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'ApplicationGatewayBackendAddressPool'}, + 'backend_http_settings_collection': {'key': 'backendHttpSettingsCollection', 'type': '[ApplicationGatewayBackendHealthHttpSettings]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHealthPool, self).__init__(**kwargs) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.backend_http_settings_collection = kwargs.get('backend_http_settings_collection', None) + + +class ApplicationGatewayBackendHealthServer(msrest.serialization.Model): + """Application gateway backendhealth http settings. + + :param address: IP address or FQDN of backend server. + :type address: str + :param ip_configuration: Reference to IP configuration of backend server. + :type ip_configuration: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param health: Health of backend server. Possible values include: "Unknown", "Up", "Down", + "Partial", "Draining". + :type health: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthServerHealth + :param health_probe_log: Health Probe Log. + :type health_probe_log: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + 'ip_configuration': {'key': 'ipConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'health': {'key': 'health', 'type': 'str'}, + 'health_probe_log': {'key': 'healthProbeLog', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHealthServer, self).__init__(**kwargs) + self.address = kwargs.get('address', None) + self.ip_configuration = kwargs.get('ip_configuration', None) + self.health = kwargs.get('health', None) + self.health_probe_log = kwargs.get('health_probe_log', None) + + +class ApplicationGatewayBackendHttpSettings(SubResource): + """Backend address pool settings of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the backend http settings that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param port: The destination port on the backend. + :type port: int + :param protocol: The protocol used to communicate with the backend. Possible values include: + "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param cookie_based_affinity: Cookie based affinity. Possible values include: "Enabled", + "Disabled". + :type cookie_based_affinity: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCookieBasedAffinity + :param request_timeout: Request timeout in seconds. Application Gateway will fail the request + if response is not received within RequestTimeout. Acceptable values are from 1 second to 86400 + seconds. + :type request_timeout: int + :param probe: Probe resource of an application gateway. + :type probe: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param authentication_certificates: Array of references to application gateway authentication + certificates. + :type authentication_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param trusted_root_certificates: Array of references to application gateway trusted root + certificates. + :type trusted_root_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param connection_draining: Connection draining of the backend http settings resource. + :type connection_draining: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayConnectionDraining + :param host_name: Host header to be sent to the backend servers. + :type host_name: str + :param pick_host_name_from_backend_address: Whether to pick host header should be picked from + the host name of the backend server. Default value is false. + :type pick_host_name_from_backend_address: bool + :param affinity_cookie_name: Cookie name to use for the affinity cookie. + :type affinity_cookie_name: str + :param probe_enabled: Whether the probe is enabled. Default value is false. + :type probe_enabled: bool + :param path: Path which should be used as a prefix for all HTTP requests. Null means no path + will be prefixed. Default value is null. + :type path: str + :ivar provisioning_state: The provisioning state of the backend HTTP settings resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'cookie_based_affinity': {'key': 'properties.cookieBasedAffinity', 'type': 'str'}, + 'request_timeout': {'key': 'properties.requestTimeout', 'type': 'int'}, + 'probe': {'key': 'properties.probe', 'type': 'SubResource'}, + 'authentication_certificates': {'key': 'properties.authenticationCertificates', 'type': '[SubResource]'}, + 'trusted_root_certificates': {'key': 'properties.trustedRootCertificates', 'type': '[SubResource]'}, + 'connection_draining': {'key': 'properties.connectionDraining', 'type': 'ApplicationGatewayConnectionDraining'}, + 'host_name': {'key': 'properties.hostName', 'type': 'str'}, + 'pick_host_name_from_backend_address': {'key': 'properties.pickHostNameFromBackendAddress', 'type': 'bool'}, + 'affinity_cookie_name': {'key': 'properties.affinityCookieName', 'type': 'str'}, + 'probe_enabled': {'key': 'properties.probeEnabled', 'type': 'bool'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayBackendHttpSettings, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.port = kwargs.get('port', None) + self.protocol = kwargs.get('protocol', None) + self.cookie_based_affinity = kwargs.get('cookie_based_affinity', None) + self.request_timeout = kwargs.get('request_timeout', None) + self.probe = kwargs.get('probe', None) + self.authentication_certificates = kwargs.get('authentication_certificates', None) + self.trusted_root_certificates = kwargs.get('trusted_root_certificates', None) + self.connection_draining = kwargs.get('connection_draining', None) + self.host_name = kwargs.get('host_name', None) + self.pick_host_name_from_backend_address = kwargs.get('pick_host_name_from_backend_address', None) + self.affinity_cookie_name = kwargs.get('affinity_cookie_name', None) + self.probe_enabled = kwargs.get('probe_enabled', None) + self.path = kwargs.get('path', None) + self.provisioning_state = None + + +class ApplicationGatewayClientAuthConfiguration(msrest.serialization.Model): + """Application gateway client authentication configuration. + + :param verify_client_cert_issuer_dn: Verify client certificate issuer name on the application + gateway. + :type verify_client_cert_issuer_dn: bool + """ + + _attribute_map = { + 'verify_client_cert_issuer_dn': {'key': 'verifyClientCertIssuerDN', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayClientAuthConfiguration, self).__init__(**kwargs) + self.verify_client_cert_issuer_dn = kwargs.get('verify_client_cert_issuer_dn', None) + + +class ApplicationGatewayConnectionDraining(msrest.serialization.Model): + """Connection draining allows open connections to a backend server to be active for a specified time after the backend server got removed from the configuration. + + All required parameters must be populated in order to send to Azure. + + :param enabled: Required. Whether connection draining is enabled or not. + :type enabled: bool + :param drain_timeout_in_sec: Required. The number of seconds connection draining is active. + Acceptable values are from 1 second to 3600 seconds. + :type drain_timeout_in_sec: int + """ + + _validation = { + 'enabled': {'required': True}, + 'drain_timeout_in_sec': {'required': True, 'maximum': 3600, 'minimum': 1}, + } + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'drain_timeout_in_sec': {'key': 'drainTimeoutInSec', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayConnectionDraining, self).__init__(**kwargs) + self.enabled = kwargs['enabled'] + self.drain_timeout_in_sec = kwargs['drain_timeout_in_sec'] + + +class ApplicationGatewayCustomError(msrest.serialization.Model): + """Customer error of an application gateway. + + :param status_code: Status code of the application gateway customer error. Possible values + include: "HttpStatus403", "HttpStatus502". + :type status_code: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomErrorStatusCode + :param custom_error_page_url: Error page URL of the application gateway customer error. + :type custom_error_page_url: str + """ + + _attribute_map = { + 'status_code': {'key': 'statusCode', 'type': 'str'}, + 'custom_error_page_url': {'key': 'customErrorPageUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayCustomError, self).__init__(**kwargs) + self.status_code = kwargs.get('status_code', None) + self.custom_error_page_url = kwargs.get('custom_error_page_url', None) + + +class ApplicationGatewayFirewallDisabledRuleGroup(msrest.serialization.Model): + """Allows to disable rules within a rule group or an entire rule group. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The name of the rule group that will be disabled. + :type rule_group_name: str + :param rules: The list of rules that will be disabled. If null, all rules of the rule group + will be disabled. + :type rules: list[int] + """ + + _validation = { + 'rule_group_name': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[int]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFirewallDisabledRuleGroup, self).__init__(**kwargs) + self.rule_group_name = kwargs['rule_group_name'] + self.rules = kwargs.get('rules', None) + + +class ApplicationGatewayFirewallExclusion(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param match_variable: Required. The variable to be excluded. + :type match_variable: str + :param selector_match_operator: Required. When matchVariable is a collection, operate on the + selector to specify which elements in the collection this exclusion applies to. + :type selector_match_operator: str + :param selector: Required. When matchVariable is a collection, operator used to specify which + elements in the collection this exclusion applies to. + :type selector: str + """ + + _validation = { + 'match_variable': {'required': True}, + 'selector_match_operator': {'required': True}, + 'selector': {'required': True}, + } + + _attribute_map = { + 'match_variable': {'key': 'matchVariable', 'type': 'str'}, + 'selector_match_operator': {'key': 'selectorMatchOperator', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFirewallExclusion, self).__init__(**kwargs) + self.match_variable = kwargs['match_variable'] + self.selector_match_operator = kwargs['selector_match_operator'] + self.selector = kwargs['selector'] + + +class ApplicationGatewayFirewallRule(msrest.serialization.Model): + """A web application firewall rule. + + All required parameters must be populated in order to send to Azure. + + :param rule_id: Required. The identifier of the web application firewall rule. + :type rule_id: int + :param description: The description of the web application firewall rule. + :type description: str + """ + + _validation = { + 'rule_id': {'required': True}, + } + + _attribute_map = { + 'rule_id': {'key': 'ruleId', 'type': 'int'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFirewallRule, self).__init__(**kwargs) + self.rule_id = kwargs['rule_id'] + self.description = kwargs.get('description', None) + + +class ApplicationGatewayFirewallRuleGroup(msrest.serialization.Model): + """A web application firewall rule group. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The name of the web application firewall rule group. + :type rule_group_name: str + :param description: The description of the web application firewall rule group. + :type description: str + :param rules: Required. The rules of the web application firewall rule group. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRule] + """ + + _validation = { + 'rule_group_name': {'required': True}, + 'rules': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[ApplicationGatewayFirewallRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFirewallRuleGroup, self).__init__(**kwargs) + self.rule_group_name = kwargs['rule_group_name'] + self.description = kwargs.get('description', None) + self.rules = kwargs['rules'] + + +class ApplicationGatewayFirewallRuleSet(Resource): + """A web application firewall rule set. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar provisioning_state: The provisioning state of the web application firewall rule set. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param rule_set_type: The type of the web application firewall rule set. + :type rule_set_type: str + :param rule_set_version: The version of the web application firewall rule set type. + :type rule_set_version: str + :param rule_groups: The rule groups of the web application firewall rule set. + :type rule_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRuleGroup] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'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}'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'rule_set_type': {'key': 'properties.ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'properties.ruleSetVersion', 'type': 'str'}, + 'rule_groups': {'key': 'properties.ruleGroups', 'type': '[ApplicationGatewayFirewallRuleGroup]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFirewallRuleSet, self).__init__(**kwargs) + self.provisioning_state = None + self.rule_set_type = kwargs.get('rule_set_type', None) + self.rule_set_version = kwargs.get('rule_set_version', None) + self.rule_groups = kwargs.get('rule_groups', None) + + +class ApplicationGatewayFrontendIPConfiguration(SubResource): + """Frontend IP configuration of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the frontend IP configuration that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param private_ip_address: PrivateIPAddress of the network interface IP Configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: Reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference to the PublicIP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param private_link_configuration: Reference to the application gateway private link + configuration. + :type private_link_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the frontend IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'private_link_configuration': {'key': 'properties.privateLinkConfiguration', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFrontendIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.private_link_configuration = kwargs.get('private_link_configuration', None) + self.provisioning_state = None + + +class ApplicationGatewayFrontendPort(SubResource): + """Frontend port of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the frontend port that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param port: Frontend port. + :type port: int + :ivar provisioning_state: The provisioning state of the frontend port resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayFrontendPort, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.port = kwargs.get('port', None) + self.provisioning_state = None + + +class ApplicationGatewayHeaderConfiguration(msrest.serialization.Model): + """Header configuration of the Actions set in Application Gateway. + + :param header_name: Header name of the header configuration. + :type header_name: str + :param header_value: Header value of the header configuration. + :type header_value: str + """ + + _attribute_map = { + 'header_name': {'key': 'headerName', 'type': 'str'}, + 'header_value': {'key': 'headerValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayHeaderConfiguration, self).__init__(**kwargs) + self.header_name = kwargs.get('header_name', None) + self.header_value = kwargs.get('header_value', None) + + +class ApplicationGatewayHttpListener(SubResource): + """Http listener of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the HTTP listener that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: Frontend IP configuration resource of an application gateway. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param frontend_port: Frontend port resource of an application gateway. + :type frontend_port: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: Protocol of the HTTP listener. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host_name: Host name of HTTP listener. + :type host_name: str + :param ssl_certificate: SSL certificate resource of an application gateway. + :type ssl_certificate: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ssl_profile: SSL profile resource of the application gateway. + :type ssl_profile: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param require_server_name_indication: Applicable only if protocol is https. Enables SNI for + multi-hosting. + :type require_server_name_indication: bool + :ivar provisioning_state: The provisioning state of the HTTP listener resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param custom_error_configurations: Custom error configurations of the HTTP listener. + :type custom_error_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomError] + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param host_names: List of Host names for HTTP Listener that allows special wildcard characters + as well. + :type host_names: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'host_name': {'key': 'properties.hostName', 'type': 'str'}, + 'ssl_certificate': {'key': 'properties.sslCertificate', 'type': 'SubResource'}, + 'ssl_profile': {'key': 'properties.sslProfile', 'type': 'SubResource'}, + 'require_server_name_indication': {'key': 'properties.requireServerNameIndication', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'custom_error_configurations': {'key': 'properties.customErrorConfigurations', 'type': '[ApplicationGatewayCustomError]'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayHttpListener, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.frontend_ip_configuration = kwargs.get('frontend_ip_configuration', None) + self.frontend_port = kwargs.get('frontend_port', None) + self.protocol = kwargs.get('protocol', None) + self.host_name = kwargs.get('host_name', None) + self.ssl_certificate = kwargs.get('ssl_certificate', None) + self.ssl_profile = kwargs.get('ssl_profile', None) + self.require_server_name_indication = kwargs.get('require_server_name_indication', None) + self.provisioning_state = None + self.custom_error_configurations = kwargs.get('custom_error_configurations', None) + self.firewall_policy = kwargs.get('firewall_policy', None) + self.host_names = kwargs.get('host_names', None) + + +class ApplicationGatewayIPConfiguration(SubResource): + """IP configuration of an application gateway. Currently 1 public and 1 private IP configuration is allowed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the IP configuration that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param subnet: Reference to the subnet resource. A subnet from where application gateway gets + its private address. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the application gateway IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.subnet = kwargs.get('subnet', None) + self.provisioning_state = None + + +class ApplicationGatewayListResult(msrest.serialization.Model): + """Response for ListApplicationGateways API service call. + + :param value: List of an application gateways in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ApplicationGatewayOnDemandProbe(msrest.serialization.Model): + """Details of on demand test probe request. + + :param protocol: The protocol used for the probe. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host: Host name to send the probe to. + :type host: str + :param path: Relative path of probe. Valid path starts from '/'. Probe is sent to + :code:``://:code:``::code:``:code:``. + :type path: str + :param timeout: The probe timeout in seconds. Probe marked as failed if valid response is not + received with this timeout period. Acceptable values are from 1 second to 86400 seconds. + :type timeout: int + :param pick_host_name_from_backend_http_settings: Whether the host header should be picked from + the backend http settings. Default value is false. + :type pick_host_name_from_backend_http_settings: bool + :param match: Criterion for classifying a healthy probe response. + :type match: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbeHealthResponseMatch + :param backend_address_pool: Reference to backend pool of application gateway to which probe + request will be sent. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Reference to backend http setting of application gateway to be + used for test probe. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'host': {'key': 'host', 'type': 'str'}, + 'path': {'key': 'path', 'type': 'str'}, + 'timeout': {'key': 'timeout', 'type': 'int'}, + 'pick_host_name_from_backend_http_settings': {'key': 'pickHostNameFromBackendHttpSettings', 'type': 'bool'}, + 'match': {'key': 'match', 'type': 'ApplicationGatewayProbeHealthResponseMatch'}, + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'backendHttpSettings', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayOnDemandProbe, self).__init__(**kwargs) + self.protocol = kwargs.get('protocol', None) + self.host = kwargs.get('host', None) + self.path = kwargs.get('path', None) + self.timeout = kwargs.get('timeout', None) + self.pick_host_name_from_backend_http_settings = kwargs.get('pick_host_name_from_backend_http_settings', None) + self.match = kwargs.get('match', None) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.backend_http_settings = kwargs.get('backend_http_settings', None) + + +class ApplicationGatewayPathRule(SubResource): + """Path rule of URL path map of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the path rule that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param paths: Path rules of URL path map. + :type paths: list[str] + :param backend_address_pool: Backend address pool resource of URL path map path rule. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Backend http settings resource of URL path map path rule. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param redirect_configuration: Redirect configuration resource of URL path map path rule. + :type redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param rewrite_rule_set: Rewrite rule set resource of URL path map path rule. + :type rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the path rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'paths': {'key': 'properties.paths', 'type': '[str]'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'properties.backendHttpSettings', 'type': 'SubResource'}, + 'redirect_configuration': {'key': 'properties.redirectConfiguration', 'type': 'SubResource'}, + 'rewrite_rule_set': {'key': 'properties.rewriteRuleSet', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPathRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.paths = kwargs.get('paths', None) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.backend_http_settings = kwargs.get('backend_http_settings', None) + self.redirect_configuration = kwargs.get('redirect_configuration', None) + self.rewrite_rule_set = kwargs.get('rewrite_rule_set', None) + self.provisioning_state = None + self.firewall_policy = kwargs.get('firewall_policy', None) + + +class ApplicationGatewayPrivateEndpointConnection(SubResource): + """Private Endpoint connection on an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private endpoint connection on an application gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar private_endpoint: The resource of private end point. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param private_link_service_connection_state: A collection of information about the state of + the connection between service consumer and provider. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + :ivar provisioning_state: The provisioning state of the application gateway private endpoint + connection resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar link_identifier: The consumer link id. + :vartype link_identifier: str + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'link_identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'link_identifier': {'key': 'properties.linkIdentifier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateEndpointConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_endpoint = None + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + self.provisioning_state = None + self.link_identifier = None + + +class ApplicationGatewayPrivateEndpointConnectionListResult(msrest.serialization.Model): + """Response for ListApplicationGatewayPrivateEndpointConnection API service call. Gets all private endpoint connections for an application gateway. + + :param value: List of private endpoint connections on an application gateway. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayPrivateEndpointConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateEndpointConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ApplicationGatewayPrivateLinkConfiguration(SubResource): + """Private Link Configuration on an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private link configuration that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param ip_configurations: An array of application gateway private link ip configurations. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkIpConfiguration] + :ivar provisioning_state: The provisioning state of the application gateway private link + configuration. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[ApplicationGatewayPrivateLinkIpConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateLinkConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.ip_configurations = kwargs.get('ip_configurations', None) + self.provisioning_state = None + + +class ApplicationGatewayPrivateLinkIpConfiguration(SubResource): + """The application gateway private link ip configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of application gateway private link ip configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: The resource type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: Reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param primary: Whether the ip configuration is primary or not. + :type primary: bool + :ivar provisioning_state: The provisioning state of the application gateway private link IP + configuration. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateLinkIpConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.primary = kwargs.get('primary', None) + self.provisioning_state = None + + +class ApplicationGatewayPrivateLinkResource(SubResource): + """PrivateLink Resource of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private link resource that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar group_id: Group identifier of private link resource. + :vartype group_id: str + :ivar required_members: Required member names of private link resource. + :vartype required_members: list[str] + :param required_zone_names: Required DNS zone names of the the private link resource. + :type required_zone_names: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'group_id': {'key': 'properties.groupId', 'type': 'str'}, + 'required_members': {'key': 'properties.requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'properties.requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateLinkResource, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.group_id = None + self.required_members = None + self.required_zone_names = kwargs.get('required_zone_names', None) + + +class ApplicationGatewayPrivateLinkResourceListResult(msrest.serialization.Model): + """Response for ListApplicationGatewayPrivateLinkResources API service call. Gets all private link resources for an application gateway. + + :param value: List of private link resources of an application gateway. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkResource] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayPrivateLinkResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayPrivateLinkResourceListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ApplicationGatewayProbe(SubResource): + """Probe of the application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the probe that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param protocol: The protocol used for the probe. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host: Host name to send the probe to. + :type host: str + :param path: Relative path of probe. Valid path starts from '/'. Probe is sent to + :code:``://:code:``::code:``:code:``. + :type path: str + :param interval: The probing interval in seconds. This is the time interval between two + consecutive probes. Acceptable values are from 1 second to 86400 seconds. + :type interval: int + :param timeout: The probe timeout in seconds. Probe marked as failed if valid response is not + received with this timeout period. Acceptable values are from 1 second to 86400 seconds. + :type timeout: int + :param unhealthy_threshold: The probe retry count. Backend server is marked down after + consecutive probe failure count reaches UnhealthyThreshold. Acceptable values are from 1 second + to 20. + :type unhealthy_threshold: int + :param pick_host_name_from_backend_http_settings: Whether the host header should be picked from + the backend http settings. Default value is false. + :type pick_host_name_from_backend_http_settings: bool + :param min_servers: Minimum number of servers that are always marked healthy. Default value is + 0. + :type min_servers: int + :param match: Criterion for classifying a healthy probe response. + :type match: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbeHealthResponseMatch + :ivar provisioning_state: The provisioning state of the probe resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param port: Custom port which will be used for probing the backend servers. The valid value + ranges from 1 to 65535. In case not set, port from http settings will be used. This property is + valid for Standard_v2 and WAF_v2 only. + :type port: int + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'port': {'maximum': 65535, 'minimum': 1}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'host': {'key': 'properties.host', 'type': 'str'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'interval': {'key': 'properties.interval', 'type': 'int'}, + 'timeout': {'key': 'properties.timeout', 'type': 'int'}, + 'unhealthy_threshold': {'key': 'properties.unhealthyThreshold', 'type': 'int'}, + 'pick_host_name_from_backend_http_settings': {'key': 'properties.pickHostNameFromBackendHttpSettings', 'type': 'bool'}, + 'min_servers': {'key': 'properties.minServers', 'type': 'int'}, + 'match': {'key': 'properties.match', 'type': 'ApplicationGatewayProbeHealthResponseMatch'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayProbe, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.protocol = kwargs.get('protocol', None) + self.host = kwargs.get('host', None) + self.path = kwargs.get('path', None) + self.interval = kwargs.get('interval', None) + self.timeout = kwargs.get('timeout', None) + self.unhealthy_threshold = kwargs.get('unhealthy_threshold', None) + self.pick_host_name_from_backend_http_settings = kwargs.get('pick_host_name_from_backend_http_settings', None) + self.min_servers = kwargs.get('min_servers', None) + self.match = kwargs.get('match', None) + self.provisioning_state = None + self.port = kwargs.get('port', None) + + +class ApplicationGatewayProbeHealthResponseMatch(msrest.serialization.Model): + """Application gateway probe health response match. + + :param body: Body that must be contained in the health response. Default value is empty. + :type body: str + :param status_codes: Allowed ranges of healthy status codes. Default range of healthy status + codes is 200-399. + :type status_codes: list[str] + """ + + _attribute_map = { + 'body': {'key': 'body', 'type': 'str'}, + 'status_codes': {'key': 'statusCodes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayProbeHealthResponseMatch, self).__init__(**kwargs) + self.body = kwargs.get('body', None) + self.status_codes = kwargs.get('status_codes', None) + + +class ApplicationGatewayRedirectConfiguration(SubResource): + """Redirect configuration of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the redirect configuration that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param redirect_type: HTTP redirection type. Possible values include: "Permanent", "Found", + "SeeOther", "Temporary". + :type redirect_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRedirectType + :param target_listener: Reference to a listener to redirect the request to. + :type target_listener: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param target_url: Url to redirect the request to. + :type target_url: str + :param include_path: Include path in the redirected url. + :type include_path: bool + :param include_query_string: Include query string in the redirected url. + :type include_query_string: bool + :param request_routing_rules: Request routing specifying redirect configuration. + :type request_routing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param url_path_maps: Url path maps specifying default redirect configuration. + :type url_path_maps: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param path_rules: Path rules specifying redirect configuration. + :type path_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'redirect_type': {'key': 'properties.redirectType', 'type': 'str'}, + 'target_listener': {'key': 'properties.targetListener', 'type': 'SubResource'}, + 'target_url': {'key': 'properties.targetUrl', 'type': 'str'}, + 'include_path': {'key': 'properties.includePath', 'type': 'bool'}, + 'include_query_string': {'key': 'properties.includeQueryString', 'type': 'bool'}, + 'request_routing_rules': {'key': 'properties.requestRoutingRules', 'type': '[SubResource]'}, + 'url_path_maps': {'key': 'properties.urlPathMaps', 'type': '[SubResource]'}, + 'path_rules': {'key': 'properties.pathRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRedirectConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.redirect_type = kwargs.get('redirect_type', None) + self.target_listener = kwargs.get('target_listener', None) + self.target_url = kwargs.get('target_url', None) + self.include_path = kwargs.get('include_path', None) + self.include_query_string = kwargs.get('include_query_string', None) + self.request_routing_rules = kwargs.get('request_routing_rules', None) + self.url_path_maps = kwargs.get('url_path_maps', None) + self.path_rules = kwargs.get('path_rules', None) + + +class ApplicationGatewayRequestRoutingRule(SubResource): + """Request routing rule of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the request routing rule that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param rule_type: Rule type. Possible values include: "Basic", "PathBasedRouting". + :type rule_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRequestRoutingRuleType + :param priority: Priority of the request routing rule. + :type priority: int + :param backend_address_pool: Backend address pool resource of the application gateway. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Backend http settings resource of the application gateway. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param http_listener: Http listener resource of the application gateway. + :type http_listener: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param url_path_map: URL path map resource of the application gateway. + :type url_path_map: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param rewrite_rule_set: Rewrite Rule Set resource in Basic rule of the application gateway. + :type rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param redirect_configuration: Redirect configuration resource of the application gateway. + :type redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the request routing rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'priority': {'maximum': 20000, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'rule_type': {'key': 'properties.ruleType', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'properties.backendHttpSettings', 'type': 'SubResource'}, + 'http_listener': {'key': 'properties.httpListener', 'type': 'SubResource'}, + 'url_path_map': {'key': 'properties.urlPathMap', 'type': 'SubResource'}, + 'rewrite_rule_set': {'key': 'properties.rewriteRuleSet', 'type': 'SubResource'}, + 'redirect_configuration': {'key': 'properties.redirectConfiguration', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRequestRoutingRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.rule_type = kwargs.get('rule_type', None) + self.priority = kwargs.get('priority', None) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.backend_http_settings = kwargs.get('backend_http_settings', None) + self.http_listener = kwargs.get('http_listener', None) + self.url_path_map = kwargs.get('url_path_map', None) + self.rewrite_rule_set = kwargs.get('rewrite_rule_set', None) + self.redirect_configuration = kwargs.get('redirect_configuration', None) + self.provisioning_state = None + + +class ApplicationGatewayRewriteRule(msrest.serialization.Model): + """Rewrite rule of an application gateway. + + :param name: Name of the rewrite rule that is unique within an Application Gateway. + :type name: str + :param rule_sequence: Rule Sequence of the rewrite rule that determines the order of execution + of a particular rule in a RewriteRuleSet. + :type rule_sequence: int + :param conditions: Conditions based on which the action set execution will be evaluated. + :type conditions: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleCondition] + :param action_set: Set of actions to be done as part of the rewrite Rule. + :type action_set: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleActionSet + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'rule_sequence': {'key': 'ruleSequence', 'type': 'int'}, + 'conditions': {'key': 'conditions', 'type': '[ApplicationGatewayRewriteRuleCondition]'}, + 'action_set': {'key': 'actionSet', 'type': 'ApplicationGatewayRewriteRuleActionSet'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRewriteRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.rule_sequence = kwargs.get('rule_sequence', None) + self.conditions = kwargs.get('conditions', None) + self.action_set = kwargs.get('action_set', None) + + +class ApplicationGatewayRewriteRuleActionSet(msrest.serialization.Model): + """Set of actions in the Rewrite Rule in Application Gateway. + + :param request_header_configurations: Request Header Actions in the Action Set. + :type request_header_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHeaderConfiguration] + :param response_header_configurations: Response Header Actions in the Action Set. + :type response_header_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHeaderConfiguration] + :param url_configuration: Url Configuration Action in the Action Set. + :type url_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayUrlConfiguration + """ + + _attribute_map = { + 'request_header_configurations': {'key': 'requestHeaderConfigurations', 'type': '[ApplicationGatewayHeaderConfiguration]'}, + 'response_header_configurations': {'key': 'responseHeaderConfigurations', 'type': '[ApplicationGatewayHeaderConfiguration]'}, + 'url_configuration': {'key': 'urlConfiguration', 'type': 'ApplicationGatewayUrlConfiguration'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRewriteRuleActionSet, self).__init__(**kwargs) + self.request_header_configurations = kwargs.get('request_header_configurations', None) + self.response_header_configurations = kwargs.get('response_header_configurations', None) + self.url_configuration = kwargs.get('url_configuration', None) + + +class ApplicationGatewayRewriteRuleCondition(msrest.serialization.Model): + """Set of conditions in the Rewrite Rule in Application Gateway. + + :param variable: The condition parameter of the RewriteRuleCondition. + :type variable: str + :param pattern: The pattern, either fixed string or regular expression, that evaluates the + truthfulness of the condition. + :type pattern: str + :param ignore_case: Setting this paramter to truth value with force the pattern to do a case + in-sensitive comparison. + :type ignore_case: bool + :param negate: Setting this value as truth will force to check the negation of the condition + given by the user. + :type negate: bool + """ + + _attribute_map = { + 'variable': {'key': 'variable', 'type': 'str'}, + 'pattern': {'key': 'pattern', 'type': 'str'}, + 'ignore_case': {'key': 'ignoreCase', 'type': 'bool'}, + 'negate': {'key': 'negate', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRewriteRuleCondition, self).__init__(**kwargs) + self.variable = kwargs.get('variable', None) + self.pattern = kwargs.get('pattern', None) + self.ignore_case = kwargs.get('ignore_case', None) + self.negate = kwargs.get('negate', None) + + +class ApplicationGatewayRewriteRuleSet(SubResource): + """Rewrite rule set of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the rewrite rule set that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param rewrite_rules: Rewrite rules in the rewrite rule set. + :type rewrite_rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRule] + :ivar provisioning_state: The provisioning state of the rewrite rule set resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'rewrite_rules': {'key': 'properties.rewriteRules', 'type': '[ApplicationGatewayRewriteRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayRewriteRuleSet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.rewrite_rules = kwargs.get('rewrite_rules', None) + self.provisioning_state = None + + +class ApplicationGatewaySku(msrest.serialization.Model): + """SKU of an application gateway. + + :param name: Name of an application gateway SKU. Possible values include: "Standard_Small", + "Standard_Medium", "Standard_Large", "WAF_Medium", "WAF_Large", "Standard_v2", "WAF_v2". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySkuName + :param tier: Tier of an application gateway. Possible values include: "Standard", "WAF", + "Standard_v2", "WAF_v2". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTier + :param capacity: Capacity (instance count) of an application gateway. + :type capacity: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewaySku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.capacity = kwargs.get('capacity', None) + + +class ApplicationGatewaySslCertificate(SubResource): + """SSL certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the SSL certificate that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Base-64 encoded pfx certificate. Only applicable in PUT Request. + :type data: str + :param password: Password for the pfx file specified in data. Only applicable in PUT request. + :type password: str + :ivar public_cert_data: Base-64 encoded Public cert data corresponding to pfx specified in + data. Only applicable in GET request. + :vartype public_cert_data: str + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :ivar provisioning_state: The provisioning state of the SSL certificate resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'public_cert_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'public_cert_data': {'key': 'properties.publicCertData', 'type': 'str'}, + 'key_vault_secret_id': {'key': 'properties.keyVaultSecretId', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewaySslCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.data = kwargs.get('data', None) + self.password = kwargs.get('password', None) + self.public_cert_data = None + self.key_vault_secret_id = kwargs.get('key_vault_secret_id', None) + self.provisioning_state = None + + +class ApplicationGatewaySslPolicy(msrest.serialization.Model): + """Application Gateway Ssl policy. + + :param disabled_ssl_protocols: Ssl protocols to be disabled on application gateway. + :type disabled_ssl_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol] + :param policy_type: Type of Ssl Policy. Possible values include: "Predefined", "Custom". + :type policy_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyType + :param policy_name: Name of Ssl predefined policy. Possible values include: + "AppGwSslPolicy20150501", "AppGwSslPolicy20170401", "AppGwSslPolicy20170401S". + :type policy_name: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyName + :param cipher_suites: Ssl cipher suites to be enabled in the specified order to application + gateway. + :type cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param min_protocol_version: Minimum version of Ssl protocol to be supported on application + gateway. Possible values include: "TLSv1_0", "TLSv1_1", "TLSv1_2". + :type min_protocol_version: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol + """ + + _attribute_map = { + 'disabled_ssl_protocols': {'key': 'disabledSslProtocols', 'type': '[str]'}, + 'policy_type': {'key': 'policyType', 'type': 'str'}, + 'policy_name': {'key': 'policyName', 'type': 'str'}, + 'cipher_suites': {'key': 'cipherSuites', 'type': '[str]'}, + 'min_protocol_version': {'key': 'minProtocolVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewaySslPolicy, self).__init__(**kwargs) + self.disabled_ssl_protocols = kwargs.get('disabled_ssl_protocols', None) + self.policy_type = kwargs.get('policy_type', None) + self.policy_name = kwargs.get('policy_name', None) + self.cipher_suites = kwargs.get('cipher_suites', None) + self.min_protocol_version = kwargs.get('min_protocol_version', None) + + +class ApplicationGatewaySslPredefinedPolicy(SubResource): + """An Ssl predefined policy. + + :param id: Resource ID. + :type id: str + :param name: Name of the Ssl predefined policy. + :type name: str + :param cipher_suites: Ssl cipher suites to be enabled in the specified order for application + gateway. + :type cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param min_protocol_version: Minimum version of Ssl protocol to be supported on application + gateway. Possible values include: "TLSv1_0", "TLSv1_1", "TLSv1_2". + :type min_protocol_version: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'cipher_suites': {'key': 'properties.cipherSuites', 'type': '[str]'}, + 'min_protocol_version': {'key': 'properties.minProtocolVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewaySslPredefinedPolicy, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.cipher_suites = kwargs.get('cipher_suites', None) + self.min_protocol_version = kwargs.get('min_protocol_version', None) + + +class ApplicationGatewaySslProfile(SubResource): + """SSL profile of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the SSL profile that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param trusted_client_certificates: Array of references to application gateway trusted client + certificates. + :type trusted_client_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param ssl_policy: SSL policy of the application gateway resource. + :type ssl_policy: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicy + :param client_auth_configuration: Client authentication configuration of the application + gateway resource. + :type client_auth_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayClientAuthConfiguration + :ivar provisioning_state: The provisioning state of the HTTP listener resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'trusted_client_certificates': {'key': 'properties.trustedClientCertificates', 'type': '[SubResource]'}, + 'ssl_policy': {'key': 'properties.sslPolicy', 'type': 'ApplicationGatewaySslPolicy'}, + 'client_auth_configuration': {'key': 'properties.clientAuthConfiguration', 'type': 'ApplicationGatewayClientAuthConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewaySslProfile, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.trusted_client_certificates = kwargs.get('trusted_client_certificates', None) + self.ssl_policy = kwargs.get('ssl_policy', None) + self.client_auth_configuration = kwargs.get('client_auth_configuration', None) + self.provisioning_state = None + + +class ApplicationGatewayTrustedClientCertificate(SubResource): + """Trusted client certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the trusted client certificate that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :ivar provisioning_state: The provisioning state of the trusted client certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayTrustedClientCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.data = kwargs.get('data', None) + self.provisioning_state = None + + +class ApplicationGatewayTrustedRootCertificate(SubResource): + """Trusted Root certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the trusted root certificate that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :ivar provisioning_state: The provisioning state of the trusted root certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'key_vault_secret_id': {'key': 'properties.keyVaultSecretId', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayTrustedRootCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.data = kwargs.get('data', None) + self.key_vault_secret_id = kwargs.get('key_vault_secret_id', None) + self.provisioning_state = None + + +class ApplicationGatewayUrlConfiguration(msrest.serialization.Model): + """Url configuration of the Actions set in Application Gateway. + + :param modified_path: Url path which user has provided for url rewrite. Null means no path will + be updated. Default value is null. + :type modified_path: str + :param modified_query_string: Query string which user has provided for url rewrite. Null means + no query string will be updated. Default value is null. + :type modified_query_string: str + :param reroute: If set as true, it will re-evaluate the url path map provided in path based + request routing rules using modified path. Default value is false. + :type reroute: bool + """ + + _attribute_map = { + 'modified_path': {'key': 'modifiedPath', 'type': 'str'}, + 'modified_query_string': {'key': 'modifiedQueryString', 'type': 'str'}, + 'reroute': {'key': 'reroute', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayUrlConfiguration, self).__init__(**kwargs) + self.modified_path = kwargs.get('modified_path', None) + self.modified_query_string = kwargs.get('modified_query_string', None) + self.reroute = kwargs.get('reroute', None) + + +class ApplicationGatewayUrlPathMap(SubResource): + """UrlPathMaps give a url path to the backend mapping information for PathBasedRouting. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the URL path map that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param default_backend_address_pool: Default backend address pool resource of URL path map. + :type default_backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_backend_http_settings: Default backend http settings resource of URL path map. + :type default_backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_rewrite_rule_set: Default Rewrite rule set resource of URL path map. + :type default_rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_redirect_configuration: Default redirect configuration resource of URL path map. + :type default_redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param path_rules: Path rule of URL path map resource. + :type path_rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPathRule] + :ivar provisioning_state: The provisioning state of the URL path map resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_backend_address_pool': {'key': 'properties.defaultBackendAddressPool', 'type': 'SubResource'}, + 'default_backend_http_settings': {'key': 'properties.defaultBackendHttpSettings', 'type': 'SubResource'}, + 'default_rewrite_rule_set': {'key': 'properties.defaultRewriteRuleSet', 'type': 'SubResource'}, + 'default_redirect_configuration': {'key': 'properties.defaultRedirectConfiguration', 'type': 'SubResource'}, + 'path_rules': {'key': 'properties.pathRules', 'type': '[ApplicationGatewayPathRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayUrlPathMap, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.default_backend_address_pool = kwargs.get('default_backend_address_pool', None) + self.default_backend_http_settings = kwargs.get('default_backend_http_settings', None) + self.default_rewrite_rule_set = kwargs.get('default_rewrite_rule_set', None) + self.default_redirect_configuration = kwargs.get('default_redirect_configuration', None) + self.path_rules = kwargs.get('path_rules', None) + self.provisioning_state = None + + +class ApplicationGatewayWebApplicationFirewallConfiguration(msrest.serialization.Model): + """Application gateway web application firewall configuration. + + All required parameters must be populated in order to send to Azure. + + :param enabled: Required. Whether the web application firewall is enabled or not. + :type enabled: bool + :param firewall_mode: Required. Web application firewall mode. Possible values include: + "Detection", "Prevention". + :type firewall_mode: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallMode + :param rule_set_type: Required. The type of the web application firewall rule set. Possible + values are: 'OWASP'. + :type rule_set_type: str + :param rule_set_version: Required. The version of the rule set type. + :type rule_set_version: str + :param disabled_rule_groups: The disabled rule groups. + :type disabled_rule_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallDisabledRuleGroup] + :param request_body_check: Whether allow WAF to check request Body. + :type request_body_check: bool + :param max_request_body_size: Maximum request body size for WAF. + :type max_request_body_size: int + :param max_request_body_size_in_kb: Maximum request body size in Kb for WAF. + :type max_request_body_size_in_kb: int + :param file_upload_limit_in_mb: Maximum file upload size in Mb for WAF. + :type file_upload_limit_in_mb: int + :param exclusions: The exclusion list. + :type exclusions: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallExclusion] + """ + + _validation = { + 'enabled': {'required': True}, + 'firewall_mode': {'required': True}, + 'rule_set_type': {'required': True}, + 'rule_set_version': {'required': True}, + 'max_request_body_size': {'maximum': 128, 'minimum': 8}, + 'max_request_body_size_in_kb': {'maximum': 128, 'minimum': 8}, + 'file_upload_limit_in_mb': {'minimum': 0}, + } + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'firewall_mode': {'key': 'firewallMode', 'type': 'str'}, + 'rule_set_type': {'key': 'ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'ruleSetVersion', 'type': 'str'}, + 'disabled_rule_groups': {'key': 'disabledRuleGroups', 'type': '[ApplicationGatewayFirewallDisabledRuleGroup]'}, + 'request_body_check': {'key': 'requestBodyCheck', 'type': 'bool'}, + 'max_request_body_size': {'key': 'maxRequestBodySize', 'type': 'int'}, + 'max_request_body_size_in_kb': {'key': 'maxRequestBodySizeInKb', 'type': 'int'}, + 'file_upload_limit_in_mb': {'key': 'fileUploadLimitInMb', 'type': 'int'}, + 'exclusions': {'key': 'exclusions', 'type': '[ApplicationGatewayFirewallExclusion]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationGatewayWebApplicationFirewallConfiguration, self).__init__(**kwargs) + self.enabled = kwargs['enabled'] + self.firewall_mode = kwargs['firewall_mode'] + self.rule_set_type = kwargs['rule_set_type'] + self.rule_set_version = kwargs['rule_set_version'] + self.disabled_rule_groups = kwargs.get('disabled_rule_groups', None) + self.request_body_check = kwargs.get('request_body_check', None) + self.max_request_body_size = kwargs.get('max_request_body_size', None) + self.max_request_body_size_in_kb = kwargs.get('max_request_body_size_in_kb', None) + self.file_upload_limit_in_mb = kwargs.get('file_upload_limit_in_mb', None) + self.exclusions = kwargs.get('exclusions', None) + + +class FirewallPolicyRule(msrest.serialization.Model): + """Properties of a rule. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: ApplicationRule, NatRule, NetworkRule. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + } + + _subtype_map = { + 'rule_type': {'ApplicationRule': 'ApplicationRule', 'NatRule': 'NatRule', 'NetworkRule': 'NetworkRule'} + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.rule_type = None # type: Optional[str] + + +class ApplicationRule(FirewallPolicyRule): + """Rule of type application. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param protocols: Array of Application Protocols. + :type protocols: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleApplicationProtocol] + :param target_fqdns: List of FQDNs for this rule. + :type target_fqdns: list[str] + :param target_urls: List of Urls for this rule condition. + :type target_urls: list[str] + :param fqdn_tags: List of FQDN Tags for this rule. + :type fqdn_tags: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param terminate_tls: Terminate TLS connections for this rule. + :type terminate_tls: bool + :param web_categories: List of destination azure web categories. + :type web_categories: list[str] + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[FirewallPolicyRuleApplicationProtocol]'}, + 'target_fqdns': {'key': 'targetFqdns', 'type': '[str]'}, + 'target_urls': {'key': 'targetUrls', 'type': '[str]'}, + 'fqdn_tags': {'key': 'fqdnTags', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'terminate_tls': {'key': 'terminateTLS', 'type': 'bool'}, + 'web_categories': {'key': 'webCategories', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationRule, self).__init__(**kwargs) + self.rule_type = 'ApplicationRule' # type: str + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.protocols = kwargs.get('protocols', None) + self.target_fqdns = kwargs.get('target_fqdns', None) + self.target_urls = kwargs.get('target_urls', None) + self.fqdn_tags = kwargs.get('fqdn_tags', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + self.terminate_tls = kwargs.get('terminate_tls', None) + self.web_categories = kwargs.get('web_categories', None) + + +class ApplicationSecurityGroup(Resource): + """An application security group in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the application security group resource. It + uniquely identifies a resource, even if the user changes its name or migrate the resource + across subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the application security group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationSecurityGroup, self).__init__(**kwargs) + self.etag = None + self.resource_guid = None + self.provisioning_state = None + + +class ApplicationSecurityGroupListResult(msrest.serialization.Model): + """A list of application security groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of application security groups. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationSecurityGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class AuthorizationListResult(msrest.serialization.Model): + """Response for ListAuthorizations API service call retrieves all authorizations that belongs to an ExpressRouteCircuit. + + :param value: The authorizations in an ExpressRoute Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitAuthorization]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AuthorizationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class AutoApprovedPrivateLinkService(msrest.serialization.Model): + """The information of an AutoApprovedPrivateLinkService. + + :param private_link_service: The id of the private link service resource. + :type private_link_service: str + """ + + _attribute_map = { + 'private_link_service': {'key': 'privateLinkService', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoApprovedPrivateLinkService, self).__init__(**kwargs) + self.private_link_service = kwargs.get('private_link_service', None) + + +class AutoApprovedPrivateLinkServicesResult(msrest.serialization.Model): + """An array of private link service id that can be linked to a private end point with auto approved. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of auto approved private link service. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkService] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AutoApprovedPrivateLinkService]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoApprovedPrivateLinkServicesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class Availability(msrest.serialization.Model): + """Availability of the metric. + + :param time_grain: The time grain of the availability. + :type time_grain: str + :param retention: The retention of the availability. + :type retention: str + :param blob_duration: Duration of the availability blob. + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Availability, self).__init__(**kwargs) + self.time_grain = kwargs.get('time_grain', None) + self.retention = kwargs.get('retention', None) + self.blob_duration = kwargs.get('blob_duration', None) + + +class AvailableDelegation(msrest.serialization.Model): + """The serviceName of an AvailableDelegation indicates a possible delegation for a subnet. + + :param name: The name of the AvailableDelegation resource. + :type name: str + :param id: A unique identifier of the AvailableDelegation resource. + :type id: str + :param type: Resource type. + :type type: str + :param service_name: The name of the service and resource. + :type service_name: str + :param actions: The actions permitted to the service upon delegation. + :type actions: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + 'actions': {'key': 'actions', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableDelegation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.type = kwargs.get('type', None) + self.service_name = kwargs.get('service_name', None) + self.actions = kwargs.get('actions', None) + + +class AvailableDelegationsResult(msrest.serialization.Model): + """An array of available delegations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available delegations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailableDelegation] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailableDelegation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableDelegationsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class AvailablePrivateEndpointType(msrest.serialization.Model): + """The information of an AvailablePrivateEndpointType. + + :param name: The name of the service and resource. + :type name: str + :param id: A unique identifier of the AvailablePrivateEndpoint Type resource. + :type id: str + :param type: Resource type. + :type type: str + :param resource_name: The name of the service and resource. + :type resource_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailablePrivateEndpointType, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.type = kwargs.get('type', None) + self.resource_name = kwargs.get('resource_name', None) + + +class AvailablePrivateEndpointTypesResult(msrest.serialization.Model): + """An array of available PrivateEndpoint types. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available privateEndpoint type. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointType] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailablePrivateEndpointType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailablePrivateEndpointTypesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class AvailableProvidersList(msrest.serialization.Model): + """List of available countries with details. + + All required parameters must be populated in order to send to Azure. + + :param countries: Required. List of available countries. + :type countries: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListCountry] + """ + + _validation = { + 'countries': {'required': True}, + } + + _attribute_map = { + 'countries': {'key': 'countries', 'type': '[AvailableProvidersListCountry]'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableProvidersList, self).__init__(**kwargs) + self.countries = kwargs['countries'] + + +class AvailableProvidersListCity(msrest.serialization.Model): + """City or town details. + + :param city_name: The city or town name. + :type city_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + """ + + _attribute_map = { + 'city_name': {'key': 'cityName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableProvidersListCity, self).__init__(**kwargs) + self.city_name = kwargs.get('city_name', None) + self.providers = kwargs.get('providers', None) + + +class AvailableProvidersListCountry(msrest.serialization.Model): + """Country details. + + :param country_name: The country name. + :type country_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + :param states: List of available states in the country. + :type states: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListState] + """ + + _attribute_map = { + 'country_name': {'key': 'countryName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'states': {'key': 'states', 'type': '[AvailableProvidersListState]'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableProvidersListCountry, self).__init__(**kwargs) + self.country_name = kwargs.get('country_name', None) + self.providers = kwargs.get('providers', None) + self.states = kwargs.get('states', None) + + +class AvailableProvidersListParameters(msrest.serialization.Model): + """Constraints that determine the list of available Internet service providers. + + :param azure_locations: A list of Azure regions. + :type azure_locations: list[str] + :param country: The country for available providers list. + :type country: str + :param state: The state for available providers list. + :type state: str + :param city: The city or town for available providers list. + :type city: str + """ + + _attribute_map = { + 'azure_locations': {'key': 'azureLocations', 'type': '[str]'}, + 'country': {'key': 'country', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableProvidersListParameters, self).__init__(**kwargs) + self.azure_locations = kwargs.get('azure_locations', None) + self.country = kwargs.get('country', None) + self.state = kwargs.get('state', None) + self.city = kwargs.get('city', None) + + +class AvailableProvidersListState(msrest.serialization.Model): + """State details. + + :param state_name: The state name. + :type state_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + :param cities: List of available cities or towns in the state. + :type cities: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListCity] + """ + + _attribute_map = { + 'state_name': {'key': 'stateName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'cities': {'key': 'cities', 'type': '[AvailableProvidersListCity]'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableProvidersListState, self).__init__(**kwargs) + self.state_name = kwargs.get('state_name', None) + self.providers = kwargs.get('providers', None) + self.cities = kwargs.get('cities', None) + + +class AvailableServiceAlias(msrest.serialization.Model): + """The available service alias. + + :param name: The name of the service alias. + :type name: str + :param id: The ID of the service alias. + :type id: str + :param type: The type of the resource. + :type type: str + :param resource_name: The resource name of the service alias. + :type resource_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableServiceAlias, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.type = kwargs.get('type', None) + self.resource_name = kwargs.get('resource_name', None) + + +class AvailableServiceAliasesResult(msrest.serialization.Model): + """An array of available service aliases. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available service aliases. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAlias] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailableServiceAlias]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableServiceAliasesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class AzureAsyncOperationResult(msrest.serialization.Model): + """The response body contains the status of the specified asynchronous operation, indicating whether it has succeeded, is in progress, or has failed. Note that this status is distinct from the HTTP status code returned for the Get Operation Status operation itself. If the asynchronous operation succeeded, the response body includes the HTTP status code for the successful request. If the asynchronous operation failed, the response body includes the HTTP status code for the failed request and error information regarding the failure. + + :param status: Status of the Azure async operation. Possible values include: "InProgress", + "Succeeded", "Failed". + :type status: str or ~azure.mgmt.network.v2020_08_01.models.NetworkOperationStatus + :param error: Details of the error occurred during specified asynchronous operation. + :type error: ~azure.mgmt.network.v2020_08_01.models.Error + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'Error'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureAsyncOperationResult, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.error = kwargs.get('error', None) + + +class AzureFirewall(Resource): + """Azure Firewall resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 zones: A list of availability zones denoting where the resource needs to come from. + :type zones: list[str] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param application_rule_collections: Collection of application rule collections used by Azure + Firewall. + :type application_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleCollection] + :param nat_rule_collections: Collection of NAT rule collections used by Azure Firewall. + :type nat_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRuleCollection] + :param network_rule_collections: Collection of network rule collections used by Azure Firewall. + :type network_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleCollection] + :param ip_configurations: IP configuration of the Azure Firewall resource. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallIPConfiguration] + :param management_ip_configuration: IP configuration of the Azure Firewall used for management + traffic. + :type management_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallIPConfiguration + :ivar provisioning_state: The provisioning state of the Azure firewall resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param threat_intel_mode: The operation mode for Threat Intelligence. Possible values include: + "Alert", "Deny", "Off". + :type threat_intel_mode: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallThreatIntelMode + :param virtual_hub: The virtualHub to which the firewall belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param firewall_policy: The firewallPolicy associated with this azure firewall. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param hub_ip_addresses: IP addresses associated with AzureFirewall. + :type hub_ip_addresses: ~azure.mgmt.network.v2020_08_01.models.HubIPAddresses + :ivar ip_groups: IpGroups associated with AzureFirewall. + :vartype ip_groups: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallIpGroups] + :param sku: The Azure Firewall Resource SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSku + :param additional_properties: The additional properties used to further config this azure + firewall. + :type additional_properties: dict[str, str] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'ip_groups': {'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}'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'application_rule_collections': {'key': 'properties.applicationRuleCollections', 'type': '[AzureFirewallApplicationRuleCollection]'}, + 'nat_rule_collections': {'key': 'properties.natRuleCollections', 'type': '[AzureFirewallNatRuleCollection]'}, + 'network_rule_collections': {'key': 'properties.networkRuleCollections', 'type': '[AzureFirewallNetworkRuleCollection]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[AzureFirewallIPConfiguration]'}, + 'management_ip_configuration': {'key': 'properties.managementIpConfiguration', 'type': 'AzureFirewallIPConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'threat_intel_mode': {'key': 'properties.threatIntelMode', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'hub_ip_addresses': {'key': 'properties.hubIPAddresses', 'type': 'HubIPAddresses'}, + 'ip_groups': {'key': 'properties.ipGroups', 'type': '[AzureFirewallIpGroups]'}, + 'sku': {'key': 'properties.sku', 'type': 'AzureFirewallSku'}, + 'additional_properties': {'key': 'properties.additionalProperties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewall, self).__init__(**kwargs) + self.zones = kwargs.get('zones', None) + self.etag = None + self.application_rule_collections = kwargs.get('application_rule_collections', None) + self.nat_rule_collections = kwargs.get('nat_rule_collections', None) + self.network_rule_collections = kwargs.get('network_rule_collections', None) + self.ip_configurations = kwargs.get('ip_configurations', None) + self.management_ip_configuration = kwargs.get('management_ip_configuration', None) + self.provisioning_state = None + self.threat_intel_mode = kwargs.get('threat_intel_mode', None) + self.virtual_hub = kwargs.get('virtual_hub', None) + self.firewall_policy = kwargs.get('firewall_policy', None) + self.hub_ip_addresses = kwargs.get('hub_ip_addresses', None) + self.ip_groups = None + self.sku = kwargs.get('sku', None) + self.additional_properties = kwargs.get('additional_properties', None) + + +class AzureFirewallApplicationRule(msrest.serialization.Model): + """Properties of an application rule. + + :param name: Name of the application rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param protocols: Array of ApplicationRuleProtocols. + :type protocols: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleProtocol] + :param target_fqdns: List of FQDNs for this rule. + :type target_fqdns: list[str] + :param fqdn_tags: List of FQDN Tags for this rule. + :type fqdn_tags: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[AzureFirewallApplicationRuleProtocol]'}, + 'target_fqdns': {'key': 'targetFqdns', 'type': '[str]'}, + 'fqdn_tags': {'key': 'fqdnTags', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallApplicationRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.protocols = kwargs.get('protocols', None) + self.target_fqdns = kwargs.get('target_fqdns', None) + self.fqdn_tags = kwargs.get('fqdn_tags', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + + +class AzureFirewallApplicationRuleCollection(SubResource): + """Application rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the application rule collection resource. + :type priority: int + :param action: The action type of a rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCAction + :param rules: Collection of rules used by a application rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRule] + :ivar provisioning_state: The provisioning state of the application rule collection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallApplicationRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallApplicationRuleCollection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.priority = kwargs.get('priority', None) + self.action = kwargs.get('action', None) + self.rules = kwargs.get('rules', None) + self.provisioning_state = None + + +class AzureFirewallApplicationRuleProtocol(msrest.serialization.Model): + """Properties of the application rule protocol. + + :param protocol_type: Protocol type. Possible values include: "Http", "Https", "Mssql". + :type protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleProtocolType + :param port: Port number for the protocol, cannot be greater than 64000. This field is + optional. + :type port: int + """ + + _validation = { + 'port': {'maximum': 64000, 'minimum': 0}, + } + + _attribute_map = { + 'protocol_type': {'key': 'protocolType', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallApplicationRuleProtocol, self).__init__(**kwargs) + self.protocol_type = kwargs.get('protocol_type', None) + self.port = kwargs.get('port', None) + + +class AzureFirewallFqdnTag(Resource): + """Azure Firewall FQDN Tag Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the Azure firewall FQDN tag resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar fqdn_tag_name: The name of this FQDN Tag. + :vartype fqdn_tag_name: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'fqdn_tag_name': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'fqdn_tag_name': {'key': 'properties.fqdnTagName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallFqdnTag, self).__init__(**kwargs) + self.etag = None + self.provisioning_state = None + self.fqdn_tag_name = None + + +class AzureFirewallFqdnTagListResult(msrest.serialization.Model): + """Response for ListAzureFirewallFqdnTags API service call. + + :param value: List of Azure Firewall FQDN Tags in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallFqdnTag] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureFirewallFqdnTag]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallFqdnTagListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class AzureFirewallIPConfiguration(SubResource): + """IP configuration of an Azure Firewall. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar private_ip_address: The Firewall Internal Load Balancer IP to be used as the next hop in + User Defined Routes. + :vartype private_ip_address: str + :param subnet: Reference to the subnet resource. This resource must be named + 'AzureFirewallSubnet' or 'AzureFirewallManagementSubnet'. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference to the PublicIP resource. This field is a mandatory input + if subnet is not null. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the Azure firewall IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_ip_address = None + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.provisioning_state = None + + +class AzureFirewallIpGroups(msrest.serialization.Model): + """IpGroups associated with azure firewall. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar change_number: The iteration number. + :vartype change_number: str + """ + + _validation = { + 'id': {'readonly': True}, + 'change_number': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallIpGroups, self).__init__(**kwargs) + self.id = None + self.change_number = None + + +class AzureFirewallListResult(msrest.serialization.Model): + """Response for ListAzureFirewalls API service call. + + :param value: List of Azure Firewalls in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureFirewall]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class AzureFirewallNatRCAction(msrest.serialization.Model): + """AzureFirewall NAT Rule Collection Action. + + :param type: The type of action. Possible values include: "Snat", "Dnat". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRCActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallNatRCAction, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + + +class AzureFirewallNatRule(msrest.serialization.Model): + """Properties of a NAT rule. + + :param name: Name of the NAT rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses for this rule. Supports IP + ranges, prefixes, and service tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param protocols: Array of AzureFirewallNetworkRuleProtocols applicable to this NAT rule. + :type protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleProtocol] + :param translated_address: The translated address for this NAT rule. + :type translated_address: str + :param translated_port: The translated port for this NAT rule. + :type translated_port: str + :param translated_fqdn: The translated FQDN for this NAT rule. + :type translated_fqdn: str + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[str]'}, + 'translated_address': {'key': 'translatedAddress', 'type': 'str'}, + 'translated_port': {'key': 'translatedPort', 'type': 'str'}, + 'translated_fqdn': {'key': 'translatedFqdn', 'type': 'str'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallNatRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.destination_ports = kwargs.get('destination_ports', None) + self.protocols = kwargs.get('protocols', None) + self.translated_address = kwargs.get('translated_address', None) + self.translated_port = kwargs.get('translated_port', None) + self.translated_fqdn = kwargs.get('translated_fqdn', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + + +class AzureFirewallNatRuleCollection(SubResource): + """NAT rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the NAT rule collection resource. + :type priority: int + :param action: The action type of a NAT rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRCAction + :param rules: Collection of rules used by a NAT rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRule] + :ivar provisioning_state: The provisioning state of the NAT rule collection resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallNatRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallNatRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallNatRuleCollection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.priority = kwargs.get('priority', None) + self.action = kwargs.get('action', None) + self.rules = kwargs.get('rules', None) + self.provisioning_state = None + + +class AzureFirewallNetworkRule(msrest.serialization.Model): + """Properties of the network rule. + + :param name: Name of the network rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param protocols: Array of AzureFirewallNetworkRuleProtocols. + :type protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param destination_fqdns: List of destination FQDNs. + :type destination_fqdns: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocols': {'key': 'protocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'destination_fqdns': {'key': 'destinationFqdns', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallNetworkRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.protocols = kwargs.get('protocols', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.destination_ports = kwargs.get('destination_ports', None) + self.destination_fqdns = kwargs.get('destination_fqdns', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + self.destination_ip_groups = kwargs.get('destination_ip_groups', None) + + +class AzureFirewallNetworkRuleCollection(SubResource): + """Network rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the network rule collection resource. + :type priority: int + :param action: The action type of a rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCAction + :param rules: Collection of rules used by a network rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRule] + :ivar provisioning_state: The provisioning state of the network rule collection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallNetworkRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallNetworkRuleCollection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.priority = kwargs.get('priority', None) + self.action = kwargs.get('action', None) + self.rules = kwargs.get('rules', None) + self.provisioning_state = None + + +class AzureFirewallPublicIPAddress(msrest.serialization.Model): + """Public IP Address associated with azure firewall. + + :param address: Public IP Address value. + :type address: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallPublicIPAddress, self).__init__(**kwargs) + self.address = kwargs.get('address', None) + + +class AzureFirewallRCAction(msrest.serialization.Model): + """Properties of the AzureFirewallRCAction. + + :param type: The type of action. Possible values include: "Allow", "Deny". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallRCAction, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + + +class AzureFirewallSku(msrest.serialization.Model): + """SKU of an Azure Firewall. + + :param name: Name of an Azure Firewall SKU. Possible values include: "AZFW_VNet", "AZFW_Hub". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSkuName + :param tier: Tier of an Azure Firewall. Possible values include: "Standard", "Premium". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallSku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + + +class AzureReachabilityReport(msrest.serialization.Model): + """Azure reachability report details. + + All required parameters must be populated in order to send to Azure. + + :param aggregation_level: Required. The aggregation level of Azure reachability report. Can be + Country, State or City. + :type aggregation_level: str + :param provider_location: Required. Parameters that define a geographic location. + :type provider_location: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLocation + :param reachability_report: Required. List of Azure reachability report items. + :type reachability_report: + list[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportItem] + """ + + _validation = { + 'aggregation_level': {'required': True}, + 'provider_location': {'required': True}, + 'reachability_report': {'required': True}, + } + + _attribute_map = { + 'aggregation_level': {'key': 'aggregationLevel', 'type': 'str'}, + 'provider_location': {'key': 'providerLocation', 'type': 'AzureReachabilityReportLocation'}, + 'reachability_report': {'key': 'reachabilityReport', 'type': '[AzureReachabilityReportItem]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureReachabilityReport, self).__init__(**kwargs) + self.aggregation_level = kwargs['aggregation_level'] + self.provider_location = kwargs['provider_location'] + self.reachability_report = kwargs['reachability_report'] + + +class AzureReachabilityReportItem(msrest.serialization.Model): + """Azure reachability report details for a given provider location. + + :param provider: The Internet service provider. + :type provider: str + :param azure_location: The Azure region. + :type azure_location: str + :param latencies: List of latency details for each of the time series. + :type latencies: + list[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLatencyInfo] + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'azure_location': {'key': 'azureLocation', 'type': 'str'}, + 'latencies': {'key': 'latencies', 'type': '[AzureReachabilityReportLatencyInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureReachabilityReportItem, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.azure_location = kwargs.get('azure_location', None) + self.latencies = kwargs.get('latencies', None) + + +class AzureReachabilityReportLatencyInfo(msrest.serialization.Model): + """Details on latency for a time series. + + :param time_stamp: The time stamp. + :type time_stamp: ~datetime.datetime + :param score: The relative latency score between 1 and 100, higher values indicating a faster + connection. + :type score: int + """ + + _validation = { + 'score': {'maximum': 100, 'minimum': 1}, + } + + _attribute_map = { + 'time_stamp': {'key': 'timeStamp', 'type': 'iso-8601'}, + 'score': {'key': 'score', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureReachabilityReportLatencyInfo, self).__init__(**kwargs) + self.time_stamp = kwargs.get('time_stamp', None) + self.score = kwargs.get('score', None) + + +class AzureReachabilityReportLocation(msrest.serialization.Model): + """Parameters that define a geographic location. + + All required parameters must be populated in order to send to Azure. + + :param country: Required. The name of the country. + :type country: str + :param state: The name of the state. + :type state: str + :param city: The name of the city or town. + :type city: str + """ + + _validation = { + 'country': {'required': True}, + } + + _attribute_map = { + 'country': {'key': 'country', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureReachabilityReportLocation, self).__init__(**kwargs) + self.country = kwargs['country'] + self.state = kwargs.get('state', None) + self.city = kwargs.get('city', None) + + +class AzureReachabilityReportParameters(msrest.serialization.Model): + """Geographic and time constraints for Azure reachability report. + + All required parameters must be populated in order to send to Azure. + + :param provider_location: Required. Parameters that define a geographic location. + :type provider_location: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLocation + :param providers: List of Internet service providers. + :type providers: list[str] + :param azure_locations: Optional Azure regions to scope the query to. + :type azure_locations: list[str] + :param start_time: Required. The start time for the Azure reachability report. + :type start_time: ~datetime.datetime + :param end_time: Required. The end time for the Azure reachability report. + :type end_time: ~datetime.datetime + """ + + _validation = { + 'provider_location': {'required': True}, + 'start_time': {'required': True}, + 'end_time': {'required': True}, + } + + _attribute_map = { + 'provider_location': {'key': 'providerLocation', 'type': 'AzureReachabilityReportLocation'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'azure_locations': {'key': 'azureLocations', 'type': '[str]'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureReachabilityReportParameters, self).__init__(**kwargs) + self.provider_location = kwargs['provider_location'] + self.providers = kwargs.get('providers', None) + self.azure_locations = kwargs.get('azure_locations', None) + self.start_time = kwargs['start_time'] + self.end_time = kwargs['end_time'] + + +class AzureWebCategory(msrest.serialization.Model): + """Azure Web Category Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar group: The name of the group that the category belongs to. + :vartype group: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'group': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'group': {'key': 'properties.group', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureWebCategory, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = None + self.type = None + self.etag = None + self.group = None + + +class AzureWebCategoryListResult(msrest.serialization.Model): + """Response for ListAzureWebCategories API service call. + + :param value: List of Azure Web Categories for a given Subscription. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureWebCategory] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureWebCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureWebCategoryListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BackendAddressPool(SubResource): + """Pool of backend IP addresses. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of backend address pools + used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param location: The location of the backend address pool. + :type location: str + :param load_balancer_backend_addresses: An array of backend addresses. + :type load_balancer_backend_addresses: + list[~azure.mgmt.network.v2020_08_01.models.LoadBalancerBackendAddress] + :ivar backend_ip_configurations: An array of references to IP addresses defined in network + interfaces. + :vartype backend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar load_balancing_rules: An array of references to load balancing rules that use this + backend address pool. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar outbound_rule: A reference to an outbound rule that uses this backend address pool. + :vartype outbound_rule: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar outbound_rules: An array of references to outbound rules that use this backend address + pool. + :vartype outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the backend address pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configurations': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'outbound_rule': {'readonly': True}, + 'outbound_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'load_balancer_backend_addresses': {'key': 'properties.loadBalancerBackendAddresses', 'type': '[LoadBalancerBackendAddress]'}, + 'backend_ip_configurations': {'key': 'properties.backendIPConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'outbound_rule': {'key': 'properties.outboundRule', 'type': 'SubResource'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BackendAddressPool, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.location = kwargs.get('location', None) + self.load_balancer_backend_addresses = kwargs.get('load_balancer_backend_addresses', None) + self.backend_ip_configurations = None + self.load_balancing_rules = None + self.outbound_rule = None + self.outbound_rules = None + self.provisioning_state = None + + +class BastionActiveSession(msrest.serialization.Model): + """The session detail for a target. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar session_id: A unique id for the session. + :vartype session_id: str + :ivar start_time: The time when the session started. + :vartype start_time: object + :ivar target_subscription_id: The subscription id for the target virtual machine. + :vartype target_subscription_id: str + :ivar resource_type: The type of the resource. + :vartype resource_type: str + :ivar target_host_name: The host name of the target. + :vartype target_host_name: str + :ivar target_resource_group: The resource group of the target. + :vartype target_resource_group: str + :ivar user_name: The user name who is active on this session. + :vartype user_name: str + :ivar target_ip_address: The IP Address of the target. + :vartype target_ip_address: str + :ivar protocol: The protocol used to connect to the target. Possible values include: "SSH", + "RDP". + :vartype protocol: str or ~azure.mgmt.network.v2020_08_01.models.BastionConnectProtocol + :ivar target_resource_id: The resource id of the target. + :vartype target_resource_id: str + :ivar session_duration_in_mins: Duration in mins the session has been active. + :vartype session_duration_in_mins: float + """ + + _validation = { + 'session_id': {'readonly': True}, + 'start_time': {'readonly': True}, + 'target_subscription_id': {'readonly': True}, + 'resource_type': {'readonly': True}, + 'target_host_name': {'readonly': True}, + 'target_resource_group': {'readonly': True}, + 'user_name': {'readonly': True}, + 'target_ip_address': {'readonly': True}, + 'protocol': {'readonly': True}, + 'target_resource_id': {'readonly': True}, + 'session_duration_in_mins': {'readonly': True}, + } + + _attribute_map = { + 'session_id': {'key': 'sessionId', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'object'}, + 'target_subscription_id': {'key': 'targetSubscriptionId', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'target_host_name': {'key': 'targetHostName', 'type': 'str'}, + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'user_name': {'key': 'userName', 'type': 'str'}, + 'target_ip_address': {'key': 'targetIpAddress', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'session_duration_in_mins': {'key': 'sessionDurationInMins', 'type': 'float'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionActiveSession, self).__init__(**kwargs) + self.session_id = None + self.start_time = None + self.target_subscription_id = None + self.resource_type = None + self.target_host_name = None + self.target_resource_group = None + self.user_name = None + self.target_ip_address = None + self.protocol = None + self.target_resource_id = None + self.session_duration_in_mins = None + + +class BastionActiveSessionListResult(msrest.serialization.Model): + """Response for GetActiveSessions. + + :param value: List of active sessions on the bastion. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionActiveSession] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionActiveSession]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionActiveSessionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BastionHost(Resource): + """Bastion Host resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: IP configuration of the Bastion Host resource. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.BastionHostIPConfiguration] + :param dns_name: FQDN for the endpoint on which bastion host is accessible. + :type dns_name: str + :ivar provisioning_state: The provisioning state of the bastion host resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[BastionHostIPConfiguration]'}, + 'dns_name': {'key': 'properties.dnsName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionHost, self).__init__(**kwargs) + self.etag = None + self.ip_configurations = kwargs.get('ip_configurations', None) + self.dns_name = kwargs.get('dns_name', None) + self.provisioning_state = None + + +class BastionHostIPConfiguration(SubResource): + """IP configuration of an Bastion Host. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Ip configuration type. + :vartype type: str + :param subnet: Reference of the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference of the PublicIP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the bastion host IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_ip_allocation_method: Private IP allocation method. Possible values include: + "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionHostIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.provisioning_state = None + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + + +class BastionHostListResult(msrest.serialization.Model): + """Response for ListBastionHosts API service call. + + :param value: List of Bastion Hosts in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionHost] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionHost]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionHostListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BastionSessionDeleteResult(msrest.serialization.Model): + """Response for DisconnectActiveSessions. + + :param value: List of sessions with their corresponding state. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionSessionState] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionSessionState]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionSessionDeleteResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BastionSessionState(msrest.serialization.Model): + """The session state detail for a target. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar session_id: A unique id for the session. + :vartype session_id: str + :ivar message: Used for extra information. + :vartype message: str + :ivar state: The state of the session. Disconnected/Failed/NotFound. + :vartype state: str + """ + + _validation = { + 'session_id': {'readonly': True}, + 'message': {'readonly': True}, + 'state': {'readonly': True}, + } + + _attribute_map = { + 'session_id': {'key': 'sessionId', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionSessionState, self).__init__(**kwargs) + self.session_id = None + self.message = None + self.state = None + + +class BastionShareableLink(msrest.serialization.Model): + """Bastion Shareable Link. + + Variables are only 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 vm: Required. Reference of the virtual machine resource. + :type vm: ~azure.mgmt.network.v2020_08_01.models.Resource + :ivar bsl: The unique Bastion Shareable Link to the virtual machine. + :vartype bsl: str + :ivar created_at: The time when the link was created. + :vartype created_at: str + :ivar message: Optional field indicating the warning or error message related to the vm in case + of partial failure. + :vartype message: str + """ + + _validation = { + 'vm': {'required': True}, + 'bsl': {'readonly': True}, + 'created_at': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'vm': {'key': 'vm', 'type': 'Resource'}, + 'bsl': {'key': 'bsl', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionShareableLink, self).__init__(**kwargs) + self.vm = kwargs['vm'] + self.bsl = None + self.created_at = None + self.message = None + + +class BastionShareableLinkListRequest(msrest.serialization.Model): + """Post request for all the Bastion Shareable Link endpoints. + + :param vms: List of VM references. + :type vms: list[~azure.mgmt.network.v2020_08_01.models.BastionShareableLink] + """ + + _attribute_map = { + 'vms': {'key': 'vms', 'type': '[BastionShareableLink]'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionShareableLinkListRequest, self).__init__(**kwargs) + self.vms = kwargs.get('vms', None) + + +class BastionShareableLinkListResult(msrest.serialization.Model): + """Response for all the Bastion Shareable Link endpoints. + + :param value: List of Bastion Shareable Links for the request. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionShareableLink] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionShareableLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionShareableLinkListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BGPCommunity(msrest.serialization.Model): + """Contains bgp community information offered in Service Community resources. + + :param service_supported_region: The region which the service support. e.g. For O365, region is + Global. + :type service_supported_region: str + :param community_name: The name of the bgp community. e.g. Skype. + :type community_name: str + :param community_value: The value of the bgp community. For more information: + https://docs.microsoft.com/en-us/azure/expressroute/expressroute-routing. + :type community_value: str + :param community_prefixes: The prefixes that the bgp community contains. + :type community_prefixes: list[str] + :param is_authorized_to_use: Customer is authorized to use bgp community or not. + :type is_authorized_to_use: bool + :param service_group: The service group of the bgp community contains. + :type service_group: str + """ + + _attribute_map = { + 'service_supported_region': {'key': 'serviceSupportedRegion', 'type': 'str'}, + 'community_name': {'key': 'communityName', 'type': 'str'}, + 'community_value': {'key': 'communityValue', 'type': 'str'}, + 'community_prefixes': {'key': 'communityPrefixes', 'type': '[str]'}, + 'is_authorized_to_use': {'key': 'isAuthorizedToUse', 'type': 'bool'}, + 'service_group': {'key': 'serviceGroup', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BGPCommunity, self).__init__(**kwargs) + self.service_supported_region = kwargs.get('service_supported_region', None) + self.community_name = kwargs.get('community_name', None) + self.community_value = kwargs.get('community_value', None) + self.community_prefixes = kwargs.get('community_prefixes', None) + self.is_authorized_to_use = kwargs.get('is_authorized_to_use', None) + self.service_group = kwargs.get('service_group', None) + + +class BgpConnection(SubResource): + """Virtual Appliance Site resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the connection. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Connection type. + :vartype type: str + :param peer_asn: Peer ASN. + :type peer_asn: long + :param peer_ip: Peer IP. + :type peer_ip: str + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar connection_state: The current state of the VirtualHub to Peer. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_state: str or ~azure.mgmt.network.v2020_08_01.models.HubBgpConnectionStatus + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + 'connection_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peer_asn': {'key': 'properties.peerAsn', 'type': 'long'}, + 'peer_ip': {'key': 'properties.peerIp', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'connection_state': {'key': 'properties.connectionState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.peer_asn = kwargs.get('peer_asn', None) + self.peer_ip = kwargs.get('peer_ip', None) + self.provisioning_state = None + self.connection_state = None + + +class BgpPeerStatus(msrest.serialization.Model): + """BGP peer status details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The virtual network gateway's local address. + :vartype local_address: str + :ivar neighbor: The remote BGP peer. + :vartype neighbor: str + :ivar asn: The autonomous system number of the remote BGP peer. + :vartype asn: long + :ivar state: The BGP peer state. Possible values include: "Unknown", "Stopped", "Idle", + "Connecting", "Connected". + :vartype state: str or ~azure.mgmt.network.v2020_08_01.models.BgpPeerState + :ivar connected_duration: For how long the peering has been up. + :vartype connected_duration: str + :ivar routes_received: The number of routes learned from this peer. + :vartype routes_received: long + :ivar messages_sent: The number of BGP messages sent. + :vartype messages_sent: long + :ivar messages_received: The number of BGP messages received. + :vartype messages_received: long + """ + + _validation = { + 'local_address': {'readonly': True}, + 'neighbor': {'readonly': True}, + 'asn': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'state': {'readonly': True}, + 'connected_duration': {'readonly': True}, + 'routes_received': {'readonly': True}, + 'messages_sent': {'readonly': True}, + 'messages_received': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'asn': {'key': 'asn', 'type': 'long'}, + 'state': {'key': 'state', 'type': 'str'}, + 'connected_duration': {'key': 'connectedDuration', 'type': 'str'}, + 'routes_received': {'key': 'routesReceived', 'type': 'long'}, + 'messages_sent': {'key': 'messagesSent', 'type': 'long'}, + 'messages_received': {'key': 'messagesReceived', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpPeerStatus, self).__init__(**kwargs) + self.local_address = None + self.neighbor = None + self.asn = None + self.state = None + self.connected_duration = None + self.routes_received = None + self.messages_sent = None + self.messages_received = None + + +class BgpPeerStatusListResult(msrest.serialization.Model): + """Response for list BGP peer status API service call. + + :param value: List of BGP peers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpPeerStatus] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpPeerStatus]'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpPeerStatusListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class BgpServiceCommunity(Resource): + """Service Community Properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 service_name: The name of the bgp community. e.g. Skype. + :type service_name: str + :param bgp_communities: A list of bgp communities. + :type bgp_communities: list[~azure.mgmt.network.v2020_08_01.models.BGPCommunity] + """ + + _validation = { + '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}'}, + 'service_name': {'key': 'properties.serviceName', 'type': 'str'}, + 'bgp_communities': {'key': 'properties.bgpCommunities', 'type': '[BGPCommunity]'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpServiceCommunity, self).__init__(**kwargs) + self.service_name = kwargs.get('service_name', None) + self.bgp_communities = kwargs.get('bgp_communities', None) + + +class BgpServiceCommunityListResult(msrest.serialization.Model): + """Response for the ListServiceCommunity API service call. + + :param value: A list of service community resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpServiceCommunity] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpServiceCommunity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpServiceCommunityListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class BgpSettings(msrest.serialization.Model): + """BGP settings details. + + :param asn: The BGP speaker's ASN. + :type asn: long + :param bgp_peering_address: The BGP peering address and BGP identifier of this BGP speaker. + :type bgp_peering_address: str + :param peer_weight: The weight added to routes learned from this BGP speaker. + :type peer_weight: int + :param bgp_peering_addresses: BGP peering address with IP configuration ID for virtual network + gateway. + :type bgp_peering_addresses: + list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationBgpPeeringAddress] + """ + + _validation = { + 'asn': {'maximum': 4294967295, 'minimum': 0}, + } + + _attribute_map = { + 'asn': {'key': 'asn', 'type': 'long'}, + 'bgp_peering_address': {'key': 'bgpPeeringAddress', 'type': 'str'}, + 'peer_weight': {'key': 'peerWeight', 'type': 'int'}, + 'bgp_peering_addresses': {'key': 'bgpPeeringAddresses', 'type': '[IPConfigurationBgpPeeringAddress]'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpSettings, self).__init__(**kwargs) + self.asn = kwargs.get('asn', None) + self.bgp_peering_address = kwargs.get('bgp_peering_address', None) + self.peer_weight = kwargs.get('peer_weight', None) + self.bgp_peering_addresses = kwargs.get('bgp_peering_addresses', None) + + +class BreakOutCategoryPolicies(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param allow: Flag to control breakout of o365 allow category. + :type allow: bool + :param optimize: Flag to control breakout of o365 optimize category. + :type optimize: bool + :param default: Flag to control breakout of o365 default category. + :type default: bool + """ + + _attribute_map = { + 'allow': {'key': 'allow', 'type': 'bool'}, + 'optimize': {'key': 'optimize', 'type': 'bool'}, + 'default': {'key': 'default', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(BreakOutCategoryPolicies, self).__init__(**kwargs) + self.allow = kwargs.get('allow', None) + self.optimize = kwargs.get('optimize', None) + self.default = kwargs.get('default', None) + + +class CheckPrivateLinkServiceVisibilityRequest(msrest.serialization.Model): + """Request body of the CheckPrivateLinkServiceVisibility API service call. + + :param private_link_service_alias: The alias of the private link service. + :type private_link_service_alias: str + """ + + _attribute_map = { + 'private_link_service_alias': {'key': 'privateLinkServiceAlias', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CheckPrivateLinkServiceVisibilityRequest, self).__init__(**kwargs) + self.private_link_service_alias = kwargs.get('private_link_service_alias', None) + + +class CloudErrorBody(msrest.serialization.Model): + """An error response from the service. + + :param code: An identifier for the error. Codes are invariant and are intended to be consumed + programmatically. + :type code: str + :param message: A message describing the error, intended to be suitable for display in a user + interface. + :type message: str + :param target: The target of the particular error. For example, the name of the property in + error. + :type target: str + :param details: A list of additional details about the error. + :type details: list[~azure.mgmt.network.v2020_08_01.models.CloudErrorBody] + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[CloudErrorBody]'}, + } + + def __init__( + self, + **kwargs + ): + super(CloudErrorBody, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + self.target = kwargs.get('target', None) + self.details = kwargs.get('details', 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: 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(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionMonitor(msrest.serialization.Model): + """Parameters that define the operation to create a connection monitor. + + :param location: Connection monitor location. + :type location: str + :param tags: A set of tags. Connection monitor tags. + :type tags: dict[str, str] + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'source': {'key': 'properties.source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'properties.destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'properties.autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'properties.monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'properties.endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'properties.testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'properties.testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'properties.outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'properties.notes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitor, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.tags = kwargs.get('tags', None) + self.source = kwargs.get('source', None) + self.destination = kwargs.get('destination', None) + self.auto_start = kwargs.get('auto_start', True) + self.monitoring_interval_in_seconds = kwargs.get('monitoring_interval_in_seconds', 60) + self.endpoints = kwargs.get('endpoints', None) + self.test_configurations = kwargs.get('test_configurations', None) + self.test_groups = kwargs.get('test_groups', None) + self.outputs = kwargs.get('outputs', None) + self.notes = kwargs.get('notes', None) + + +class ConnectionMonitorDestination(msrest.serialization.Model): + """Describes the destination of connection monitor. + + :param resource_id: The ID of the resource used as the destination by connection monitor. + :type resource_id: str + :param address: Address of the connection monitor destination (IP or domain name). + :type address: str + :param port: The destination port used by connection monitor. + :type port: int + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorDestination, self).__init__(**kwargs) + self.resource_id = kwargs.get('resource_id', None) + self.address = kwargs.get('address', None) + self.port = kwargs.get('port', None) + + +class ConnectionMonitorEndpoint(msrest.serialization.Model): + """Describes the connection monitor endpoint. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor endpoint. + :type name: str + :param type: The endpoint type. Possible values include: "AzureVM", "AzureVNet", "AzureSubnet", + "ExternalAddress", "MMAWorkspaceMachine", "MMAWorkspaceNetwork". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.EndpointType + :param resource_id: Resource ID of the connection monitor endpoint. + :type resource_id: str + :param address: Address of the connection monitor endpoint (IP or domain name). + :type address: str + :param filter: Filter for sub-items within the endpoint. + :type filter: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilter + :param scope: Endpoint scope. + :type scope: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScope + :param coverage_level: Test coverage for the endpoint. Possible values include: "Default", + "Low", "BelowAverage", "Average", "AboveAverage", "Full". + :type coverage_level: str or ~azure.mgmt.network.v2020_08_01.models.CoverageLevel + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'filter': {'key': 'filter', 'type': 'ConnectionMonitorEndpointFilter'}, + 'scope': {'key': 'scope', 'type': 'ConnectionMonitorEndpointScope'}, + 'coverage_level': {'key': 'coverageLevel', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorEndpoint, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs.get('type', None) + self.resource_id = kwargs.get('resource_id', None) + self.address = kwargs.get('address', None) + self.filter = kwargs.get('filter', None) + self.scope = kwargs.get('scope', None) + self.coverage_level = kwargs.get('coverage_level', None) + + +class ConnectionMonitorEndpointFilter(msrest.serialization.Model): + """Describes the connection monitor endpoint filter. + + :param type: The behavior of the endpoint filter. Currently only 'Include' is supported. + Possible values include: "Include". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterType + :param items: List of items in the filter. + :type items: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterItem] + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'items': {'key': 'items', 'type': '[ConnectionMonitorEndpointFilterItem]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorEndpointFilter, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.items = kwargs.get('items', None) + + +class ConnectionMonitorEndpointFilterItem(msrest.serialization.Model): + """Describes the connection monitor endpoint filter item. + + :param type: The type of item included in the filter. Currently only 'AgentAddress' is + supported. Possible values include: "AgentAddress". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterItemType + :param address: The address of the filter item. + :type address: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorEndpointFilterItem, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.address = kwargs.get('address', None) + + +class ConnectionMonitorEndpointScope(msrest.serialization.Model): + """Describes the connection monitor endpoint scope. + + :param include: List of items which needs to be included to the endpoint scope. + :type include: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScopeItem] + :param exclude: List of items which needs to be excluded from the endpoint scope. + :type exclude: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScopeItem] + """ + + _attribute_map = { + 'include': {'key': 'include', 'type': '[ConnectionMonitorEndpointScopeItem]'}, + 'exclude': {'key': 'exclude', 'type': '[ConnectionMonitorEndpointScopeItem]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorEndpointScope, self).__init__(**kwargs) + self.include = kwargs.get('include', None) + self.exclude = kwargs.get('exclude', None) + + +class ConnectionMonitorEndpointScopeItem(msrest.serialization.Model): + """Describes the connection monitor endpoint scope item. + + :param address: The address of the endpoint item. Supported types are IPv4/IPv6 subnet mask or + IPv4/IPv6 IP address. + :type address: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorEndpointScopeItem, self).__init__(**kwargs) + self.address = kwargs.get('address', None) + + +class ConnectionMonitorHttpConfiguration(msrest.serialization.Model): + """Describes the HTTP configuration. + + :param port: The port to connect to. + :type port: int + :param method: The HTTP method to use. Possible values include: "Get", "Post". + :type method: str or ~azure.mgmt.network.v2020_08_01.models.HTTPConfigurationMethod + :param path: The path component of the URI. For instance, "/dir1/dir2". + :type path: str + :param request_headers: The HTTP headers to transmit with the request. + :type request_headers: list[~azure.mgmt.network.v2020_08_01.models.HTTPHeader] + :param valid_status_code_ranges: HTTP status codes to consider successful. For instance, + "2xx,301-304,418". + :type valid_status_code_ranges: list[str] + :param prefer_https: Value indicating whether HTTPS is preferred over HTTP in cases where the + choice is not explicit. + :type prefer_https: bool + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'port': {'key': 'port', 'type': 'int'}, + 'method': {'key': 'method', 'type': 'str'}, + 'path': {'key': 'path', 'type': 'str'}, + 'request_headers': {'key': 'requestHeaders', 'type': '[HTTPHeader]'}, + 'valid_status_code_ranges': {'key': 'validStatusCodeRanges', 'type': '[str]'}, + 'prefer_https': {'key': 'preferHTTPS', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorHttpConfiguration, self).__init__(**kwargs) + self.port = kwargs.get('port', None) + self.method = kwargs.get('method', None) + self.path = kwargs.get('path', None) + self.request_headers = kwargs.get('request_headers', None) + self.valid_status_code_ranges = kwargs.get('valid_status_code_ranges', None) + self.prefer_https = kwargs.get('prefer_https', None) + + +class ConnectionMonitorIcmpConfiguration(msrest.serialization.Model): + """Describes the ICMP configuration. + + :param disable_trace_route: Value indicating whether path evaluation with trace route should be + disabled. + :type disable_trace_route: bool + """ + + _attribute_map = { + 'disable_trace_route': {'key': 'disableTraceRoute', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorIcmpConfiguration, self).__init__(**kwargs) + self.disable_trace_route = kwargs.get('disable_trace_route', None) + + +class ConnectionMonitorListResult(msrest.serialization.Model): + """List of connection monitors. + + :param value: Information about connection monitors. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ConnectionMonitorResult]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class ConnectionMonitorOutput(msrest.serialization.Model): + """Describes a connection monitor output destination. + + :param type: Connection monitor output destination type. Currently, only "Workspace" is + supported. Possible values include: "Workspace". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.OutputType + :param workspace_settings: Describes the settings for producing output into a log analytics + workspace. + :type workspace_settings: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorWorkspaceSettings + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'workspace_settings': {'key': 'workspaceSettings', 'type': 'ConnectionMonitorWorkspaceSettings'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorOutput, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.workspace_settings = kwargs.get('workspace_settings', None) + + +class ConnectionMonitorParameters(msrest.serialization.Model): + """Parameters that define the operation to create a connection monitor. + + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'notes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorParameters, self).__init__(**kwargs) + self.source = kwargs.get('source', None) + self.destination = kwargs.get('destination', None) + self.auto_start = kwargs.get('auto_start', True) + self.monitoring_interval_in_seconds = kwargs.get('monitoring_interval_in_seconds', 60) + self.endpoints = kwargs.get('endpoints', None) + self.test_configurations = kwargs.get('test_configurations', None) + self.test_groups = kwargs.get('test_groups', None) + self.outputs = kwargs.get('outputs', None) + self.notes = kwargs.get('notes', None) + + +class ConnectionMonitorQueryResult(msrest.serialization.Model): + """List of connection states snapshots. + + :param source_status: Status of connection monitor source. Possible values include: "Unknown", + "Active", "Inactive". + :type source_status: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSourceStatus + :param states: Information about connection states. + :type states: list[~azure.mgmt.network.v2020_08_01.models.ConnectionStateSnapshot] + """ + + _attribute_map = { + 'source_status': {'key': 'sourceStatus', 'type': 'str'}, + 'states': {'key': 'states', 'type': '[ConnectionStateSnapshot]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorQueryResult, self).__init__(**kwargs) + self.source_status = kwargs.get('source_status', None) + self.states = kwargs.get('states', None) + + +class ConnectionMonitorResult(msrest.serialization.Model): + """Information about the connection monitor. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: Name of the connection monitor. + :vartype name: str + :ivar id: ID of the connection monitor. + :vartype id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Connection monitor type. + :vartype type: str + :param location: Connection monitor location. + :type location: str + :param tags: A set of tags. Connection monitor tags. + :type tags: dict[str, str] + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + :ivar provisioning_state: The provisioning state of the connection monitor. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar start_time: The date and time when the connection monitor was started. + :vartype start_time: ~datetime.datetime + :ivar monitoring_status: The monitoring status of the connection monitor. + :vartype monitoring_status: str + :ivar connection_monitor_type: Type of connection monitor. Possible values include: + "MultiEndpoint", "SingleSourceDestination". + :vartype connection_monitor_type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorType + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'monitoring_status': {'readonly': True}, + 'connection_monitor_type': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'source': {'key': 'properties.source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'properties.destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'properties.autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'properties.monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'properties.endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'properties.testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'properties.testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'properties.outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'properties.notes', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'monitoring_status': {'key': 'properties.monitoringStatus', 'type': 'str'}, + 'connection_monitor_type': {'key': 'properties.connectionMonitorType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.etag = None + self.type = None + self.location = kwargs.get('location', None) + self.tags = kwargs.get('tags', None) + self.source = kwargs.get('source', None) + self.destination = kwargs.get('destination', None) + self.auto_start = kwargs.get('auto_start', True) + self.monitoring_interval_in_seconds = kwargs.get('monitoring_interval_in_seconds', 60) + self.endpoints = kwargs.get('endpoints', None) + self.test_configurations = kwargs.get('test_configurations', None) + self.test_groups = kwargs.get('test_groups', None) + self.outputs = kwargs.get('outputs', None) + self.notes = kwargs.get('notes', None) + self.provisioning_state = None + self.start_time = None + self.monitoring_status = None + self.connection_monitor_type = None + + +class ConnectionMonitorResultProperties(ConnectionMonitorParameters): + """Describes the properties of a connection monitor. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + :ivar provisioning_state: The provisioning state of the connection monitor. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar start_time: The date and time when the connection monitor was started. + :vartype start_time: ~datetime.datetime + :ivar monitoring_status: The monitoring status of the connection monitor. + :vartype monitoring_status: str + :ivar connection_monitor_type: Type of connection monitor. Possible values include: + "MultiEndpoint", "SingleSourceDestination". + :vartype connection_monitor_type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorType + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'monitoring_status': {'readonly': True}, + 'connection_monitor_type': {'readonly': True}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'notes', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'monitoring_status': {'key': 'monitoringStatus', 'type': 'str'}, + 'connection_monitor_type': {'key': 'connectionMonitorType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorResultProperties, self).__init__(**kwargs) + self.provisioning_state = None + self.start_time = None + self.monitoring_status = None + self.connection_monitor_type = None + + +class ConnectionMonitorSource(msrest.serialization.Model): + """Describes the source of connection monitor. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. The ID of the resource used as the source by connection monitor. + :type resource_id: str + :param port: The source port used by connection monitor. + :type port: int + """ + + _validation = { + 'resource_id': {'required': True}, + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorSource, self).__init__(**kwargs) + self.resource_id = kwargs['resource_id'] + self.port = kwargs.get('port', None) + + +class ConnectionMonitorSuccessThreshold(msrest.serialization.Model): + """Describes the threshold for declaring a test successful. + + :param checks_failed_percent: The maximum percentage of failed checks permitted for a test to + evaluate as successful. + :type checks_failed_percent: int + :param round_trip_time_ms: The maximum round-trip time in milliseconds permitted for a test to + evaluate as successful. + :type round_trip_time_ms: float + """ + + _attribute_map = { + 'checks_failed_percent': {'key': 'checksFailedPercent', 'type': 'int'}, + 'round_trip_time_ms': {'key': 'roundTripTimeMs', 'type': 'float'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorSuccessThreshold, self).__init__(**kwargs) + self.checks_failed_percent = kwargs.get('checks_failed_percent', None) + self.round_trip_time_ms = kwargs.get('round_trip_time_ms', None) + + +class ConnectionMonitorTcpConfiguration(msrest.serialization.Model): + """Describes the TCP configuration. + + :param port: The port to connect to. + :type port: int + :param disable_trace_route: Value indicating whether path evaluation with trace route should be + disabled. + :type disable_trace_route: bool + :param destination_port_behavior: Destination port behavior. Possible values include: "None", + "ListenIfAvailable". + :type destination_port_behavior: str or + ~azure.mgmt.network.v2020_08_01.models.DestinationPortBehavior + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'port': {'key': 'port', 'type': 'int'}, + 'disable_trace_route': {'key': 'disableTraceRoute', 'type': 'bool'}, + 'destination_port_behavior': {'key': 'destinationPortBehavior', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorTcpConfiguration, self).__init__(**kwargs) + self.port = kwargs.get('port', None) + self.disable_trace_route = kwargs.get('disable_trace_route', None) + self.destination_port_behavior = kwargs.get('destination_port_behavior', None) + + +class ConnectionMonitorTestConfiguration(msrest.serialization.Model): + """Describes a connection monitor test configuration. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor test configuration. + :type name: str + :param test_frequency_sec: The frequency of test evaluation, in seconds. + :type test_frequency_sec: int + :param protocol: Required. The protocol to use in test evaluation. Possible values include: + "Tcp", "Http", "Icmp". + :type protocol: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfigurationProtocol + :param preferred_ip_version: The preferred IP version to use in test evaluation. The connection + monitor may choose to use a different version depending on other parameters. Possible values + include: "IPv4", "IPv6". + :type preferred_ip_version: str or ~azure.mgmt.network.v2020_08_01.models.PreferredIPVersion + :param http_configuration: The parameters used to perform test evaluation over HTTP. + :type http_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorHttpConfiguration + :param tcp_configuration: The parameters used to perform test evaluation over TCP. + :type tcp_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTcpConfiguration + :param icmp_configuration: The parameters used to perform test evaluation over ICMP. + :type icmp_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorIcmpConfiguration + :param success_threshold: The threshold for declaring a test successful. + :type success_threshold: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSuccessThreshold + """ + + _validation = { + 'name': {'required': True}, + 'protocol': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'test_frequency_sec': {'key': 'testFrequencySec', 'type': 'int'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'preferred_ip_version': {'key': 'preferredIPVersion', 'type': 'str'}, + 'http_configuration': {'key': 'httpConfiguration', 'type': 'ConnectionMonitorHttpConfiguration'}, + 'tcp_configuration': {'key': 'tcpConfiguration', 'type': 'ConnectionMonitorTcpConfiguration'}, + 'icmp_configuration': {'key': 'icmpConfiguration', 'type': 'ConnectionMonitorIcmpConfiguration'}, + 'success_threshold': {'key': 'successThreshold', 'type': 'ConnectionMonitorSuccessThreshold'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorTestConfiguration, self).__init__(**kwargs) + self.name = kwargs['name'] + self.test_frequency_sec = kwargs.get('test_frequency_sec', None) + self.protocol = kwargs['protocol'] + self.preferred_ip_version = kwargs.get('preferred_ip_version', None) + self.http_configuration = kwargs.get('http_configuration', None) + self.tcp_configuration = kwargs.get('tcp_configuration', None) + self.icmp_configuration = kwargs.get('icmp_configuration', None) + self.success_threshold = kwargs.get('success_threshold', None) + + +class ConnectionMonitorTestGroup(msrest.serialization.Model): + """Describes the connection monitor test group. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor test group. + :type name: str + :param disable: Value indicating whether test group is disabled. + :type disable: bool + :param test_configurations: Required. List of test configuration names. + :type test_configurations: list[str] + :param sources: Required. List of source endpoint names. + :type sources: list[str] + :param destinations: Required. List of destination endpoint names. + :type destinations: list[str] + """ + + _validation = { + 'name': {'required': True}, + 'test_configurations': {'required': True}, + 'sources': {'required': True}, + 'destinations': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'disable': {'key': 'disable', 'type': 'bool'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[str]'}, + 'sources': {'key': 'sources', 'type': '[str]'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorTestGroup, self).__init__(**kwargs) + self.name = kwargs['name'] + self.disable = kwargs.get('disable', None) + self.test_configurations = kwargs['test_configurations'] + self.sources = kwargs['sources'] + self.destinations = kwargs['destinations'] + + +class ConnectionMonitorWorkspaceSettings(msrest.serialization.Model): + """Describes the settings for producing output into a log analytics workspace. + + :param workspace_resource_id: Log analytics workspace resource ID. + :type workspace_resource_id: str + """ + + _attribute_map = { + 'workspace_resource_id': {'key': 'workspaceResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionMonitorWorkspaceSettings, self).__init__(**kwargs) + self.workspace_resource_id = kwargs.get('workspace_resource_id', None) + + +class ConnectionResetSharedKey(msrest.serialization.Model): + """The virtual network connection reset shared key. + + All required parameters must be populated in order to send to Azure. + + :param key_length: Required. The virtual network connection reset shared key length, should + between 1 and 128. + :type key_length: int + """ + + _validation = { + 'key_length': {'required': True, 'maximum': 128, 'minimum': 1}, + } + + _attribute_map = { + 'key_length': {'key': 'keyLength', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionResetSharedKey, self).__init__(**kwargs) + self.key_length = kwargs['key_length'] + + +class ConnectionSharedKey(SubResource): + """Response for GetConnectionSharedKey API service call. + + All required parameters must be populated in order to send to Azure. + + :param id: Resource ID. + :type id: str + :param value: Required. The virtual network connection shared key value. + :type value: str + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionSharedKey, self).__init__(**kwargs) + self.value = kwargs['value'] + + +class ConnectionStateSnapshot(msrest.serialization.Model): + """Connection state snapshot. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param connection_state: The connection state. Possible values include: "Reachable", + "Unreachable", "Unknown". + :type connection_state: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionState + :param start_time: The start time of the connection snapshot. + :type start_time: ~datetime.datetime + :param end_time: The end time of the connection snapshot. + :type end_time: ~datetime.datetime + :param evaluation_state: Connectivity analysis evaluation state. Possible values include: + "NotStarted", "InProgress", "Completed". + :type evaluation_state: str or ~azure.mgmt.network.v2020_08_01.models.EvaluationState + :param avg_latency_in_ms: Average latency in ms. + :type avg_latency_in_ms: long + :param min_latency_in_ms: Minimum latency in ms. + :type min_latency_in_ms: long + :param max_latency_in_ms: Maximum latency in ms. + :type max_latency_in_ms: long + :param probes_sent: The number of sent probes. + :type probes_sent: long + :param probes_failed: The number of failed probes. + :type probes_failed: long + :ivar hops: List of hops between the source and the destination. + :vartype hops: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityHop] + """ + + _validation = { + 'avg_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'min_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'max_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'probes_sent': {'maximum': 4294967295, 'minimum': 0}, + 'probes_failed': {'maximum': 4294967295, 'minimum': 0}, + 'hops': {'readonly': True}, + } + + _attribute_map = { + 'connection_state': {'key': 'connectionState', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'evaluation_state': {'key': 'evaluationState', 'type': 'str'}, + 'avg_latency_in_ms': {'key': 'avgLatencyInMs', 'type': 'long'}, + 'min_latency_in_ms': {'key': 'minLatencyInMs', 'type': 'long'}, + 'max_latency_in_ms': {'key': 'maxLatencyInMs', 'type': 'long'}, + 'probes_sent': {'key': 'probesSent', 'type': 'long'}, + 'probes_failed': {'key': 'probesFailed', 'type': 'long'}, + 'hops': {'key': 'hops', 'type': '[ConnectivityHop]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionStateSnapshot, self).__init__(**kwargs) + self.connection_state = kwargs.get('connection_state', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.evaluation_state = kwargs.get('evaluation_state', None) + self.avg_latency_in_ms = kwargs.get('avg_latency_in_ms', None) + self.min_latency_in_ms = kwargs.get('min_latency_in_ms', None) + self.max_latency_in_ms = kwargs.get('max_latency_in_ms', None) + self.probes_sent = kwargs.get('probes_sent', None) + self.probes_failed = kwargs.get('probes_failed', None) + self.hops = None + + +class ConnectivityDestination(msrest.serialization.Model): + """Parameters that define destination of connection. + + :param resource_id: The ID of the resource to which a connection attempt will be made. + :type resource_id: str + :param address: The IP address or URI the resource to which a connection attempt will be made. + :type address: str + :param port: Port on which check connectivity will be performed. + :type port: int + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityDestination, self).__init__(**kwargs) + self.resource_id = kwargs.get('resource_id', None) + self.address = kwargs.get('address', None) + self.port = kwargs.get('port', None) + + +class ConnectivityHop(msrest.serialization.Model): + """Information about a hop between the source and the destination. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the hop. + :vartype type: str + :ivar id: The ID of the hop. + :vartype id: str + :ivar address: The IP address of the hop. + :vartype address: str + :ivar resource_id: The ID of the resource corresponding to this hop. + :vartype resource_id: str + :ivar next_hop_ids: List of next hop identifiers. + :vartype next_hop_ids: list[str] + :ivar previous_hop_ids: List of previous hop identifiers. + :vartype previous_hop_ids: list[str] + :ivar links: List of hop links. + :vartype links: list[~azure.mgmt.network.v2020_08_01.models.HopLink] + :ivar previous_links: List of previous hop links. + :vartype previous_links: list[~azure.mgmt.network.v2020_08_01.models.HopLink] + :ivar issues: List of issues. + :vartype issues: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityIssue] + """ + + _validation = { + 'type': {'readonly': True}, + 'id': {'readonly': True}, + 'address': {'readonly': True}, + 'resource_id': {'readonly': True}, + 'next_hop_ids': {'readonly': True}, + 'previous_hop_ids': {'readonly': True}, + 'links': {'readonly': True}, + 'previous_links': {'readonly': True}, + 'issues': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'next_hop_ids': {'key': 'nextHopIds', 'type': '[str]'}, + 'previous_hop_ids': {'key': 'previousHopIds', 'type': '[str]'}, + 'links': {'key': 'links', 'type': '[HopLink]'}, + 'previous_links': {'key': 'previousLinks', 'type': '[HopLink]'}, + 'issues': {'key': 'issues', 'type': '[ConnectivityIssue]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityHop, self).__init__(**kwargs) + self.type = None + self.id = None + self.address = None + self.resource_id = None + self.next_hop_ids = None + self.previous_hop_ids = None + self.links = None + self.previous_links = None + self.issues = None + + +class ConnectivityInformation(msrest.serialization.Model): + """Information on the connectivity status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar hops: List of hops between the source and the destination. + :vartype hops: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityHop] + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connected", "Disconnected", "Degraded". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionStatus + :ivar avg_latency_in_ms: Average latency in milliseconds. + :vartype avg_latency_in_ms: int + :ivar min_latency_in_ms: Minimum latency in milliseconds. + :vartype min_latency_in_ms: int + :ivar max_latency_in_ms: Maximum latency in milliseconds. + :vartype max_latency_in_ms: int + :ivar probes_sent: Total number of probes sent. + :vartype probes_sent: int + :ivar probes_failed: Number of failed probes. + :vartype probes_failed: int + """ + + _validation = { + 'hops': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'avg_latency_in_ms': {'readonly': True}, + 'min_latency_in_ms': {'readonly': True}, + 'max_latency_in_ms': {'readonly': True}, + 'probes_sent': {'readonly': True}, + 'probes_failed': {'readonly': True}, + } + + _attribute_map = { + 'hops': {'key': 'hops', 'type': '[ConnectivityHop]'}, + 'connection_status': {'key': 'connectionStatus', 'type': 'str'}, + 'avg_latency_in_ms': {'key': 'avgLatencyInMs', 'type': 'int'}, + 'min_latency_in_ms': {'key': 'minLatencyInMs', 'type': 'int'}, + 'max_latency_in_ms': {'key': 'maxLatencyInMs', 'type': 'int'}, + 'probes_sent': {'key': 'probesSent', 'type': 'int'}, + 'probes_failed': {'key': 'probesFailed', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityInformation, self).__init__(**kwargs) + self.hops = None + self.connection_status = None + self.avg_latency_in_ms = None + self.min_latency_in_ms = None + self.max_latency_in_ms = None + self.probes_sent = None + self.probes_failed = None + + +class ConnectivityIssue(msrest.serialization.Model): + """Information about an issue encountered in the process of checking for connectivity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar origin: The origin of the issue. Possible values include: "Local", "Inbound", "Outbound". + :vartype origin: str or ~azure.mgmt.network.v2020_08_01.models.Origin + :ivar severity: The severity of the issue. Possible values include: "Error", "Warning". + :vartype severity: str or ~azure.mgmt.network.v2020_08_01.models.Severity + :ivar type: The type of issue. Possible values include: "Unknown", "AgentStopped", + "GuestFirewall", "DnsResolution", "SocketBind", "NetworkSecurityRule", "UserDefinedRoute", + "PortThrottled", "Platform". + :vartype type: str or ~azure.mgmt.network.v2020_08_01.models.IssueType + :ivar context: Provides additional context on the issue. + :vartype context: list[dict[str, str]] + """ + + _validation = { + 'origin': {'readonly': True}, + 'severity': {'readonly': True}, + 'type': {'readonly': True}, + 'context': {'readonly': True}, + } + + _attribute_map = { + 'origin': {'key': 'origin', 'type': 'str'}, + 'severity': {'key': 'severity', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'context': {'key': 'context', 'type': '[{str}]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityIssue, self).__init__(**kwargs) + self.origin = None + self.severity = None + self.type = None + self.context = None + + +class ConnectivityParameters(msrest.serialization.Model): + """Parameters that determine how the connectivity check will be performed. + + All required parameters must be populated in order to send to Azure. + + :param source: Required. The source of the connection. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectivitySource + :param destination: Required. The destination of connection. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectivityDestination + :param protocol: Network protocol. Possible values include: "Tcp", "Http", "Https", "Icmp". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.Protocol + :param protocol_configuration: Configuration of the protocol. + :type protocol_configuration: ~azure.mgmt.network.v2020_08_01.models.ProtocolConfiguration + :param preferred_ip_version: Preferred IP version of the connection. Possible values include: + "IPv4", "IPv6". + :type preferred_ip_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + """ + + _validation = { + 'source': {'required': True}, + 'destination': {'required': True}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectivitySource'}, + 'destination': {'key': 'destination', 'type': 'ConnectivityDestination'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'protocol_configuration': {'key': 'protocolConfiguration', 'type': 'ProtocolConfiguration'}, + 'preferred_ip_version': {'key': 'preferredIPVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityParameters, self).__init__(**kwargs) + self.source = kwargs['source'] + self.destination = kwargs['destination'] + self.protocol = kwargs.get('protocol', None) + self.protocol_configuration = kwargs.get('protocol_configuration', None) + self.preferred_ip_version = kwargs.get('preferred_ip_version', None) + + +class ConnectivitySource(msrest.serialization.Model): + """Parameters that define the source of the connection. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. The ID of the resource from which a connectivity check will be + initiated. + :type resource_id: str + :param port: The source port from which a connectivity check will be performed. + :type port: int + """ + + _validation = { + 'resource_id': {'required': True}, + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivitySource, self).__init__(**kwargs) + self.resource_id = kwargs['resource_id'] + self.port = kwargs.get('port', None) + + +class Container(SubResource): + """Reference to container resource in remote resource provider. + + :param id: Resource ID. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Container, self).__init__(**kwargs) + + +class ContainerNetworkInterface(SubResource): + """Container network interface child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar container_network_interface_configuration: Container network interface configuration from + which this container network interface is created. + :vartype container_network_interface_configuration: + ~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceConfiguration + :param container: Reference to the container to which this container network interface is + attached. + :type container: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar ip_configurations: Reference to the ip configuration on this container nic. + :vartype ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceIpConfiguration] + :ivar provisioning_state: The provisioning state of the container network interface resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'container_network_interface_configuration': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'container_network_interface_configuration': {'key': 'properties.containerNetworkInterfaceConfiguration', 'type': 'ContainerNetworkInterfaceConfiguration'}, + 'container': {'key': 'properties.container', 'type': 'SubResource'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[ContainerNetworkInterfaceIpConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerNetworkInterface, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.container_network_interface_configuration = None + self.container = kwargs.get('container', None) + self.ip_configurations = None + self.provisioning_state = None + + +class ContainerNetworkInterfaceConfiguration(SubResource): + """Container network interface configuration child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: A list of ip configurations of the container network interface + configuration. + :type ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationProfile] + :param container_network_interfaces: A list of container network interfaces created from this + container network interface configuration. + :type container_network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the container network interface + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[IPConfigurationProfile]'}, + 'container_network_interfaces': {'key': 'properties.containerNetworkInterfaces', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerNetworkInterfaceConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.ip_configurations = kwargs.get('ip_configurations', None) + self.container_network_interfaces = kwargs.get('container_network_interfaces', None) + self.provisioning_state = None + + +class ContainerNetworkInterfaceIpConfiguration(msrest.serialization.Model): + """The ip configuration for a container network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the container network interface IP + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerNetworkInterfaceIpConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.provisioning_state = None + + +class CustomDnsConfigPropertiesFormat(msrest.serialization.Model): + """Contains custom Dns resolution configuration from customer. + + :param fqdn: Fqdn that resolves to private endpoint ip address. + :type fqdn: str + :param ip_addresses: A list of private ip addresses of the private endpoint. + :type ip_addresses: list[str] + """ + + _attribute_map = { + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomDnsConfigPropertiesFormat, self).__init__(**kwargs) + self.fqdn = kwargs.get('fqdn', None) + self.ip_addresses = kwargs.get('ip_addresses', None) + + +class CustomIpPrefix(Resource): + """Custom IP prefix resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the custom IP prefix. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param cidr: The prefix range in CIDR notation. Should include the start address and the prefix + length. + :type cidr: str + :param commissioned_state: The commissioned state of the Custom IP Prefix. Possible values + include: "Provisioning", "Provisioned", "Commissioning", "Commissioned", "Decommissioning", + "Deprovisioning". + :type commissioned_state: str or ~azure.mgmt.network.v2020_08_01.models.CommissionedState + :ivar public_ip_prefixes: The list of all referenced PublicIpPrefixes. + :vartype public_ip_prefixes: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_guid: The resource GUID property of the custom IP prefix resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the custom IP prefix resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'public_ip_prefixes': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'cidr': {'key': 'properties.cidr', 'type': 'str'}, + 'commissioned_state': {'key': 'properties.commissionedState', 'type': 'str'}, + 'public_ip_prefixes': {'key': 'properties.publicIpPrefixes', 'type': '[SubResource]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomIpPrefix, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.etag = None + self.zones = kwargs.get('zones', None) + self.cidr = kwargs.get('cidr', None) + self.commissioned_state = kwargs.get('commissioned_state', None) + self.public_ip_prefixes = None + self.resource_guid = None + self.provisioning_state = None + + +class CustomIpPrefixListResult(msrest.serialization.Model): + """Response for ListCustomIpPrefixes API service call. + + :param value: A list of Custom IP prefixes that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CustomIpPrefix]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomIpPrefixListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class DdosCustomPolicy(Resource): + """A DDoS custom policy in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the DDoS custom policy resource. It uniquely + identifies the resource, even if the user changes its name or migrate the resource across + subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DDoS custom policy resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar public_ip_addresses: The list of public IPs associated with the DDoS custom policy + resource. This list is read-only. + :vartype public_ip_addresses: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param protocol_custom_settings: The protocol-specific DDoS policy customization parameters. + :type protocol_custom_settings: + list[~azure.mgmt.network.v2020_08_01.models.ProtocolCustomSettingsFormat] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'public_ip_addresses': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'public_ip_addresses': {'key': 'properties.publicIPAddresses', 'type': '[SubResource]'}, + 'protocol_custom_settings': {'key': 'properties.protocolCustomSettings', 'type': '[ProtocolCustomSettingsFormat]'}, + } + + def __init__( + self, + **kwargs + ): + super(DdosCustomPolicy, self).__init__(**kwargs) + self.etag = None + self.resource_guid = None + self.provisioning_state = None + self.public_ip_addresses = None + self.protocol_custom_settings = kwargs.get('protocol_custom_settings', None) + + +class DdosProtectionPlan(msrest.serialization.Model): + """A DDoS protection plan in a resource group. + + Variables are only populated by 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the DDoS protection plan resource. It + uniquely identifies the resource, even if the user changes its name or migrate the resource + across subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DDoS protection plan resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar virtual_networks: The list of virtual networks associated with the DDoS protection plan + resource. This list is read-only. + :vartype virtual_networks: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'virtual_networks': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(DdosProtectionPlan, 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.etag = None + self.resource_guid = None + self.provisioning_state = None + self.virtual_networks = None + + +class DdosProtectionPlanListResult(msrest.serialization.Model): + """A list of DDoS protection plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of DDoS protection plans. + :type value: list[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DdosProtectionPlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DdosProtectionPlanListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class DdosSettings(msrest.serialization.Model): + """Contains the DDoS protection settings of the public IP. + + :param ddos_custom_policy: The DDoS custom policy associated with the public IP. + :type ddos_custom_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protection_coverage: The DDoS protection policy customizability of the public IP. Only + standard coverage will have the ability to be customized. Possible values include: "Basic", + "Standard". + :type protection_coverage: str or + ~azure.mgmt.network.v2020_08_01.models.DdosSettingsProtectionCoverage + :param protected_ip: Enables DDoS protection on the public IP. + :type protected_ip: bool + """ + + _attribute_map = { + 'ddos_custom_policy': {'key': 'ddosCustomPolicy', 'type': 'SubResource'}, + 'protection_coverage': {'key': 'protectionCoverage', 'type': 'str'}, + 'protected_ip': {'key': 'protectedIP', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DdosSettings, self).__init__(**kwargs) + self.ddos_custom_policy = kwargs.get('ddos_custom_policy', None) + self.protection_coverage = kwargs.get('protection_coverage', None) + self.protected_ip = kwargs.get('protected_ip', None) + + +class Delegation(SubResource): + """Details the service to which the subnet is delegated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a subnet. This name can be used to + access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param service_name: The name of the service to whom the subnet should be delegated (e.g. + Microsoft.Sql/servers). + :type service_name: str + :ivar actions: The actions permitted to the service upon delegation. + :vartype actions: list[str] + :ivar provisioning_state: The provisioning state of the service delegation resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'actions': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'service_name': {'key': 'properties.serviceName', 'type': 'str'}, + 'actions': {'key': 'properties.actions', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Delegation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.service_name = kwargs.get('service_name', None) + self.actions = None + self.provisioning_state = None + + +class DeviceProperties(msrest.serialization.Model): + """List of properties of the device. + + :param device_vendor: Name of the device Vendor. + :type device_vendor: str + :param device_model: Model of the device. + :type device_model: str + :param link_speed_in_mbps: Link speed. + :type link_speed_in_mbps: int + """ + + _attribute_map = { + 'device_vendor': {'key': 'deviceVendor', 'type': 'str'}, + 'device_model': {'key': 'deviceModel', 'type': 'str'}, + 'link_speed_in_mbps': {'key': 'linkSpeedInMbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(DeviceProperties, self).__init__(**kwargs) + self.device_vendor = kwargs.get('device_vendor', None) + self.device_model = kwargs.get('device_model', None) + self.link_speed_in_mbps = kwargs.get('link_speed_in_mbps', None) + + +class DhcpOptions(msrest.serialization.Model): + """DhcpOptions contains an array of DNS servers available to VMs deployed in the virtual network. Standard DHCP option for a subnet overrides VNET DHCP options. + + :param dns_servers: The list of DNS servers IP addresses. + :type dns_servers: list[str] + """ + + _attribute_map = { + 'dns_servers': {'key': 'dnsServers', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(DhcpOptions, self).__init__(**kwargs) + self.dns_servers = kwargs.get('dns_servers', None) + + +class Dimension(msrest.serialization.Model): + """Dimension of the metric. + + :param name: The name of the dimension. + :type name: str + :param display_name: The display name of the dimension. + :type display_name: str + :param internal_name: The internal name of the dimension. + :type internal_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + } + + 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) + + +class DnsNameAvailabilityResult(msrest.serialization.Model): + """Response for the CheckDnsNameAvailability API service call. + + :param available: Domain availability (True/False). + :type available: bool + """ + + _attribute_map = { + 'available': {'key': 'available', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DnsNameAvailabilityResult, self).__init__(**kwargs) + self.available = kwargs.get('available', None) + + +class DnsSettings(msrest.serialization.Model): + """DNS Proxy Settings in Firewall Policy. + + :param servers: List of Custom DNS Servers. + :type servers: list[str] + :param enable_proxy: Enable DNS Proxy on Firewalls attached to the Firewall Policy. + :type enable_proxy: bool + :param require_proxy_for_network_rules: FQDNs in Network Rules are supported when set to true. + :type require_proxy_for_network_rules: bool + """ + + _attribute_map = { + 'servers': {'key': 'servers', 'type': '[str]'}, + 'enable_proxy': {'key': 'enableProxy', 'type': 'bool'}, + 'require_proxy_for_network_rules': {'key': 'requireProxyForNetworkRules', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DnsSettings, self).__init__(**kwargs) + self.servers = kwargs.get('servers', None) + self.enable_proxy = kwargs.get('enable_proxy', None) + self.require_proxy_for_network_rules = kwargs.get('require_proxy_for_network_rules', None) + + +class DscpConfiguration(Resource): + """DSCP Configuration in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param markings: List of markings to be used in the configuration. + :type markings: list[int] + :param source_ip_ranges: Source IP ranges. + :type source_ip_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosIpRange] + :param destination_ip_ranges: Destination IP ranges. + :type destination_ip_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosIpRange] + :param source_port_ranges: Sources port ranges. + :type source_port_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosPortRange] + :param destination_port_ranges: Destination port ranges. + :type destination_port_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosPortRange] + :param protocol: RNM supported protocol types. Possible values include: "DoNotUse", "Icmp", + "Tcp", "Udp", "Gre", "Esp", "Ah", "Vxlan", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ProtocolType + :ivar qos_collection_id: Qos Collection ID generated by RNM. + :vartype qos_collection_id: str + :ivar associated_network_interfaces: Associated Network Interfaces to the DSCP Configuration. + :vartype associated_network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar resource_guid: The resource GUID property of the DSCP Configuration resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DSCP Configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'qos_collection_id': {'readonly': True}, + 'associated_network_interfaces': {'readonly': True}, + 'resource_guid': {'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'}, + 'markings': {'key': 'properties.markings', 'type': '[int]'}, + 'source_ip_ranges': {'key': 'properties.sourceIpRanges', 'type': '[QosIpRange]'}, + 'destination_ip_ranges': {'key': 'properties.destinationIpRanges', 'type': '[QosIpRange]'}, + 'source_port_ranges': {'key': 'properties.sourcePortRanges', 'type': '[QosPortRange]'}, + 'destination_port_ranges': {'key': 'properties.destinationPortRanges', 'type': '[QosPortRange]'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'qos_collection_id': {'key': 'properties.qosCollectionId', 'type': 'str'}, + 'associated_network_interfaces': {'key': 'properties.associatedNetworkInterfaces', 'type': '[NetworkInterface]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DscpConfiguration, self).__init__(**kwargs) + self.etag = None + self.markings = kwargs.get('markings', None) + self.source_ip_ranges = kwargs.get('source_ip_ranges', None) + self.destination_ip_ranges = kwargs.get('destination_ip_ranges', None) + self.source_port_ranges = kwargs.get('source_port_ranges', None) + self.destination_port_ranges = kwargs.get('destination_port_ranges', None) + self.protocol = kwargs.get('protocol', None) + self.qos_collection_id = None + self.associated_network_interfaces = None + self.resource_guid = None + self.provisioning_state = None + + +class DscpConfigurationListResult(msrest.serialization.Model): + """Response for the DscpConfigurationList API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of dscp configurations in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.DscpConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DscpConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DscpConfigurationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class EffectiveNetworkSecurityGroup(msrest.serialization.Model): + """Effective network security group. + + :param network_security_group: The ID of network security group that is applied. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param association: Associated resources. + :type association: + ~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroupAssociation + :param effective_security_rules: A collection of effective security rules. + :type effective_security_rules: + list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityRule] + :param tag_map: Mapping of tags to list of IP Addresses included within the tag. + :type tag_map: str + """ + + _attribute_map = { + 'network_security_group': {'key': 'networkSecurityGroup', 'type': 'SubResource'}, + 'association': {'key': 'association', 'type': 'EffectiveNetworkSecurityGroupAssociation'}, + 'effective_security_rules': {'key': 'effectiveSecurityRules', 'type': '[EffectiveNetworkSecurityRule]'}, + 'tag_map': {'key': 'tagMap', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveNetworkSecurityGroup, self).__init__(**kwargs) + self.network_security_group = kwargs.get('network_security_group', None) + self.association = kwargs.get('association', None) + self.effective_security_rules = kwargs.get('effective_security_rules', None) + self.tag_map = kwargs.get('tag_map', None) + + +class EffectiveNetworkSecurityGroupAssociation(msrest.serialization.Model): + """The effective network security group association. + + :param subnet: The ID of the subnet if assigned. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param network_interface: The ID of the network interface if assigned. + :type network_interface: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'subnet': {'key': 'subnet', 'type': 'SubResource'}, + 'network_interface': {'key': 'networkInterface', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveNetworkSecurityGroupAssociation, self).__init__(**kwargs) + self.subnet = kwargs.get('subnet', None) + self.network_interface = kwargs.get('network_interface', None) + + +class EffectiveNetworkSecurityGroupListResult(msrest.serialization.Model): + """Response for list effective network security groups API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of effective network security groups. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EffectiveNetworkSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveNetworkSecurityGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class EffectiveNetworkSecurityRule(msrest.serialization.Model): + """Effective network security rules. + + :param name: The name of the security rule specified by the user (if created by the user). + :type name: str + :param protocol: The network protocol this rule applies to. Possible values include: "Tcp", + "Udp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveSecurityRuleProtocol + :param source_port_range: The source port or range. + :type source_port_range: str + :param destination_port_range: The destination port or range. + :type destination_port_range: str + :param source_port_ranges: The source port ranges. Expected values include a single integer + between 0 and 65535, a range using '-' as separator (e.g. 100-400), or an asterisk (*). + :type source_port_ranges: list[str] + :param destination_port_ranges: The destination port ranges. Expected values include a single + integer between 0 and 65535, a range using '-' as separator (e.g. 100-400), or an asterisk (*). + :type destination_port_ranges: list[str] + :param source_address_prefix: The source address prefix. + :type source_address_prefix: str + :param destination_address_prefix: The destination address prefix. + :type destination_address_prefix: str + :param source_address_prefixes: The source address prefixes. Expected values include CIDR IP + ranges, Default Tags (VirtualNetwork, AzureLoadBalancer, Internet), System Tags, and the + asterisk (*). + :type source_address_prefixes: list[str] + :param destination_address_prefixes: The destination address prefixes. Expected values include + CIDR IP ranges, Default Tags (VirtualNetwork, AzureLoadBalancer, Internet), System Tags, and + the asterisk (*). + :type destination_address_prefixes: list[str] + :param expanded_source_address_prefix: The expanded source address prefix. + :type expanded_source_address_prefix: list[str] + :param expanded_destination_address_prefix: Expanded destination address prefix. + :type expanded_destination_address_prefix: list[str] + :param access: Whether network traffic is allowed or denied. Possible values include: "Allow", + "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :param priority: The priority of the rule. + :type priority: int + :param direction: The direction of the rule. Possible values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleDirection + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_port_range': {'key': 'sourcePortRange', 'type': 'str'}, + 'destination_port_range': {'key': 'destinationPortRange', 'type': 'str'}, + 'source_port_ranges': {'key': 'sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'destinationPortRanges', 'type': '[str]'}, + 'source_address_prefix': {'key': 'sourceAddressPrefix', 'type': 'str'}, + 'destination_address_prefix': {'key': 'destinationAddressPrefix', 'type': 'str'}, + 'source_address_prefixes': {'key': 'sourceAddressPrefixes', 'type': '[str]'}, + 'destination_address_prefixes': {'key': 'destinationAddressPrefixes', 'type': '[str]'}, + 'expanded_source_address_prefix': {'key': 'expandedSourceAddressPrefix', 'type': '[str]'}, + 'expanded_destination_address_prefix': {'key': 'expandedDestinationAddressPrefix', 'type': '[str]'}, + 'access': {'key': 'access', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'direction': {'key': 'direction', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveNetworkSecurityRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.protocol = kwargs.get('protocol', None) + self.source_port_range = kwargs.get('source_port_range', None) + self.destination_port_range = kwargs.get('destination_port_range', None) + self.source_port_ranges = kwargs.get('source_port_ranges', None) + self.destination_port_ranges = kwargs.get('destination_port_ranges', None) + self.source_address_prefix = kwargs.get('source_address_prefix', None) + self.destination_address_prefix = kwargs.get('destination_address_prefix', None) + self.source_address_prefixes = kwargs.get('source_address_prefixes', None) + self.destination_address_prefixes = kwargs.get('destination_address_prefixes', None) + self.expanded_source_address_prefix = kwargs.get('expanded_source_address_prefix', None) + self.expanded_destination_address_prefix = kwargs.get('expanded_destination_address_prefix', None) + self.access = kwargs.get('access', None) + self.priority = kwargs.get('priority', None) + self.direction = kwargs.get('direction', None) + + +class EffectiveRoute(msrest.serialization.Model): + """Effective Route. + + :param name: The name of the user defined route. This is optional. + :type name: str + :param disable_bgp_route_propagation: If true, on-premises routes are not propagated to the + network interfaces in the subnet. + :type disable_bgp_route_propagation: bool + :param source: Who created the route. Possible values include: "Unknown", "User", + "VirtualNetworkGateway", "Default". + :type source: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveRouteSource + :param state: The value of effective route. Possible values include: "Active", "Invalid". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveRouteState + :param address_prefix: The address prefixes of the effective routes in CIDR notation. + :type address_prefix: list[str] + :param next_hop_ip_address: The IP address of the next hop of the effective route. + :type next_hop_ip_address: list[str] + :param next_hop_type: The type of Azure hop the packet should be sent to. Possible values + include: "VirtualNetworkGateway", "VnetLocal", "Internet", "VirtualAppliance", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteNextHopType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'disable_bgp_route_propagation': {'key': 'disableBgpRoutePropagation', 'type': 'bool'}, + 'source': {'key': 'source', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'address_prefix': {'key': 'addressPrefix', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveRoute, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.disable_bgp_route_propagation = kwargs.get('disable_bgp_route_propagation', None) + self.source = kwargs.get('source', None) + self.state = kwargs.get('state', None) + self.address_prefix = kwargs.get('address_prefix', None) + self.next_hop_ip_address = kwargs.get('next_hop_ip_address', None) + self.next_hop_type = kwargs.get('next_hop_type', None) + + +class EffectiveRouteListResult(msrest.serialization.Model): + """Response for list effective route API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of effective routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EffectiveRoute] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EffectiveRoute]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveRouteListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class EffectiveRoutesParameters(msrest.serialization.Model): + """The parameters specifying the resource whose effective routes are being requested. + + :param resource_id: The resource whose effective routes are being requested. + :type resource_id: str + :param virtual_wan_resource_type: The type of the specified resource like RouteTable, + ExpressRouteConnection, HubVirtualNetworkConnection, VpnConnection and P2SConnection. + :type virtual_wan_resource_type: str + """ + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'virtual_wan_resource_type': {'key': 'virtualWanResourceType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EffectiveRoutesParameters, self).__init__(**kwargs) + self.resource_id = kwargs.get('resource_id', None) + self.virtual_wan_resource_type = kwargs.get('virtual_wan_resource_type', None) + + +class EndpointServiceResult(SubResource): + """Endpoint service. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: Name of the endpoint service. + :vartype name: str + :ivar type: Type of the endpoint service. + :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(EndpointServiceResult, self).__init__(**kwargs) + self.name = None + self.type = None + + +class EndpointServicesListResult(msrest.serialization.Model): + """Response for the ListAvailableEndpointServices API service call. + + :param value: List of available endpoint services in a region. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EndpointServiceResult] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EndpointServiceResult]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointServicesListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class Error(msrest.serialization.Model): + """Common error representation. + + :param code: Error code. + :type code: str + :param message: Error message. + :type message: str + :param target: Error target. + :type target: str + :param details: Error details. + :type details: list[~azure.mgmt.network.v2020_08_01.models.ErrorDetails] + :param inner_error: Inner error message. + :type inner_error: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorDetails]'}, + 'inner_error': {'key': 'innerError', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Error, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + self.target = kwargs.get('target', None) + self.details = kwargs.get('details', None) + self.inner_error = kwargs.get('inner_error', None) + + +class ErrorDetails(msrest.serialization.Model): + """Common error details representation. + + :param code: Error code. + :type code: str + :param target: Error target. + :type target: str + :param message: Error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorDetails, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.target = kwargs.get('target', None) + self.message = kwargs.get('message', None) + + +class ErrorResponse(msrest.serialization.Model): + """The error object. + + :param error: The error details object. + :type error: ~azure.mgmt.network.v2020_08_01.models.ErrorDetails + """ + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorDetails'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.error = kwargs.get('error', None) + + +class EvaluatedNetworkSecurityGroup(msrest.serialization.Model): + """Results of network security group evaluation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param network_security_group_id: Network security group ID. + :type network_security_group_id: str + :param applied_to: Resource ID of nic or subnet to which network security group is applied. + :type applied_to: str + :param matched_rule: Matched network security rule. + :type matched_rule: ~azure.mgmt.network.v2020_08_01.models.MatchedRule + :ivar rules_evaluation_result: List of network security rules evaluation results. + :vartype rules_evaluation_result: + list[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityRulesEvaluationResult] + """ + + _validation = { + 'rules_evaluation_result': {'readonly': True}, + } + + _attribute_map = { + 'network_security_group_id': {'key': 'networkSecurityGroupId', 'type': 'str'}, + 'applied_to': {'key': 'appliedTo', 'type': 'str'}, + 'matched_rule': {'key': 'matchedRule', 'type': 'MatchedRule'}, + 'rules_evaluation_result': {'key': 'rulesEvaluationResult', 'type': '[NetworkSecurityRulesEvaluationResult]'}, + } + + def __init__( + self, + **kwargs + ): + super(EvaluatedNetworkSecurityGroup, self).__init__(**kwargs) + self.network_security_group_id = kwargs.get('network_security_group_id', None) + self.applied_to = kwargs.get('applied_to', None) + self.matched_rule = kwargs.get('matched_rule', None) + self.rules_evaluation_result = None + + +class ExpressRouteCircuit(Resource): + """ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 sku: The SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param allow_classic_operations: Allow classic operations. + :type allow_classic_operations: bool + :param circuit_provisioning_state: The CircuitProvisioningState state of the resource. + :type circuit_provisioning_state: str + :param service_provider_provisioning_state: The ServiceProviderProvisioningState state of the + resource. Possible values include: "NotProvisioned", "Provisioning", "Provisioned", + "Deprovisioning". + :type service_provider_provisioning_state: str or + ~azure.mgmt.network.v2020_08_01.models.ServiceProviderProvisioningState + :param authorizations: The list of authorizations. + :type authorizations: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :param peerings: The list of peerings. + :type peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :param service_key: The ServiceKey. + :type service_key: str + :param service_provider_notes: The ServiceProviderNotes. + :type service_provider_notes: str + :param service_provider_properties: The ServiceProviderProperties. + :type service_provider_properties: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitServiceProviderProperties + :param express_route_port: The reference to the ExpressRoutePort resource when the circuit is + provisioned on an ExpressRoutePort resource. + :type express_route_port: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param bandwidth_in_gbps: The bandwidth of the circuit when the circuit is provisioned on an + ExpressRoutePort resource. + :type bandwidth_in_gbps: float + :ivar stag: The identifier of the circuit traffic. Outer tag for QinQ encapsulation. + :vartype stag: int + :ivar provisioning_state: The provisioning state of the express route circuit resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :param global_reach_enabled: Flag denoting global reach status. + :type global_reach_enabled: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'stag': {'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}'}, + 'sku': {'key': 'sku', 'type': 'ExpressRouteCircuitSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'allow_classic_operations': {'key': 'properties.allowClassicOperations', 'type': 'bool'}, + 'circuit_provisioning_state': {'key': 'properties.circuitProvisioningState', 'type': 'str'}, + 'service_provider_provisioning_state': {'key': 'properties.serviceProviderProvisioningState', 'type': 'str'}, + 'authorizations': {'key': 'properties.authorizations', 'type': '[ExpressRouteCircuitAuthorization]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'service_key': {'key': 'properties.serviceKey', 'type': 'str'}, + 'service_provider_notes': {'key': 'properties.serviceProviderNotes', 'type': 'str'}, + 'service_provider_properties': {'key': 'properties.serviceProviderProperties', 'type': 'ExpressRouteCircuitServiceProviderProperties'}, + 'express_route_port': {'key': 'properties.expressRoutePort', 'type': 'SubResource'}, + 'bandwidth_in_gbps': {'key': 'properties.bandwidthInGbps', 'type': 'float'}, + 'stag': {'key': 'properties.stag', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'global_reach_enabled': {'key': 'properties.globalReachEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuit, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.etag = None + self.allow_classic_operations = kwargs.get('allow_classic_operations', None) + self.circuit_provisioning_state = kwargs.get('circuit_provisioning_state', None) + self.service_provider_provisioning_state = kwargs.get('service_provider_provisioning_state', None) + self.authorizations = kwargs.get('authorizations', None) + self.peerings = kwargs.get('peerings', None) + self.service_key = kwargs.get('service_key', None) + self.service_provider_notes = kwargs.get('service_provider_notes', None) + self.service_provider_properties = kwargs.get('service_provider_properties', None) + self.express_route_port = kwargs.get('express_route_port', None) + self.bandwidth_in_gbps = kwargs.get('bandwidth_in_gbps', None) + self.stag = None + self.provisioning_state = None + self.gateway_manager_etag = kwargs.get('gateway_manager_etag', None) + self.global_reach_enabled = kwargs.get('global_reach_enabled', None) + + +class ExpressRouteCircuitArpTable(msrest.serialization.Model): + """The ARP table associated with the ExpressRouteCircuit. + + :param age: Entry age in minutes. + :type age: int + :param interface: Interface address. + :type interface: str + :param ip_address: The IP address. + :type ip_address: str + :param mac_address: The MAC address. + :type mac_address: str + """ + + _attribute_map = { + 'age': {'key': 'age', 'type': 'int'}, + 'interface': {'key': 'interface', 'type': 'str'}, + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'mac_address': {'key': 'macAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitArpTable, self).__init__(**kwargs) + self.age = kwargs.get('age', None) + self.interface = kwargs.get('interface', None) + self.ip_address = kwargs.get('ip_address', None) + self.mac_address = kwargs.get('mac_address', None) + + +class ExpressRouteCircuitAuthorization(SubResource): + """Authorization in an ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param authorization_key: The authorization key. + :type authorization_key: str + :param authorization_use_status: The authorization use status. Possible values include: + "Available", "InUse". + :type authorization_use_status: str or + ~azure.mgmt.network.v2020_08_01.models.AuthorizationUseStatus + :ivar provisioning_state: The provisioning state of the authorization resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'authorization_use_status': {'key': 'properties.authorizationUseStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitAuthorization, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.authorization_key = kwargs.get('authorization_key', None) + self.authorization_use_status = kwargs.get('authorization_use_status', None) + self.provisioning_state = None + + +class ExpressRouteCircuitConnection(SubResource): + """Express Route Circuit Connection in an ExpressRouteCircuitPeering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the circuit initiating connection. + :type express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param peer_express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the peered circuit. + :type peer_express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: /29 IP address space to carve out Customer addresses for tunnels. + :type address_prefix: str + :param authorization_key: The authorization key. + :type authorization_key: str + :param ipv6_circuit_connection_config: IPv6 Address PrefixProperties of the express route + circuit connection. + :type ipv6_circuit_connection_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6CircuitConnectionConfig + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + :ivar provisioning_state: The provisioning state of the express route circuit connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'circuit_connection_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'SubResource'}, + 'peer_express_route_circuit_peering': {'key': 'properties.peerExpressRouteCircuitPeering', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'ipv6_circuit_connection_config': {'key': 'properties.ipv6CircuitConnectionConfig', 'type': 'Ipv6CircuitConnectionConfig'}, + 'circuit_connection_status': {'key': 'properties.circuitConnectionStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.express_route_circuit_peering = kwargs.get('express_route_circuit_peering', None) + self.peer_express_route_circuit_peering = kwargs.get('peer_express_route_circuit_peering', None) + self.address_prefix = kwargs.get('address_prefix', None) + self.authorization_key = kwargs.get('authorization_key', None) + self.ipv6_circuit_connection_config = kwargs.get('ipv6_circuit_connection_config', None) + self.circuit_connection_status = None + self.provisioning_state = None + + +class ExpressRouteCircuitConnectionListResult(msrest.serialization.Model): + """Response for ListConnections API service call retrieves all global reach connections that belongs to a Private Peering for an ExpressRouteCircuit. + + :param value: The global reach connection associated with Private Peering in an ExpressRoute + Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitListResult(msrest.serialization.Model): + """Response for ListExpressRouteCircuit API service call. + + :param value: A list of ExpressRouteCircuits in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuit]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitPeering(SubResource): + """Peering in an ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param peering_type: The peering type. Possible values include: "AzurePublicPeering", + "AzurePrivatePeering", "MicrosoftPeering". + :type peering_type: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringType + :param state: The peering state. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringState + :param azure_asn: The Azure ASN. + :type azure_asn: int + :param peer_asn: The peer ASN. + :type peer_asn: long + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :param primary_azure_port: The primary port. + :type primary_azure_port: str + :param secondary_azure_port: The secondary port. + :type secondary_azure_port: str + :param shared_key: The shared key. + :type shared_key: str + :param vlan_id: The VLAN ID. + :type vlan_id: int + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :param stats: The peering stats of express route circuit. + :type stats: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :ivar provisioning_state: The provisioning state of the express route circuit peering resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :ivar last_modified_by: Who was the last to modify the peering. + :vartype last_modified_by: str + :param route_filter: The reference to the RouteFilter resource. + :type route_filter: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ipv6_peering_config: The IPv6 peering configuration. + :type ipv6_peering_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6ExpressRouteCircuitPeeringConfig + :param express_route_connection: The ExpressRoute connection. + :type express_route_connection: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnectionId + :param connections: The list of circuit connections associated with Azure Private Peering for + this circuit. + :type connections: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :ivar peered_connections: The list of peered circuit connections associated with Azure Private + Peering for this circuit. + :vartype peered_connections: + list[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'last_modified_by': {'readonly': True}, + 'peered_connections': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peering_type': {'key': 'properties.peeringType', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'azure_asn': {'key': 'properties.azureASN', 'type': 'int'}, + 'peer_asn': {'key': 'properties.peerASN', 'type': 'long'}, + 'primary_peer_address_prefix': {'key': 'properties.primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'properties.secondaryPeerAddressPrefix', 'type': 'str'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'vlan_id': {'key': 'properties.vlanId', 'type': 'int'}, + 'microsoft_peering_config': {'key': 'properties.microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'stats': {'key': 'properties.stats', 'type': 'ExpressRouteCircuitStats'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'last_modified_by': {'key': 'properties.lastModifiedBy', 'type': 'str'}, + 'route_filter': {'key': 'properties.routeFilter', 'type': 'SubResource'}, + 'ipv6_peering_config': {'key': 'properties.ipv6PeeringConfig', 'type': 'Ipv6ExpressRouteCircuitPeeringConfig'}, + 'express_route_connection': {'key': 'properties.expressRouteConnection', 'type': 'ExpressRouteConnectionId'}, + 'connections': {'key': 'properties.connections', 'type': '[ExpressRouteCircuitConnection]'}, + 'peered_connections': {'key': 'properties.peeredConnections', 'type': '[PeerExpressRouteCircuitConnection]'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitPeering, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.peering_type = kwargs.get('peering_type', None) + self.state = kwargs.get('state', None) + self.azure_asn = kwargs.get('azure_asn', None) + self.peer_asn = kwargs.get('peer_asn', None) + self.primary_peer_address_prefix = kwargs.get('primary_peer_address_prefix', None) + self.secondary_peer_address_prefix = kwargs.get('secondary_peer_address_prefix', None) + self.primary_azure_port = kwargs.get('primary_azure_port', None) + self.secondary_azure_port = kwargs.get('secondary_azure_port', None) + self.shared_key = kwargs.get('shared_key', None) + self.vlan_id = kwargs.get('vlan_id', None) + self.microsoft_peering_config = kwargs.get('microsoft_peering_config', None) + self.stats = kwargs.get('stats', None) + self.provisioning_state = None + self.gateway_manager_etag = kwargs.get('gateway_manager_etag', None) + self.last_modified_by = None + self.route_filter = kwargs.get('route_filter', None) + self.ipv6_peering_config = kwargs.get('ipv6_peering_config', None) + self.express_route_connection = kwargs.get('express_route_connection', None) + self.connections = kwargs.get('connections', None) + self.peered_connections = None + + +class ExpressRouteCircuitPeeringConfig(msrest.serialization.Model): + """Specifies the peering configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param advertised_public_prefixes: The reference to AdvertisedPublicPrefixes. + :type advertised_public_prefixes: list[str] + :param advertised_communities: The communities of bgp peering. Specified for microsoft peering. + :type advertised_communities: list[str] + :ivar advertised_public_prefixes_state: The advertised public prefix state of the Peering + resource. Possible values include: "NotConfigured", "Configuring", "Configured", + "ValidationNeeded". + :vartype advertised_public_prefixes_state: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringAdvertisedPublicPrefixState + :param legacy_mode: The legacy mode of the peering. + :type legacy_mode: int + :param customer_asn: The CustomerASN of the peering. + :type customer_asn: int + :param routing_registry_name: The RoutingRegistryName of the configuration. + :type routing_registry_name: str + """ + + _validation = { + 'advertised_public_prefixes_state': {'readonly': True}, + } + + _attribute_map = { + 'advertised_public_prefixes': {'key': 'advertisedPublicPrefixes', 'type': '[str]'}, + 'advertised_communities': {'key': 'advertisedCommunities', 'type': '[str]'}, + 'advertised_public_prefixes_state': {'key': 'advertisedPublicPrefixesState', 'type': 'str'}, + 'legacy_mode': {'key': 'legacyMode', 'type': 'int'}, + 'customer_asn': {'key': 'customerASN', 'type': 'int'}, + 'routing_registry_name': {'key': 'routingRegistryName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitPeeringConfig, self).__init__(**kwargs) + self.advertised_public_prefixes = kwargs.get('advertised_public_prefixes', None) + self.advertised_communities = kwargs.get('advertised_communities', None) + self.advertised_public_prefixes_state = None + self.legacy_mode = kwargs.get('legacy_mode', None) + self.customer_asn = kwargs.get('customer_asn', None) + self.routing_registry_name = kwargs.get('routing_registry_name', None) + + +class ExpressRouteCircuitPeeringId(msrest.serialization.Model): + """ExpressRoute circuit peering identifier. + + :param id: The ID of the ExpressRoute circuit peering. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitPeeringId, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class ExpressRouteCircuitPeeringListResult(msrest.serialization.Model): + """Response for ListPeering API service call retrieves all peerings that belong to an ExpressRouteCircuit. + + :param value: The peerings in an express route circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitPeeringListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitReference(msrest.serialization.Model): + """Reference to an express route circuit. + + :param id: Corresponding Express Route Circuit Id. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitReference, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class ExpressRouteCircuitRoutesTable(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param network: IP address of a network entity. + :type network: str + :param next_hop: NextHop address. + :type next_hop: str + :param loc_prf: Local preference value as set with the set local-preference route-map + configuration command. + :type loc_prf: str + :param weight: Route Weight. + :type weight: int + :param path: Autonomous system paths to the destination network. + :type path: str + """ + + _attribute_map = { + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'loc_prf': {'key': 'locPrf', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + 'path': {'key': 'path', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitRoutesTable, self).__init__(**kwargs) + self.network = kwargs.get('network', None) + self.next_hop = kwargs.get('next_hop', None) + self.loc_prf = kwargs.get('loc_prf', None) + self.weight = kwargs.get('weight', None) + self.path = kwargs.get('path', None) + + +class ExpressRouteCircuitRoutesTableSummary(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param neighbor: IP address of the neighbor. + :type neighbor: str + :param v: BGP version number spoken to the neighbor. + :type v: int + :param as_property: Autonomous system number. + :type as_property: int + :param up_down: The length of time that the BGP session has been in the Established state, or + the current status if not in the Established state. + :type up_down: str + :param state_pfx_rcd: Current state of the BGP session, and the number of prefixes that have + been received from a neighbor or peer group. + :type state_pfx_rcd: str + """ + + _attribute_map = { + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'v': {'key': 'v', 'type': 'int'}, + 'as_property': {'key': 'as', 'type': 'int'}, + 'up_down': {'key': 'upDown', 'type': 'str'}, + 'state_pfx_rcd': {'key': 'statePfxRcd', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitRoutesTableSummary, self).__init__(**kwargs) + self.neighbor = kwargs.get('neighbor', None) + self.v = kwargs.get('v', None) + self.as_property = kwargs.get('as_property', None) + self.up_down = kwargs.get('up_down', None) + self.state_pfx_rcd = kwargs.get('state_pfx_rcd', None) + + +class ExpressRouteCircuitsArpTableListResult(msrest.serialization.Model): + """Response for ListArpTable associated with the Express Route Circuits API. + + :param value: A list of the ARP tables. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitArpTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitArpTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitsArpTableListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitServiceProviderProperties(msrest.serialization.Model): + """Contains ServiceProviderProperties in an ExpressRouteCircuit. + + :param service_provider_name: The serviceProviderName. + :type service_provider_name: str + :param peering_location: The peering location. + :type peering_location: str + :param bandwidth_in_mbps: The BandwidthInMbps. + :type bandwidth_in_mbps: int + """ + + _attribute_map = { + 'service_provider_name': {'key': 'serviceProviderName', 'type': 'str'}, + 'peering_location': {'key': 'peeringLocation', 'type': 'str'}, + 'bandwidth_in_mbps': {'key': 'bandwidthInMbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitServiceProviderProperties, self).__init__(**kwargs) + self.service_provider_name = kwargs.get('service_provider_name', None) + self.peering_location = kwargs.get('peering_location', None) + self.bandwidth_in_mbps = kwargs.get('bandwidth_in_mbps', None) + + +class ExpressRouteCircuitSku(msrest.serialization.Model): + """Contains SKU in an ExpressRouteCircuit. + + :param name: The name of the SKU. + :type name: str + :param tier: The tier of the SKU. Possible values include: "Standard", "Premium", "Basic", + "Local". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSkuTier + :param family: The family of the SKU. Possible values include: "UnlimitedData", "MeteredData". + :type family: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSkuFamily + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitSku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.family = kwargs.get('family', None) + + +class ExpressRouteCircuitsRoutesTableListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Circuits API. + + :param value: The list of routes table. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitRoutesTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitRoutesTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitsRoutesTableListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitsRoutesTableSummaryListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Circuits API. + + :param value: A list of the routes table. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitRoutesTableSummary] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitRoutesTableSummary]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitsRoutesTableSummaryListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteCircuitStats(msrest.serialization.Model): + """Contains stats associated with the peering. + + :param primarybytes_in: The Primary BytesIn of the peering. + :type primarybytes_in: long + :param primarybytes_out: The primary BytesOut of the peering. + :type primarybytes_out: long + :param secondarybytes_in: The secondary BytesIn of the peering. + :type secondarybytes_in: long + :param secondarybytes_out: The secondary BytesOut of the peering. + :type secondarybytes_out: long + """ + + _attribute_map = { + 'primarybytes_in': {'key': 'primarybytesIn', 'type': 'long'}, + 'primarybytes_out': {'key': 'primarybytesOut', 'type': 'long'}, + 'secondarybytes_in': {'key': 'secondarybytesIn', 'type': 'long'}, + 'secondarybytes_out': {'key': 'secondarybytesOut', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCircuitStats, self).__init__(**kwargs) + self.primarybytes_in = kwargs.get('primarybytes_in', None) + self.primarybytes_out = kwargs.get('primarybytes_out', None) + self.secondarybytes_in = kwargs.get('secondarybytes_in', None) + self.secondarybytes_out = kwargs.get('secondarybytes_out', None) + + +class ExpressRouteConnection(SubResource): + """ExpressRouteConnection 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 id: Resource ID. + :type id: str + :param name: Required. The name of the resource. + :type name: str + :ivar provisioning_state: The provisioning state of the express route connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_circuit_peering: The ExpressRoute circuit peering. + :type express_route_circuit_peering: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringId + :param authorization_key: Authorization key to establish the connection. + :type authorization_key: str + :param routing_weight: The routing weight associated to the connection. + :type routing_weight: int + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param express_route_gateway_bypass: Enable FastPath to vWan Firewall hub. + :type express_route_gateway_bypass: bool + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + """ + + _validation = { + 'name': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'ExpressRouteCircuitPeeringId'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteConnection, self).__init__(**kwargs) + self.name = kwargs['name'] + self.provisioning_state = None + self.express_route_circuit_peering = kwargs.get('express_route_circuit_peering', None) + self.authorization_key = kwargs.get('authorization_key', None) + self.routing_weight = kwargs.get('routing_weight', None) + self.enable_internet_security = kwargs.get('enable_internet_security', None) + self.express_route_gateway_bypass = kwargs.get('express_route_gateway_bypass', None) + self.routing_configuration = kwargs.get('routing_configuration', None) + + +class ExpressRouteConnectionId(msrest.serialization.Model): + """The ID of the ExpressRouteConnection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the ExpressRouteConnection. + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteConnectionId, self).__init__(**kwargs) + self.id = None + + +class ExpressRouteConnectionList(msrest.serialization.Model): + """ExpressRouteConnection list. + + :param value: The list of ExpressRoute connections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteConnection]'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteConnectionList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class ExpressRouteCrossConnection(Resource): + """ExpressRouteCrossConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar primary_azure_port: The name of the primary port. + :vartype primary_azure_port: str + :ivar secondary_azure_port: The name of the secondary port. + :vartype secondary_azure_port: str + :ivar s_tag: The identifier of the circuit traffic. + :vartype s_tag: int + :ivar peering_location: The peering location of the ExpressRoute circuit. + :vartype peering_location: str + :ivar bandwidth_in_mbps: The circuit bandwidth In Mbps. + :vartype bandwidth_in_mbps: int + :param express_route_circuit: The ExpressRouteCircuit. + :type express_route_circuit: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitReference + :param service_provider_provisioning_state: The provisioning state of the circuit in the + connectivity provider system. Possible values include: "NotProvisioned", "Provisioning", + "Provisioned", "Deprovisioning". + :type service_provider_provisioning_state: str or + ~azure.mgmt.network.v2020_08_01.models.ServiceProviderProvisioningState + :param service_provider_notes: Additional read only notes set by the connectivity provider. + :type service_provider_notes: str + :ivar provisioning_state: The provisioning state of the express route cross connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param peerings: The list of peerings. + :type peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'primary_azure_port': {'readonly': True}, + 'secondary_azure_port': {'readonly': True}, + 's_tag': {'readonly': True}, + 'peering_location': {'readonly': True}, + 'bandwidth_in_mbps': {'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'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 's_tag': {'key': 'properties.sTag', 'type': 'int'}, + 'peering_location': {'key': 'properties.peeringLocation', 'type': 'str'}, + 'bandwidth_in_mbps': {'key': 'properties.bandwidthInMbps', 'type': 'int'}, + 'express_route_circuit': {'key': 'properties.expressRouteCircuit', 'type': 'ExpressRouteCircuitReference'}, + 'service_provider_provisioning_state': {'key': 'properties.serviceProviderProvisioningState', 'type': 'str'}, + 'service_provider_notes': {'key': 'properties.serviceProviderNotes', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCrossConnectionPeering]'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnection, self).__init__(**kwargs) + self.etag = None + self.primary_azure_port = None + self.secondary_azure_port = None + self.s_tag = None + self.peering_location = None + self.bandwidth_in_mbps = None + self.express_route_circuit = kwargs.get('express_route_circuit', None) + self.service_provider_provisioning_state = kwargs.get('service_provider_provisioning_state', None) + self.service_provider_notes = kwargs.get('service_provider_notes', None) + self.provisioning_state = None + self.peerings = kwargs.get('peerings', None) + + +class ExpressRouteCrossConnectionListResult(msrest.serialization.Model): + """Response for ListExpressRouteCrossConnection API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ExpressRouteCrossConnection resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ExpressRouteCrossConnectionPeering(SubResource): + """Peering in an ExpressRoute Cross Connection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param peering_type: The peering type. Possible values include: "AzurePublicPeering", + "AzurePrivatePeering", "MicrosoftPeering". + :type peering_type: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringType + :param state: The peering state. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringState + :ivar azure_asn: The Azure ASN. + :vartype azure_asn: int + :param peer_asn: The peer ASN. + :type peer_asn: long + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :ivar primary_azure_port: The primary port. + :vartype primary_azure_port: str + :ivar secondary_azure_port: The secondary port. + :vartype secondary_azure_port: str + :param shared_key: The shared key. + :type shared_key: str + :param vlan_id: The VLAN ID. + :type vlan_id: int + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :ivar provisioning_state: The provisioning state of the express route cross connection peering + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :ivar last_modified_by: Who was the last to modify the peering. + :vartype last_modified_by: str + :param ipv6_peering_config: The IPv6 peering configuration. + :type ipv6_peering_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6ExpressRouteCircuitPeeringConfig + """ + + _validation = { + 'etag': {'readonly': True}, + 'azure_asn': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 1}, + 'primary_azure_port': {'readonly': True}, + 'secondary_azure_port': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'last_modified_by': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'peering_type': {'key': 'properties.peeringType', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'azure_asn': {'key': 'properties.azureASN', 'type': 'int'}, + 'peer_asn': {'key': 'properties.peerASN', 'type': 'long'}, + 'primary_peer_address_prefix': {'key': 'properties.primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'properties.secondaryPeerAddressPrefix', 'type': 'str'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'vlan_id': {'key': 'properties.vlanId', 'type': 'int'}, + 'microsoft_peering_config': {'key': 'properties.microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'last_modified_by': {'key': 'properties.lastModifiedBy', 'type': 'str'}, + 'ipv6_peering_config': {'key': 'properties.ipv6PeeringConfig', 'type': 'Ipv6ExpressRouteCircuitPeeringConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnectionPeering, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.peering_type = kwargs.get('peering_type', None) + self.state = kwargs.get('state', None) + self.azure_asn = None + self.peer_asn = kwargs.get('peer_asn', None) + self.primary_peer_address_prefix = kwargs.get('primary_peer_address_prefix', None) + self.secondary_peer_address_prefix = kwargs.get('secondary_peer_address_prefix', None) + self.primary_azure_port = None + self.secondary_azure_port = None + self.shared_key = kwargs.get('shared_key', None) + self.vlan_id = kwargs.get('vlan_id', None) + self.microsoft_peering_config = kwargs.get('microsoft_peering_config', None) + self.provisioning_state = None + self.gateway_manager_etag = kwargs.get('gateway_manager_etag', None) + self.last_modified_by = None + self.ipv6_peering_config = kwargs.get('ipv6_peering_config', None) + + +class ExpressRouteCrossConnectionPeeringList(msrest.serialization.Model): + """Response for ListPeering API service call retrieves all peerings that belong to an ExpressRouteCrossConnection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The peerings in an express route cross connection. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnectionPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnectionPeeringList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ExpressRouteCrossConnectionRoutesTableSummary(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param neighbor: IP address of Neighbor router. + :type neighbor: str + :param asn: Autonomous system number. + :type asn: int + :param up_down: The length of time that the BGP session has been in the Established state, or + the current status if not in the Established state. + :type up_down: str + :param state_or_prefixes_received: Current state of the BGP session, and the number of prefixes + that have been received from a neighbor or peer group. + :type state_or_prefixes_received: str + """ + + _attribute_map = { + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'asn': {'key': 'asn', 'type': 'int'}, + 'up_down': {'key': 'upDown', 'type': 'str'}, + 'state_or_prefixes_received': {'key': 'stateOrPrefixesReceived', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnectionRoutesTableSummary, self).__init__(**kwargs) + self.neighbor = kwargs.get('neighbor', None) + self.asn = kwargs.get('asn', None) + self.up_down = kwargs.get('up_down', None) + self.state_or_prefixes_received = kwargs.get('state_or_prefixes_received', None) + + +class ExpressRouteCrossConnectionsRoutesTableSummaryListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Cross Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of the routes table. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionRoutesTableSummary] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnectionRoutesTableSummary]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteCrossConnectionsRoutesTableSummaryListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ExpressRouteGateway(Resource): + """ExpressRoute gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param auto_scale_configuration: Configuration for auto scaling. + :type auto_scale_configuration: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayPropertiesAutoScaleConfiguration + :ivar express_route_connections: List of ExpressRoute connections to the ExpressRoute gateway. + :vartype express_route_connections: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + :ivar provisioning_state: The provisioning state of the express route gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param virtual_hub: The Virtual Hub where the ExpressRoute gateway is or will be deployed. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.VirtualHubId + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'express_route_connections': {'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'}, + 'auto_scale_configuration': {'key': 'properties.autoScaleConfiguration', 'type': 'ExpressRouteGatewayPropertiesAutoScaleConfiguration'}, + 'express_route_connections': {'key': 'properties.expressRouteConnections', 'type': '[ExpressRouteConnection]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'VirtualHubId'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteGateway, self).__init__(**kwargs) + self.etag = None + self.auto_scale_configuration = kwargs.get('auto_scale_configuration', None) + self.express_route_connections = None + self.provisioning_state = None + self.virtual_hub = kwargs.get('virtual_hub', None) + + +class ExpressRouteGatewayList(msrest.serialization.Model): + """List of ExpressRoute gateways. + + :param value: List of ExpressRoute gateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteGateway]'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteGatewayList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class ExpressRouteGatewayPropertiesAutoScaleConfiguration(msrest.serialization.Model): + """Configuration for auto scaling. + + :param bounds: Minimum and maximum number of scale units to deploy. + :type bounds: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds + """ + + _attribute_map = { + 'bounds': {'key': 'bounds', 'type': 'ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteGatewayPropertiesAutoScaleConfiguration, self).__init__(**kwargs) + self.bounds = kwargs.get('bounds', None) + + +class ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds(msrest.serialization.Model): + """Minimum and maximum number of scale units to deploy. + + :param min: Minimum number of scale units deployed for ExpressRoute gateway. + :type min: int + :param max: Maximum number of scale units deployed for ExpressRoute gateway. + :type max: int + """ + + _attribute_map = { + 'min': {'key': 'min', 'type': 'int'}, + 'max': {'key': 'max', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds, self).__init__(**kwargs) + self.min = kwargs.get('min', None) + self.max = kwargs.get('max', None) + + +class ExpressRouteLink(SubResource): + """ExpressRouteLink child resource definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of child port resource that is unique among child port resources of the + parent. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar router_name: Name of Azure router associated with physical port. + :vartype router_name: str + :ivar interface_name: Name of Azure router interface. + :vartype interface_name: str + :ivar patch_panel_id: Mapping between physical port to patch panel port. + :vartype patch_panel_id: str + :ivar rack_id: Mapping of physical patch panel to rack. + :vartype rack_id: str + :ivar connector_type: Physical fiber port type. Possible values include: "LC", "SC". + :vartype connector_type: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkConnectorType + :param admin_state: Administrative state of the physical port. Possible values include: + "Enabled", "Disabled". + :type admin_state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkAdminState + :ivar provisioning_state: The provisioning state of the express route link resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param mac_sec_config: MacSec configuration. + :type mac_sec_config: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecConfig + """ + + _validation = { + 'etag': {'readonly': True}, + 'router_name': {'readonly': True}, + 'interface_name': {'readonly': True}, + 'patch_panel_id': {'readonly': True}, + 'rack_id': {'readonly': True}, + 'connector_type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'router_name': {'key': 'properties.routerName', 'type': 'str'}, + 'interface_name': {'key': 'properties.interfaceName', 'type': 'str'}, + 'patch_panel_id': {'key': 'properties.patchPanelId', 'type': 'str'}, + 'rack_id': {'key': 'properties.rackId', 'type': 'str'}, + 'connector_type': {'key': 'properties.connectorType', 'type': 'str'}, + 'admin_state': {'key': 'properties.adminState', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'mac_sec_config': {'key': 'properties.macSecConfig', 'type': 'ExpressRouteLinkMacSecConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteLink, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.router_name = None + self.interface_name = None + self.patch_panel_id = None + self.rack_id = None + self.connector_type = None + self.admin_state = kwargs.get('admin_state', None) + self.provisioning_state = None + self.mac_sec_config = kwargs.get('mac_sec_config', None) + + +class ExpressRouteLinkListResult(msrest.serialization.Model): + """Response for ListExpressRouteLinks API service call. + + :param value: The list of ExpressRouteLink sub-resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteLinkListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteLinkMacSecConfig(msrest.serialization.Model): + """ExpressRouteLink Mac Security Configuration. + + :param ckn_secret_identifier: Keyvault Secret Identifier URL containing Mac security CKN key. + :type ckn_secret_identifier: str + :param cak_secret_identifier: Keyvault Secret Identifier URL containing Mac security CAK key. + :type cak_secret_identifier: str + :param cipher: Mac security cipher. Possible values include: "GcmAes256", "GcmAes128", + "GcmAesXpn128", "GcmAesXpn256". + :type cipher: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecCipher + :param sci_state: Sci mode enabled/disabled. Possible values include: "Disabled", "Enabled". + :type sci_state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecSciState + """ + + _attribute_map = { + 'ckn_secret_identifier': {'key': 'cknSecretIdentifier', 'type': 'str'}, + 'cak_secret_identifier': {'key': 'cakSecretIdentifier', 'type': 'str'}, + 'cipher': {'key': 'cipher', 'type': 'str'}, + 'sci_state': {'key': 'sciState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteLinkMacSecConfig, self).__init__(**kwargs) + self.ckn_secret_identifier = kwargs.get('ckn_secret_identifier', None) + self.cak_secret_identifier = kwargs.get('cak_secret_identifier', None) + self.cipher = kwargs.get('cipher', None) + self.sci_state = kwargs.get('sci_state', None) + + +class ExpressRoutePort(Resource): + """ExpressRoutePort resource definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param identity: The identity of ExpressRoutePort, if configured. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :param peering_location: The name of the peering location that the ExpressRoutePort is mapped + to physically. + :type peering_location: str + :param bandwidth_in_gbps: Bandwidth of procured ports in Gbps. + :type bandwidth_in_gbps: int + :ivar provisioned_bandwidth_in_gbps: Aggregate Gbps of associated circuit bandwidths. + :vartype provisioned_bandwidth_in_gbps: float + :ivar mtu: Maximum transmission unit of the physical port pair(s). + :vartype mtu: str + :param encapsulation: Encapsulation method on physical ports. Possible values include: "Dot1Q", + "QinQ". + :type encapsulation: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsEncapsulation + :ivar ether_type: Ether type of the physical port. + :vartype ether_type: str + :ivar allocation_date: Date of the physical port allocation to be used in Letter of + Authorization. + :vartype allocation_date: str + :param links: The set of physical links of the ExpressRoutePort resource. + :type links: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink] + :ivar circuits: Reference the ExpressRoute circuit(s) that are provisioned on this + ExpressRoutePort resource. + :vartype circuits: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the express route port resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_guid: The resource GUID property of the express route port resource. + :vartype resource_guid: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioned_bandwidth_in_gbps': {'readonly': True}, + 'mtu': {'readonly': True}, + 'ether_type': {'readonly': True}, + 'allocation_date': {'readonly': True}, + 'circuits': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_guid': {'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'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'peering_location': {'key': 'properties.peeringLocation', 'type': 'str'}, + 'bandwidth_in_gbps': {'key': 'properties.bandwidthInGbps', 'type': 'int'}, + 'provisioned_bandwidth_in_gbps': {'key': 'properties.provisionedBandwidthInGbps', 'type': 'float'}, + 'mtu': {'key': 'properties.mtu', 'type': 'str'}, + 'encapsulation': {'key': 'properties.encapsulation', 'type': 'str'}, + 'ether_type': {'key': 'properties.etherType', 'type': 'str'}, + 'allocation_date': {'key': 'properties.allocationDate', 'type': 'str'}, + 'links': {'key': 'properties.links', 'type': '[ExpressRouteLink]'}, + 'circuits': {'key': 'properties.circuits', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePort, self).__init__(**kwargs) + self.etag = None + self.identity = kwargs.get('identity', None) + self.peering_location = kwargs.get('peering_location', None) + self.bandwidth_in_gbps = kwargs.get('bandwidth_in_gbps', None) + self.provisioned_bandwidth_in_gbps = None + self.mtu = None + self.encapsulation = kwargs.get('encapsulation', None) + self.ether_type = None + self.allocation_date = None + self.links = kwargs.get('links', None) + self.circuits = None + self.provisioning_state = None + self.resource_guid = None + + +class ExpressRoutePortListResult(msrest.serialization.Model): + """Response for ListExpressRoutePorts API service call. + + :param value: A list of ExpressRoutePort resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRoutePort]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePortListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRoutePortsLocation(Resource): + """Definition of the ExpressRoutePorts peering location resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar address: Address of peering location. + :vartype address: str + :ivar contact: Contact details of peering locations. + :vartype contact: str + :param available_bandwidths: The inventory of available ExpressRoutePort bandwidths. + :type available_bandwidths: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocationBandwidths] + :ivar provisioning_state: The provisioning state of the express route port location resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'address': {'readonly': True}, + 'contact': {'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}'}, + 'address': {'key': 'properties.address', 'type': 'str'}, + 'contact': {'key': 'properties.contact', 'type': 'str'}, + 'available_bandwidths': {'key': 'properties.availableBandwidths', 'type': '[ExpressRoutePortsLocationBandwidths]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePortsLocation, self).__init__(**kwargs) + self.address = None + self.contact = None + self.available_bandwidths = kwargs.get('available_bandwidths', None) + self.provisioning_state = None + + +class ExpressRoutePortsLocationBandwidths(msrest.serialization.Model): + """Real-time inventory of available ExpressRoute port bandwidths. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar offer_name: Bandwidth descriptive name. + :vartype offer_name: str + :ivar value_in_gbps: Bandwidth value in Gbps. + :vartype value_in_gbps: int + """ + + _validation = { + 'offer_name': {'readonly': True}, + 'value_in_gbps': {'readonly': True}, + } + + _attribute_map = { + 'offer_name': {'key': 'offerName', 'type': 'str'}, + 'value_in_gbps': {'key': 'valueInGbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePortsLocationBandwidths, self).__init__(**kwargs) + self.offer_name = None + self.value_in_gbps = None + + +class ExpressRoutePortsLocationListResult(msrest.serialization.Model): + """Response for ListExpressRoutePortsLocations API service call. + + :param value: The list of all ExpressRoutePort peering locations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocation] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRoutePortsLocation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePortsLocationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExpressRouteServiceProvider(Resource): + """A ExpressRouteResourceProvider object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 peering_locations: A list of peering locations. + :type peering_locations: list[str] + :param bandwidths_offered: A list of bandwidths offered. + :type bandwidths_offered: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProviderBandwidthsOffered] + :ivar provisioning_state: The provisioning state of the express route service provider + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'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}'}, + 'peering_locations': {'key': 'properties.peeringLocations', 'type': '[str]'}, + 'bandwidths_offered': {'key': 'properties.bandwidthsOffered', 'type': '[ExpressRouteServiceProviderBandwidthsOffered]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteServiceProvider, self).__init__(**kwargs) + self.peering_locations = kwargs.get('peering_locations', None) + self.bandwidths_offered = kwargs.get('bandwidths_offered', None) + self.provisioning_state = None + + +class ExpressRouteServiceProviderBandwidthsOffered(msrest.serialization.Model): + """Contains bandwidths offered in ExpressRouteServiceProvider resources. + + :param offer_name: The OfferName. + :type offer_name: str + :param value_in_mbps: The ValueInMbps. + :type value_in_mbps: int + """ + + _attribute_map = { + 'offer_name': {'key': 'offerName', 'type': 'str'}, + 'value_in_mbps': {'key': 'valueInMbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteServiceProviderBandwidthsOffered, self).__init__(**kwargs) + self.offer_name = kwargs.get('offer_name', None) + self.value_in_mbps = kwargs.get('value_in_mbps', None) + + +class ExpressRouteServiceProviderListResult(msrest.serialization.Model): + """Response for the ListExpressRouteServiceProvider API service call. + + :param value: A list of ExpressRouteResourceProvider resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProvider] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteServiceProvider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteServiceProviderListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ExtendedLocation(msrest.serialization.Model): + """ExtendedLocation complex type. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the extended location. + :type name: str + :param type: Required. The type of the extended location. Possible values include: "EdgeZone". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ExtendedLocationTypes + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExtendedLocation, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs['type'] + + +class FirewallPolicy(Resource): + """FirewallPolicy Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param identity: The identity of the firewall policy. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :ivar rule_collection_groups: List of references to FirewallPolicyRuleCollectionGroups. + :vartype rule_collection_groups: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the firewall policy resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param base_policy: The parent firewall policy from which rules are inherited. + :type base_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar firewalls: List of references to Azure Firewalls that this Firewall Policy is associated + with. + :vartype firewalls: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar child_policies: List of references to Child Firewall Policies. + :vartype child_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param threat_intel_mode: The operation mode for Threat Intelligence. Possible values include: + "Alert", "Deny", "Off". + :type threat_intel_mode: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallThreatIntelMode + :param threat_intel_whitelist: ThreatIntel Whitelist for Firewall Policy. + :type threat_intel_whitelist: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyThreatIntelWhitelist + :param dns_settings: DNS Proxy Settings definition. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.DnsSettings + :param intrusion_detection: The configuration for Intrusion detection. + :type intrusion_detection: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetection + :param transport_security: TLS Configuration definition. + :type transport_security: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyTransportSecurity + :param sku: The Firewall Policy SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicySku + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'rule_collection_groups': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'firewalls': {'readonly': True}, + 'child_policies': {'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'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'rule_collection_groups': {'key': 'properties.ruleCollectionGroups', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'base_policy': {'key': 'properties.basePolicy', 'type': 'SubResource'}, + 'firewalls': {'key': 'properties.firewalls', 'type': '[SubResource]'}, + 'child_policies': {'key': 'properties.childPolicies', 'type': '[SubResource]'}, + 'threat_intel_mode': {'key': 'properties.threatIntelMode', 'type': 'str'}, + 'threat_intel_whitelist': {'key': 'properties.threatIntelWhitelist', 'type': 'FirewallPolicyThreatIntelWhitelist'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'DnsSettings'}, + 'intrusion_detection': {'key': 'properties.intrusionDetection', 'type': 'FirewallPolicyIntrusionDetection'}, + 'transport_security': {'key': 'properties.transportSecurity', 'type': 'FirewallPolicyTransportSecurity'}, + 'sku': {'key': 'properties.sku', 'type': 'FirewallPolicySku'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicy, self).__init__(**kwargs) + self.etag = None + self.identity = kwargs.get('identity', None) + self.rule_collection_groups = None + self.provisioning_state = None + self.base_policy = kwargs.get('base_policy', None) + self.firewalls = None + self.child_policies = None + self.threat_intel_mode = kwargs.get('threat_intel_mode', None) + self.threat_intel_whitelist = kwargs.get('threat_intel_whitelist', None) + self.dns_settings = kwargs.get('dns_settings', None) + self.intrusion_detection = kwargs.get('intrusion_detection', None) + self.transport_security = kwargs.get('transport_security', None) + self.sku = kwargs.get('sku', None) + + +class FirewallPolicyCertificateAuthority(msrest.serialization.Model): + """Trusted Root certificates properties for tls. + + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :param name: Name of the CA certificate. + :type name: str + """ + + _attribute_map = { + 'key_vault_secret_id': {'key': 'keyVaultSecretId', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyCertificateAuthority, self).__init__(**kwargs) + self.key_vault_secret_id = kwargs.get('key_vault_secret_id', None) + self.name = kwargs.get('name', None) + + +class FirewallPolicyRuleCollection(msrest.serialization.Model): + """Properties of the rule collection. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: FirewallPolicyFilterRuleCollection, FirewallPolicyNatRuleCollection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + } + + _subtype_map = { + 'rule_collection_type': {'FirewallPolicyFilterRuleCollection': 'FirewallPolicyFilterRuleCollection', 'FirewallPolicyNatRuleCollection': 'FirewallPolicyNatRuleCollection'} + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyRuleCollection, self).__init__(**kwargs) + self.rule_collection_type = None # type: Optional[str] + self.name = kwargs.get('name', None) + self.priority = kwargs.get('priority', None) + + +class FirewallPolicyFilterRuleCollection(FirewallPolicyRuleCollection): + """Firewall Policy Filter Rule Collection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + :param action: The action type of a Filter rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyFilterRuleCollectionAction + :param rules: List of rules included in a rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRule] + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'FirewallPolicyFilterRuleCollectionAction'}, + 'rules': {'key': 'rules', 'type': '[FirewallPolicyRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyFilterRuleCollection, self).__init__(**kwargs) + self.rule_collection_type = 'FirewallPolicyFilterRuleCollection' # type: str + self.action = kwargs.get('action', None) + self.rules = kwargs.get('rules', None) + + +class FirewallPolicyFilterRuleCollectionAction(msrest.serialization.Model): + """Properties of the FirewallPolicyFilterRuleCollectionAction. + + :param type: The type of action. Possible values include: "Allow", "Deny". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyFilterRuleCollectionActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyFilterRuleCollectionAction, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + + +class FirewallPolicyIntrusionDetection(msrest.serialization.Model): + """Configuration for intrusion detection mode and rules. + + :param mode: Intrusion detection general state. Possible values include: "Off", "Alert", + "Deny". + :type mode: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionStateType + :param configuration: Intrusion detection configuration properties. + :type configuration: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionConfiguration + """ + + _attribute_map = { + 'mode': {'key': 'mode', 'type': 'str'}, + 'configuration': {'key': 'configuration', 'type': 'FirewallPolicyIntrusionDetectionConfiguration'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyIntrusionDetection, self).__init__(**kwargs) + self.mode = kwargs.get('mode', None) + self.configuration = kwargs.get('configuration', None) + + +class FirewallPolicyIntrusionDetectionBypassTrafficSpecifications(msrest.serialization.Model): + """Intrusion detection bypass traffic specification. + + :param name: Name of the bypass traffic rule. + :type name: str + :param description: Description of the bypass traffic rule. + :type description: str + :param protocol: The rule bypass protocol. Possible values include: "TCP", "UDP", "ICMP", + "ANY". + :type protocol: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionProtocol + :param source_addresses: List of source IP addresses or ranges for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or ranges for this rule. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports or ranges. + :type destination_ports: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionBypassTrafficSpecifications, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.protocol = kwargs.get('protocol', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.destination_ports = kwargs.get('destination_ports', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + self.destination_ip_groups = kwargs.get('destination_ip_groups', None) + + +class FirewallPolicyIntrusionDetectionConfiguration(msrest.serialization.Model): + """The operation for configuring intrusion detection. + + :param signature_overrides: List of specific signatures states. + :type signature_overrides: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionSignatureSpecification] + :param bypass_traffic_settings: List of rules for traffic to bypass. + :type bypass_traffic_settings: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionBypassTrafficSpecifications] + """ + + _attribute_map = { + 'signature_overrides': {'key': 'signatureOverrides', 'type': '[FirewallPolicyIntrusionDetectionSignatureSpecification]'}, + 'bypass_traffic_settings': {'key': 'bypassTrafficSettings', 'type': '[FirewallPolicyIntrusionDetectionBypassTrafficSpecifications]'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionConfiguration, self).__init__(**kwargs) + self.signature_overrides = kwargs.get('signature_overrides', None) + self.bypass_traffic_settings = kwargs.get('bypass_traffic_settings', None) + + +class FirewallPolicyIntrusionDetectionSignatureSpecification(msrest.serialization.Model): + """Intrusion detection signatures specification states. + + :param id: Signature id. + :type id: str + :param mode: The signature state. Possible values include: "Off", "Alert", "Deny". + :type mode: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionStateType + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'mode': {'key': 'mode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionSignatureSpecification, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.mode = kwargs.get('mode', None) + + +class FirewallPolicyListResult(msrest.serialization.Model): + """Response for ListFirewallPolicies API service call. + + :param value: List of Firewall Policies in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicy] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FirewallPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class FirewallPolicyNatRuleCollection(FirewallPolicyRuleCollection): + """Firewall Policy NAT Rule Collection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + :param action: The action type of a Nat rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyNatRuleCollectionAction + :param rules: List of rules included in a rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRule] + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'FirewallPolicyNatRuleCollectionAction'}, + 'rules': {'key': 'rules', 'type': '[FirewallPolicyRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyNatRuleCollection, self).__init__(**kwargs) + self.rule_collection_type = 'FirewallPolicyNatRuleCollection' # type: str + self.action = kwargs.get('action', None) + self.rules = kwargs.get('rules', None) + + +class FirewallPolicyNatRuleCollectionAction(msrest.serialization.Model): + """Properties of the FirewallPolicyNatRuleCollectionAction. + + :param type: The type of action. Possible values include: "DNAT". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyNatRuleCollectionActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyNatRuleCollectionAction, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + + +class FirewallPolicyRuleApplicationProtocol(msrest.serialization.Model): + """Properties of the application rule protocol. + + :param protocol_type: Protocol type. Possible values include: "Http", "Https". + :type protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleApplicationProtocolType + :param port: Port number for the protocol, cannot be greater than 64000. + :type port: int + """ + + _validation = { + 'port': {'maximum': 64000, 'minimum': 0}, + } + + _attribute_map = { + 'protocol_type': {'key': 'protocolType', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyRuleApplicationProtocol, self).__init__(**kwargs) + self.protocol_type = kwargs.get('protocol_type', None) + self.port = kwargs.get('port', None) + + +class FirewallPolicyRuleCollectionGroup(SubResource): + """Rule Collection Group resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Rule Group type. + :vartype type: str + :param priority: Priority of the Firewall Policy Rule Collection Group resource. + :type priority: int + :param rule_collections: Group of Firewall Policy rule collections. + :type rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollection] + :ivar provisioning_state: The provisioning state of the firewall policy rule collection group + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'rule_collections': {'key': 'properties.ruleCollections', 'type': '[FirewallPolicyRuleCollection]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyRuleCollectionGroup, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.priority = kwargs.get('priority', None) + self.rule_collections = kwargs.get('rule_collections', None) + self.provisioning_state = None + + +class FirewallPolicyRuleCollectionGroupListResult(msrest.serialization.Model): + """Response for ListFirewallPolicyRuleCollectionGroups API service call. + + :param value: List of FirewallPolicyRuleCollectionGroups in a FirewallPolicy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FirewallPolicyRuleCollectionGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyRuleCollectionGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class FirewallPolicySku(msrest.serialization.Model): + """SKU of Firewall policy. + + :param tier: Tier of Firewall Policy. Possible values include: "Standard", "Premium". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicySkuTier + """ + + _attribute_map = { + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicySku, self).__init__(**kwargs) + self.tier = kwargs.get('tier', None) + + +class FirewallPolicyThreatIntelWhitelist(msrest.serialization.Model): + """ThreatIntel Whitelist for Firewall Policy. + + :param ip_addresses: List of IP addresses for the ThreatIntel Whitelist. + :type ip_addresses: list[str] + :param fqdns: List of FQDNs for the ThreatIntel Whitelist. + :type fqdns: list[str] + """ + + _attribute_map = { + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + 'fqdns': {'key': 'fqdns', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyThreatIntelWhitelist, self).__init__(**kwargs) + self.ip_addresses = kwargs.get('ip_addresses', None) + self.fqdns = kwargs.get('fqdns', None) + + +class FirewallPolicyTransportSecurity(msrest.serialization.Model): + """Configuration needed to perform TLS termination & initiation. + + :param certificate_authority: The CA used for intermediate CA generation. + :type certificate_authority: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyCertificateAuthority + """ + + _attribute_map = { + 'certificate_authority': {'key': 'certificateAuthority', 'type': 'FirewallPolicyCertificateAuthority'}, + } + + def __init__( + self, + **kwargs + ): + super(FirewallPolicyTransportSecurity, self).__init__(**kwargs) + self.certificate_authority = kwargs.get('certificate_authority', None) + + +class FlowLog(Resource): + """A flow log resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param target_resource_id: ID of network security group to which flow log will be applied. + :type target_resource_id: str + :ivar target_resource_guid: Guid of network security group to which flow log will be applied. + :vartype target_resource_guid: str + :param storage_id: ID of the storage account which is used to store the flow log. + :type storage_id: str + :param enabled: Flag to enable/disable flow logging. + :type enabled: bool + :param retention_policy: Parameters that define the retention policy for flow log. + :type retention_policy: ~azure.mgmt.network.v2020_08_01.models.RetentionPolicyParameters + :param format: Parameters that define the flow log format. + :type format: ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatParameters + :param flow_analytics_configuration: Parameters that define the configuration of traffic + analytics. + :type flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsProperties + :ivar provisioning_state: The provisioning state of the flow log. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'target_resource_guid': {'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'}, + 'target_resource_id': {'key': 'properties.targetResourceId', 'type': 'str'}, + 'target_resource_guid': {'key': 'properties.targetResourceGuid', 'type': 'str'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'retention_policy': {'key': 'properties.retentionPolicy', 'type': 'RetentionPolicyParameters'}, + 'format': {'key': 'properties.format', 'type': 'FlowLogFormatParameters'}, + 'flow_analytics_configuration': {'key': 'properties.flowAnalyticsConfiguration', 'type': 'TrafficAnalyticsProperties'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FlowLog, self).__init__(**kwargs) + self.etag = None + self.target_resource_id = kwargs.get('target_resource_id', None) + self.target_resource_guid = None + self.storage_id = kwargs.get('storage_id', None) + self.enabled = kwargs.get('enabled', None) + self.retention_policy = kwargs.get('retention_policy', None) + self.format = kwargs.get('format', None) + self.flow_analytics_configuration = kwargs.get('flow_analytics_configuration', None) + self.provisioning_state = None + + +class FlowLogFormatParameters(msrest.serialization.Model): + """Parameters that define the flow log format. + + :param type: The file type of flow log. Possible values include: "JSON". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatType + :param version: The version (revision) of the flow log. + :type version: int + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'version': {'key': 'version', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(FlowLogFormatParameters, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.version = kwargs.get('version', 0) + + +class FlowLogInformation(msrest.serialization.Model): + """Information on the configuration of flow log and traffic analytics (optional) . + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the resource to configure for flow log and + traffic analytics (optional) . + :type target_resource_id: str + :param flow_analytics_configuration: Parameters that define the configuration of traffic + analytics. + :type flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsProperties + :param storage_id: Required. ID of the storage account which is used to store the flow log. + :type storage_id: str + :param enabled: Required. Flag to enable/disable flow logging. + :type enabled: bool + :param retention_policy: Parameters that define the retention policy for flow log. + :type retention_policy: ~azure.mgmt.network.v2020_08_01.models.RetentionPolicyParameters + :param format: Parameters that define the flow log format. + :type format: ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatParameters + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'storage_id': {'required': True}, + 'enabled': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'flow_analytics_configuration': {'key': 'flowAnalyticsConfiguration', 'type': 'TrafficAnalyticsProperties'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'retention_policy': {'key': 'properties.retentionPolicy', 'type': 'RetentionPolicyParameters'}, + 'format': {'key': 'properties.format', 'type': 'FlowLogFormatParameters'}, + } + + def __init__( + self, + **kwargs + ): + super(FlowLogInformation, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + self.flow_analytics_configuration = kwargs.get('flow_analytics_configuration', None) + self.storage_id = kwargs['storage_id'] + self.enabled = kwargs['enabled'] + self.retention_policy = kwargs.get('retention_policy', None) + self.format = kwargs.get('format', None) + + +class FlowLogListResult(msrest.serialization.Model): + """List of flow logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: Information about flow log resource. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FlowLog]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FlowLogListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class FlowLogStatusParameters(msrest.serialization.Model): + """Parameters that define a resource to query flow log and traffic analytics (optional) status. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource where getting the flow log and traffic + analytics (optional) status. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FlowLogStatusParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + + +class FrontendIPConfiguration(SubResource): + """Frontend IP address of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of frontend IP + configurations used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :ivar inbound_nat_rules: An array of references to inbound rules that use this frontend IP. + :vartype inbound_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar inbound_nat_pools: An array of references to inbound pools that use this frontend IP. + :vartype inbound_nat_pools: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar outbound_rules: An array of references to outbound rules that use this frontend IP. + :vartype outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar load_balancing_rules: An array of references to load balancing rules that use this + frontend IP. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The Private IP allocation method. Possible values include: + "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param private_ip_address_version: Whether the specific ipconfiguration is IPv4 or IPv6. + Default is taken as IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the Public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :param public_ip_prefix: The reference to the Public IP Prefix resource. + :type public_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the frontend IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'inbound_nat_rules': {'readonly': True}, + 'inbound_nat_pools': {'readonly': True}, + 'outbound_rules': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'inbound_nat_rules': {'key': 'properties.inboundNatRules', 'type': '[SubResource]'}, + 'inbound_nat_pools': {'key': 'properties.inboundNatPools', 'type': '[SubResource]'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[SubResource]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'public_ip_prefix': {'key': 'properties.publicIPPrefix', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FrontendIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.zones = kwargs.get('zones', None) + self.inbound_nat_rules = None + self.inbound_nat_pools = None + self.outbound_rules = None + self.load_balancing_rules = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.private_ip_address_version = kwargs.get('private_ip_address_version', None) + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.public_ip_prefix = kwargs.get('public_ip_prefix', None) + self.provisioning_state = None + + +class GatewayRoute(msrest.serialization.Model): + """Gateway routing details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The gateway's local address. + :vartype local_address: str + :ivar network: The route's network prefix. + :vartype network: str + :ivar next_hop: The route's next hop. + :vartype next_hop: str + :ivar source_peer: The peer this route was learned from. + :vartype source_peer: str + :ivar origin: The source this route was learned from. + :vartype origin: str + :ivar as_path: The route's AS path sequence. + :vartype as_path: str + :ivar weight: The route's weight. + :vartype weight: int + """ + + _validation = { + 'local_address': {'readonly': True}, + 'network': {'readonly': True}, + 'next_hop': {'readonly': True}, + 'source_peer': {'readonly': True}, + 'origin': {'readonly': True}, + 'as_path': {'readonly': True}, + 'weight': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'source_peer': {'key': 'sourcePeer', 'type': 'str'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(GatewayRoute, self).__init__(**kwargs) + self.local_address = None + self.network = None + self.next_hop = None + self.source_peer = None + self.origin = None + self.as_path = None + self.weight = None + + +class GatewayRouteListResult(msrest.serialization.Model): + """List of virtual network gateway routes. + + :param value: List of gateway routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.GatewayRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GatewayRoute]'}, + } + + def __init__( + self, + **kwargs + ): + super(GatewayRouteListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class GenerateExpressRoutePortsLOARequest(msrest.serialization.Model): + """The customer name to be printed on a letter of authorization. + + All required parameters must be populated in order to send to Azure. + + :param customer_name: Required. The customer name. + :type customer_name: str + """ + + _validation = { + 'customer_name': {'required': True}, + } + + _attribute_map = { + 'customer_name': {'key': 'customerName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GenerateExpressRoutePortsLOARequest, self).__init__(**kwargs) + self.customer_name = kwargs['customer_name'] + + +class GenerateExpressRoutePortsLOAResult(msrest.serialization.Model): + """Response for GenerateExpressRoutePortsLOA API service call. + + :param encoded_content: The content as a base64 encoded string. + :type encoded_content: str + """ + + _attribute_map = { + 'encoded_content': {'key': 'encodedContent', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GenerateExpressRoutePortsLOAResult, self).__init__(**kwargs) + self.encoded_content = kwargs.get('encoded_content', None) + + +class GetVpnSitesConfigurationRequest(msrest.serialization.Model): + """List of Vpn-Sites. + + All required parameters must be populated in order to send to Azure. + + :param vpn_sites: List of resource-ids of the vpn-sites for which config is to be downloaded. + :type vpn_sites: list[str] + :param output_blob_sas_url: Required. The sas-url to download the configurations for vpn-sites. + :type output_blob_sas_url: str + """ + + _validation = { + 'output_blob_sas_url': {'required': True}, + } + + _attribute_map = { + 'vpn_sites': {'key': 'vpnSites', 'type': '[str]'}, + 'output_blob_sas_url': {'key': 'outputBlobSasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GetVpnSitesConfigurationRequest, self).__init__(**kwargs) + self.vpn_sites = kwargs.get('vpn_sites', None) + self.output_blob_sas_url = kwargs['output_blob_sas_url'] + + +class HopLink(msrest.serialization.Model): + """Hop link. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar next_hop_id: The ID of the next hop. + :vartype next_hop_id: str + :ivar link_type: Link type. + :vartype link_type: str + :ivar issues: List of issues. + :vartype issues: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityIssue] + :ivar context: Provides additional context on links. + :vartype context: dict[str, str] + :ivar resource_id: Resource ID. + :vartype resource_id: str + :ivar round_trip_time_min: Minimum roundtrip time in milliseconds. + :vartype round_trip_time_min: long + :ivar round_trip_time_avg: Average roundtrip time in milliseconds. + :vartype round_trip_time_avg: long + :ivar round_trip_time_max: Maximum roundtrip time in milliseconds. + :vartype round_trip_time_max: long + """ + + _validation = { + 'next_hop_id': {'readonly': True}, + 'link_type': {'readonly': True}, + 'issues': {'readonly': True}, + 'context': {'readonly': True}, + 'resource_id': {'readonly': True}, + 'round_trip_time_min': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'round_trip_time_avg': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'round_trip_time_max': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + } + + _attribute_map = { + 'next_hop_id': {'key': 'nextHopId', 'type': 'str'}, + 'link_type': {'key': 'linkType', 'type': 'str'}, + 'issues': {'key': 'issues', 'type': '[ConnectivityIssue]'}, + 'context': {'key': 'context', 'type': '{str}'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'round_trip_time_min': {'key': 'properties.roundTripTimeMin', 'type': 'long'}, + 'round_trip_time_avg': {'key': 'properties.roundTripTimeAvg', 'type': 'long'}, + 'round_trip_time_max': {'key': 'properties.roundTripTimeMax', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(HopLink, self).__init__(**kwargs) + self.next_hop_id = None + self.link_type = None + self.issues = None + self.context = None + self.resource_id = None + self.round_trip_time_min = None + self.round_trip_time_avg = None + self.round_trip_time_max = None + + +class HTTPConfiguration(msrest.serialization.Model): + """HTTP configuration of the connectivity check. + + :param method: HTTP method. Possible values include: "Get". + :type method: str or ~azure.mgmt.network.v2020_08_01.models.HTTPMethod + :param headers: List of HTTP headers. + :type headers: list[~azure.mgmt.network.v2020_08_01.models.HTTPHeader] + :param valid_status_codes: Valid status codes. + :type valid_status_codes: list[int] + """ + + _attribute_map = { + 'method': {'key': 'method', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '[HTTPHeader]'}, + 'valid_status_codes': {'key': 'validStatusCodes', 'type': '[int]'}, + } + + def __init__( + self, + **kwargs + ): + super(HTTPConfiguration, self).__init__(**kwargs) + self.method = kwargs.get('method', None) + self.headers = kwargs.get('headers', None) + self.valid_status_codes = kwargs.get('valid_status_codes', None) + + +class HTTPHeader(msrest.serialization.Model): + """The HTTP header. + + :param name: The name in HTTP header. + :type name: str + :param value: The value in HTTP header. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HTTPHeader, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + + +class HubIPAddresses(msrest.serialization.Model): + """IP addresses associated with azure firewall. + + :param public_i_ps: Public IP addresses associated with azure firewall. + :type public_i_ps: ~azure.mgmt.network.v2020_08_01.models.HubPublicIPAddresses + :param private_ip_address: Private IP Address associated with azure firewall. + :type private_ip_address: str + """ + + _attribute_map = { + 'public_i_ps': {'key': 'publicIPs', 'type': 'HubPublicIPAddresses'}, + 'private_ip_address': {'key': 'privateIPAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HubIPAddresses, self).__init__(**kwargs) + self.public_i_ps = kwargs.get('public_i_ps', None) + self.private_ip_address = kwargs.get('private_ip_address', None) + + +class HubIpConfiguration(SubResource): + """IpConfigurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the Ip Configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Ipconfiguration type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :ivar provisioning_state: The provisioning state of the IP configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HubIpConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.provisioning_state = None + + +class HubPublicIPAddresses(msrest.serialization.Model): + """Public IP addresses associated with azure firewall. + + :param addresses: The list of Public IP addresses associated with azure firewall or IP + addresses to be retained. + :type addresses: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallPublicIPAddress] + :param count: The number of Public IP addresses associated with azure firewall. + :type count: int + """ + + _attribute_map = { + 'addresses': {'key': 'addresses', 'type': '[AzureFirewallPublicIPAddress]'}, + 'count': {'key': 'count', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(HubPublicIPAddresses, self).__init__(**kwargs) + self.addresses = kwargs.get('addresses', None) + self.count = kwargs.get('count', None) + + +class HubRoute(msrest.serialization.Model): + """RouteTable route. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the Route that is unique within a RouteTable. This name can + be used to access this route. + :type name: str + :param destination_type: Required. The type of destinations (eg: CIDR, ResourceId, Service). + :type destination_type: str + :param destinations: Required. List of all destinations. + :type destinations: list[str] + :param next_hop_type: Required. The type of next hop (eg: ResourceId). + :type next_hop_type: str + :param next_hop: Required. NextHop resource ID. + :type next_hop: str + """ + + _validation = { + 'name': {'required': True}, + 'destination_type': {'required': True}, + 'destinations': {'required': True}, + 'next_hop_type': {'required': True}, + 'next_hop': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'destination_type': {'key': 'destinationType', 'type': 'str'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HubRoute, self).__init__(**kwargs) + self.name = kwargs['name'] + self.destination_type = kwargs['destination_type'] + self.destinations = kwargs['destinations'] + self.next_hop_type = kwargs['next_hop_type'] + self.next_hop = kwargs['next_hop'] + + +class HubRouteTable(SubResource): + """RouteTable resource in a virtual hub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.HubRoute] + :param labels: List of labels associated with this route table. + :type labels: list[str] + :ivar associated_connections: List of all connections associated with this route table. + :vartype associated_connections: list[str] + :ivar propagating_connections: List of all connections that advertise to this route table. + :vartype propagating_connections: list[str] + :ivar provisioning_state: The provisioning state of the RouteTable resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'associated_connections': {'readonly': True}, + 'propagating_connections': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[HubRoute]'}, + 'labels': {'key': 'properties.labels', 'type': '[str]'}, + 'associated_connections': {'key': 'properties.associatedConnections', 'type': '[str]'}, + 'propagating_connections': {'key': 'properties.propagatingConnections', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HubRouteTable, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.routes = kwargs.get('routes', None) + self.labels = kwargs.get('labels', None) + self.associated_connections = None + self.propagating_connections = None + self.provisioning_state = None + + +class HubVirtualNetworkConnection(SubResource): + """HubVirtualNetworkConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param remote_virtual_network: Reference to the remote virtual network. + :type remote_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param allow_hub_to_remote_vnet_transit: Deprecated: VirtualHub to RemoteVnet transit to + enabled or not. + :type allow_hub_to_remote_vnet_transit: bool + :param allow_remote_vnet_to_use_hub_vnet_gateways: Deprecated: Allow RemoteVnet to use Virtual + Hub's gateways. + :type allow_remote_vnet_to_use_hub_vnet_gateways: bool + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + :ivar provisioning_state: The provisioning state of the hub virtual network connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'remote_virtual_network': {'key': 'properties.remoteVirtualNetwork', 'type': 'SubResource'}, + 'allow_hub_to_remote_vnet_transit': {'key': 'properties.allowHubToRemoteVnetTransit', 'type': 'bool'}, + 'allow_remote_vnet_to_use_hub_vnet_gateways': {'key': 'properties.allowRemoteVnetToUseHubVnetGateways', 'type': 'bool'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HubVirtualNetworkConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.remote_virtual_network = kwargs.get('remote_virtual_network', None) + self.allow_hub_to_remote_vnet_transit = kwargs.get('allow_hub_to_remote_vnet_transit', None) + self.allow_remote_vnet_to_use_hub_vnet_gateways = kwargs.get('allow_remote_vnet_to_use_hub_vnet_gateways', None) + self.enable_internet_security = kwargs.get('enable_internet_security', None) + self.routing_configuration = kwargs.get('routing_configuration', None) + self.provisioning_state = None + + +class InboundNatPool(SubResource): + """Inbound NAT pool of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of inbound NAT pools used + by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: The reference to the transport protocol used by the inbound NAT pool. Possible + values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param frontend_port_range_start: The first port number in the range of external ports that + will be used to provide Inbound Nat to NICs associated with a load balancer. Acceptable values + range between 1 and 65534. + :type frontend_port_range_start: int + :param frontend_port_range_end: The last port number in the range of external ports that will + be used to provide Inbound Nat to NICs associated with a load balancer. Acceptable values range + between 1 and 65535. + :type frontend_port_range_end: int + :param backend_port: The port used for internal connections on the endpoint. Acceptable values + are between 1 and 65535. + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :ivar provisioning_state: The provisioning state of the inbound NAT pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'frontend_port_range_start': {'key': 'properties.frontendPortRangeStart', 'type': 'int'}, + 'frontend_port_range_end': {'key': 'properties.frontendPortRangeEnd', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundNatPool, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.frontend_ip_configuration = kwargs.get('frontend_ip_configuration', None) + self.protocol = kwargs.get('protocol', None) + self.frontend_port_range_start = kwargs.get('frontend_port_range_start', None) + self.frontend_port_range_end = kwargs.get('frontend_port_range_end', None) + self.backend_port = kwargs.get('backend_port', None) + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + self.enable_floating_ip = kwargs.get('enable_floating_ip', None) + self.enable_tcp_reset = kwargs.get('enable_tcp_reset', None) + self.provisioning_state = None + + +class InboundNatRule(SubResource): + """Inbound NAT rule of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of inbound NAT rules used + by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar backend_ip_configuration: A reference to a private IP address defined on a network + interface of a VM. Traffic sent to the frontend port of each of the frontend IP configurations + is forwarded to the backend IP. + :vartype backend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param protocol: The reference to the transport protocol used by the load balancing rule. + Possible values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param frontend_port: The port for the external endpoint. Port numbers for each rule must be + unique within the Load Balancer. Acceptable values range from 1 to 65534. + :type frontend_port: int + :param backend_port: The port used for the internal endpoint. Acceptable values range from 1 to + 65535. + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :ivar provisioning_state: The provisioning state of the inbound NAT rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configuration': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'backend_ip_configuration': {'key': 'properties.backendIPConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundNatRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.frontend_ip_configuration = kwargs.get('frontend_ip_configuration', None) + self.backend_ip_configuration = None + self.protocol = kwargs.get('protocol', None) + self.frontend_port = kwargs.get('frontend_port', None) + self.backend_port = kwargs.get('backend_port', None) + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + self.enable_floating_ip = kwargs.get('enable_floating_ip', None) + self.enable_tcp_reset = kwargs.get('enable_tcp_reset', None) + self.provisioning_state = None + + +class InboundNatRuleListResult(msrest.serialization.Model): + """Response for ListInboundNatRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of inbound nat rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundNatRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundNatRuleListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class InboundSecurityRule(SubResource): + """NVA Inbound Security Rule resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of security rule collection. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: NVA inbound security rule type. + :vartype type: str + :param rules: List of allowed rules. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.InboundSecurityRules] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'rules': {'key': 'properties.rules', 'type': '[InboundSecurityRules]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundSecurityRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.rules = kwargs.get('rules', None) + self.provisioning_state = None + + +class InboundSecurityRules(msrest.serialization.Model): + """Properties of the Inbound Security Rules resource. + + :param protocol: Protocol. This should be either TCP or UDP. Possible values include: "TCP", + "UDP". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.InboundSecurityRulesProtocol + :param source_address_prefix: The CIDR or source IP range. Only /30, /31 and /32 Ip ranges are + allowed. + :type source_address_prefix: str + :param destination_port_range: NVA port ranges to be opened up. One needs to provide specific + ports. + :type destination_port_range: int + """ + + _validation = { + 'destination_port_range': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_address_prefix': {'key': 'sourceAddressPrefix', 'type': 'str'}, + 'destination_port_range': {'key': 'destinationPortRange', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundSecurityRules, self).__init__(**kwargs) + self.protocol = kwargs.get('protocol', None) + self.source_address_prefix = kwargs.get('source_address_prefix', None) + self.destination_port_range = kwargs.get('destination_port_range', None) + + +class IPAddressAvailabilityResult(msrest.serialization.Model): + """Response for CheckIPAddressAvailability API service call. + + :param available: Private IP address availability. + :type available: bool + :param available_ip_addresses: Contains other available private IP addresses if the asked for + address is taken. + :type available_ip_addresses: list[str] + """ + + _attribute_map = { + 'available': {'key': 'available', 'type': 'bool'}, + 'available_ip_addresses': {'key': 'availableIPAddresses', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(IPAddressAvailabilityResult, self).__init__(**kwargs) + self.available = kwargs.get('available', None) + self.available_ip_addresses = kwargs.get('available_ip_addresses', None) + + +class IpAllocation(Resource): + """IpAllocation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar subnet: The Subnet that using the prefix of this IpAllocation resource. + :vartype subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar virtual_network: The VirtualNetwork that using the prefix of this IpAllocation resource. + :vartype virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param type_properties_type: The type for the IpAllocation. Possible values include: + "Undefined", "Hypernet". + :type type_properties_type: str or ~azure.mgmt.network.v2020_08_01.models.IpAllocationType + :param prefix: The address prefix for the IpAllocation. + :type prefix: str + :param prefix_length: The address prefix length for the IpAllocation. + :type prefix_length: int + :param prefix_type: The address prefix Type for the IpAllocation. Possible values include: + "IPv4", "IPv6". + :type prefix_type: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param ipam_allocation_id: The IPAM allocation ID. + :type ipam_allocation_id: str + :param allocation_tags: IpAllocation tags. + :type allocation_tags: dict[str, str] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnet': {'readonly': True}, + 'virtual_network': {'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'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'SubResource'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + 'prefix': {'key': 'properties.prefix', 'type': 'str'}, + 'prefix_length': {'key': 'properties.prefixLength', 'type': 'int'}, + 'prefix_type': {'key': 'properties.prefixType', 'type': 'str'}, + 'ipam_allocation_id': {'key': 'properties.ipamAllocationId', 'type': 'str'}, + 'allocation_tags': {'key': 'properties.allocationTags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(IpAllocation, self).__init__(**kwargs) + self.etag = None + self.subnet = None + self.virtual_network = None + self.type_properties_type = kwargs.get('type_properties_type', None) + self.prefix = kwargs.get('prefix', None) + self.prefix_length = kwargs.get('prefix_length', 0) + self.prefix_type = kwargs.get('prefix_type', None) + self.ipam_allocation_id = kwargs.get('ipam_allocation_id', None) + self.allocation_tags = kwargs.get('allocation_tags', None) + + +class IpAllocationListResult(msrest.serialization.Model): + """Response for the ListIpAllocations API service call. + + :param value: A list of IpAllocation resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.IpAllocation] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[IpAllocation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IpAllocationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class IPConfiguration(SubResource): + """IP configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :ivar provisioning_state: The provisioning state of the IP configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.provisioning_state = None + + +class IPConfigurationBgpPeeringAddress(msrest.serialization.Model): + """Properties of IPConfigurationBgpPeeringAddress. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param ipconfiguration_id: The ID of IP configuration which belongs to gateway. + :type ipconfiguration_id: str + :ivar default_bgp_ip_addresses: The list of default BGP peering addresses which belong to IP + configuration. + :vartype default_bgp_ip_addresses: list[str] + :param custom_bgp_ip_addresses: The list of custom BGP peering addresses which belong to IP + configuration. + :type custom_bgp_ip_addresses: list[str] + :ivar tunnel_ip_addresses: The list of tunnel public IP addresses which belong to IP + configuration. + :vartype tunnel_ip_addresses: list[str] + """ + + _validation = { + 'default_bgp_ip_addresses': {'readonly': True}, + 'tunnel_ip_addresses': {'readonly': True}, + } + + _attribute_map = { + 'ipconfiguration_id': {'key': 'ipconfigurationId', 'type': 'str'}, + 'default_bgp_ip_addresses': {'key': 'defaultBgpIpAddresses', 'type': '[str]'}, + 'custom_bgp_ip_addresses': {'key': 'customBgpIpAddresses', 'type': '[str]'}, + 'tunnel_ip_addresses': {'key': 'tunnelIpAddresses', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(IPConfigurationBgpPeeringAddress, self).__init__(**kwargs) + self.ipconfiguration_id = kwargs.get('ipconfiguration_id', None) + self.default_bgp_ip_addresses = None + self.custom_bgp_ip_addresses = kwargs.get('custom_bgp_ip_addresses', None) + self.tunnel_ip_addresses = None + + +class IPConfigurationProfile(SubResource): + """IP configuration profile child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param subnet: The reference to the subnet resource to create a container network interface ip + configuration. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :ivar provisioning_state: The provisioning state of the IP configuration profile resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IPConfigurationProfile, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.subnet = kwargs.get('subnet', None) + self.provisioning_state = None + + +class IpGroup(Resource): + """The IpGroups resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the IpGroups resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ip_addresses: IpAddresses/IpAddressPrefixes in the IpGroups resource. + :type ip_addresses: list[str] + :ivar firewalls: List of references to Firewall resources that this IpGroups is associated + with. + :vartype firewalls: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar firewall_policies: List of references to Firewall Policies resources that this IpGroups + is associated with. + :vartype firewall_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'firewalls': {'readonly': True}, + 'firewall_policies': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'ip_addresses': {'key': 'properties.ipAddresses', 'type': '[str]'}, + 'firewalls': {'key': 'properties.firewalls', 'type': '[SubResource]'}, + 'firewall_policies': {'key': 'properties.firewallPolicies', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(IpGroup, self).__init__(**kwargs) + self.etag = None + self.provisioning_state = None + self.ip_addresses = kwargs.get('ip_addresses', None) + self.firewalls = None + self.firewall_policies = None + + +class IpGroupListResult(msrest.serialization.Model): + """Response for the ListIpGroups API service call. + + :param value: The list of IpGroups information resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.IpGroup] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[IpGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IpGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class IpsecPolicy(msrest.serialization.Model): + """An IPSec Policy configuration for a virtual network gateway connection. + + All required parameters must be populated in order to send to Azure. + + :param sa_life_time_seconds: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) lifetime in seconds for a site to site VPN tunnel. + :type sa_life_time_seconds: int + :param sa_data_size_kilobytes: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) payload size in KB for a site to site VPN tunnel. + :type sa_data_size_kilobytes: int + :param ipsec_encryption: Required. The IPSec encryption algorithm (IKE phase 1). Possible + values include: "None", "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES128", "GCMAES192", + "GCMAES256". + :type ipsec_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IpsecEncryption + :param ipsec_integrity: Required. The IPSec integrity algorithm (IKE phase 1). Possible values + include: "MD5", "SHA1", "SHA256", "GCMAES128", "GCMAES192", "GCMAES256". + :type ipsec_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IpsecIntegrity + :param ike_encryption: Required. The IKE encryption algorithm (IKE phase 2). Possible values + include: "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES256", "GCMAES128". + :type ike_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IkeEncryption + :param ike_integrity: Required. The IKE integrity algorithm (IKE phase 2). Possible values + include: "MD5", "SHA1", "SHA256", "SHA384", "GCMAES256", "GCMAES128". + :type ike_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IkeIntegrity + :param dh_group: Required. The DH Group used in IKE Phase 1 for initial SA. Possible values + include: "None", "DHGroup1", "DHGroup2", "DHGroup14", "DHGroup2048", "ECP256", "ECP384", + "DHGroup24". + :type dh_group: str or ~azure.mgmt.network.v2020_08_01.models.DhGroup + :param pfs_group: Required. The Pfs Group used in IKE Phase 2 for new child SA. Possible values + include: "None", "PFS1", "PFS2", "PFS2048", "ECP256", "ECP384", "PFS24", "PFS14", "PFSMM". + :type pfs_group: str or ~azure.mgmt.network.v2020_08_01.models.PfsGroup + """ + + _validation = { + 'sa_life_time_seconds': {'required': True}, + 'sa_data_size_kilobytes': {'required': True}, + 'ipsec_encryption': {'required': True}, + 'ipsec_integrity': {'required': True}, + 'ike_encryption': {'required': True}, + 'ike_integrity': {'required': True}, + 'dh_group': {'required': True}, + 'pfs_group': {'required': True}, + } + + _attribute_map = { + 'sa_life_time_seconds': {'key': 'saLifeTimeSeconds', 'type': 'int'}, + 'sa_data_size_kilobytes': {'key': 'saDataSizeKilobytes', 'type': 'int'}, + 'ipsec_encryption': {'key': 'ipsecEncryption', 'type': 'str'}, + 'ipsec_integrity': {'key': 'ipsecIntegrity', 'type': 'str'}, + 'ike_encryption': {'key': 'ikeEncryption', 'type': 'str'}, + 'ike_integrity': {'key': 'ikeIntegrity', 'type': 'str'}, + 'dh_group': {'key': 'dhGroup', 'type': 'str'}, + 'pfs_group': {'key': 'pfsGroup', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IpsecPolicy, self).__init__(**kwargs) + self.sa_life_time_seconds = kwargs['sa_life_time_seconds'] + self.sa_data_size_kilobytes = kwargs['sa_data_size_kilobytes'] + self.ipsec_encryption = kwargs['ipsec_encryption'] + self.ipsec_integrity = kwargs['ipsec_integrity'] + self.ike_encryption = kwargs['ike_encryption'] + self.ike_integrity = kwargs['ike_integrity'] + self.dh_group = kwargs['dh_group'] + self.pfs_group = kwargs['pfs_group'] + + +class IpTag(msrest.serialization.Model): + """Contains the IpTag associated with the object. + + :param ip_tag_type: The IP tag type. Example: FirstPartyUsage. + :type ip_tag_type: str + :param tag: The value of the IP tag associated with the public IP. Example: SQL. + :type tag: str + """ + + _attribute_map = { + 'ip_tag_type': {'key': 'ipTagType', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IpTag, self).__init__(**kwargs) + self.ip_tag_type = kwargs.get('ip_tag_type', None) + self.tag = kwargs.get('tag', None) + + +class Ipv6CircuitConnectionConfig(msrest.serialization.Model): + """IPv6 Circuit Connection properties for global reach. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param address_prefix: /125 IP address space to carve out customer addresses for global reach. + :type address_prefix: str + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + """ + + _validation = { + 'circuit_connection_status': {'readonly': True}, + } + + _attribute_map = { + 'address_prefix': {'key': 'addressPrefix', 'type': 'str'}, + 'circuit_connection_status': {'key': 'circuitConnectionStatus', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Ipv6CircuitConnectionConfig, self).__init__(**kwargs) + self.address_prefix = kwargs.get('address_prefix', None) + self.circuit_connection_status = None + + +class Ipv6ExpressRouteCircuitPeeringConfig(msrest.serialization.Model): + """Contains IPv6 peering config. + + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :param route_filter: The reference to the RouteFilter resource. + :type route_filter: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param state: The state of peering. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringState + """ + + _attribute_map = { + 'primary_peer_address_prefix': {'key': 'primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'secondaryPeerAddressPrefix', 'type': 'str'}, + 'microsoft_peering_config': {'key': 'microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'route_filter': {'key': 'routeFilter', 'type': 'SubResource'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Ipv6ExpressRouteCircuitPeeringConfig, self).__init__(**kwargs) + self.primary_peer_address_prefix = kwargs.get('primary_peer_address_prefix', None) + self.secondary_peer_address_prefix = kwargs.get('secondary_peer_address_prefix', None) + self.microsoft_peering_config = kwargs.get('microsoft_peering_config', None) + self.route_filter = kwargs.get('route_filter', None) + self.state = kwargs.get('state', None) + + +class ListHubRouteTablesResult(msrest.serialization.Model): + """List of RouteTables and a URL nextLink to get the next set of results. + + :param value: List of RouteTables. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubRouteTable] + :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': '[HubRouteTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListHubRouteTablesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListHubVirtualNetworkConnectionsResult(msrest.serialization.Model): + """List of HubVirtualNetworkConnections and a URL nextLink to get the next set of results. + + :param value: List of HubVirtualNetworkConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection] + :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': '[HubVirtualNetworkConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListHubVirtualNetworkConnectionsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListP2SVpnGatewaysResult(msrest.serialization.Model): + """Result of the request to list P2SVpnGateways. It contains a list of P2SVpnGateways and a URL nextLink to get the next set of results. + + :param value: List of P2SVpnGateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :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': '[P2SVpnGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListP2SVpnGatewaysResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVirtualHubBgpConnectionResults(msrest.serialization.Model): + """VirtualHubBgpConnections list. + + :param value: The list of VirtualHubBgpConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpConnection] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVirtualHubBgpConnectionResults, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVirtualHubIpConfigurationResults(msrest.serialization.Model): + """VirtualHubIpConfigurations list. + + :param value: The list of VirtualHubIpConfigurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HubIpConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVirtualHubIpConfigurationResults, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVirtualHubRouteTableV2SResult(msrest.serialization.Model): + """List of VirtualHubRouteTableV2s and a URL nextLink to get the next set of results. + + :param value: List of VirtualHubRouteTableV2s. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :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': '[VirtualHubRouteTableV2]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVirtualHubRouteTableV2SResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVirtualHubsResult(msrest.serialization.Model): + """Result of the request to list VirtualHubs. It contains a list of VirtualHubs and a URL nextLink to get the next set of results. + + :param value: List of VirtualHubs. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHub] + :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': '[VirtualHub]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVirtualHubsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVirtualWANsResult(msrest.serialization.Model): + """Result of the request to list VirtualWANs. It contains a list of VirtualWANs and a URL nextLink to get the next set of results. + + :param value: List of VirtualWANs. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualWAN] + :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': '[VirtualWAN]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVirtualWANsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnConnectionsResult(msrest.serialization.Model): + """Result of the request to list all vpn connections to a virtual wan vpn gateway. It contains a list of Vpn Connections and a URL nextLink to get the next set of results. + + :param value: List of Vpn Connections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :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': '[VpnConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnConnectionsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnGatewayNatRulesResult(msrest.serialization.Model): + """Result of the request to list all nat rules to a virtual wan vpn gateway. It contains a list of Nat rules and a URL nextLink to get the next set of results. + + :param value: List of Nat Rules. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + :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': '[VpnGatewayNatRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnGatewayNatRulesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnGatewaysResult(msrest.serialization.Model): + """Result of the request to list VpnGateways. It contains a list of VpnGateways and a URL nextLink to get the next set of results. + + :param value: List of VpnGateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :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': '[VpnGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnGatewaysResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnServerConfigurationsResult(msrest.serialization.Model): + """Result of the request to list all VpnServerConfigurations. It contains a list of VpnServerConfigurations and a URL nextLink to get the next set of results. + + :param value: List of VpnServerConfigurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration] + :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': '[VpnServerConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnServerConfigurationsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnSiteLinkConnectionsResult(msrest.serialization.Model): + """Result of the request to list all vpn connections to a virtual wan vpn gateway. It contains a list of Vpn Connections and a URL nextLink to get the next set of results. + + :param value: List of VpnSiteLinkConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection] + :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': '[VpnSiteLinkConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnSiteLinkConnectionsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnSiteLinksResult(msrest.serialization.Model): + """Result of the request to list VpnSiteLinks. It contains a list of VpnSiteLinks and a URL nextLink to get the next set of results. + + :param value: List of VpnSitesLinks. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLink] + :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': '[VpnSiteLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnSiteLinksResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ListVpnSitesResult(msrest.serialization.Model): + """Result of the request to list VpnSites. It contains a list of VpnSites and a URL nextLink to get the next set of results. + + :param value: List of VpnSites. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSite] + :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': '[VpnSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ListVpnSitesResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class LoadBalancer(Resource): + """LoadBalancer resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The load balancer SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param frontend_ip_configurations: Object representing the frontend IPs to be used for the load + balancer. + :type frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :param backend_address_pools: Collection of backend address pools used by a load balancer. + :type backend_address_pools: list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :param load_balancing_rules: Object collection representing the load balancing rules Gets the + provisioning. + :type load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule] + :param probes: Collection of probe objects used in the load balancer. + :type probes: list[~azure.mgmt.network.v2020_08_01.models.Probe] + :param inbound_nat_rules: Collection of inbound NAT Rules used by a load balancer. Defining + inbound NAT rules on your load balancer is mutually exclusive with defining an inbound NAT + pool. Inbound NAT pools are referenced from virtual machine scale sets. NICs that are + associated with individual virtual machines cannot reference an Inbound NAT pool. They have to + reference individual inbound NAT rules. + :type inbound_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :param inbound_nat_pools: Defines an external port range for inbound NAT to a single backend + port on NICs associated with a load balancer. Inbound NAT rules are created automatically for + each NIC associated with the Load Balancer using an external port from this range. Defining an + Inbound NAT pool on your Load Balancer is mutually exclusive with defining inbound Nat rules. + Inbound NAT pools are referenced from virtual machine scale sets. NICs that are associated with + individual virtual machines cannot reference an inbound NAT pool. They have to reference + individual inbound NAT rules. + :type inbound_nat_pools: list[~azure.mgmt.network.v2020_08_01.models.InboundNatPool] + :param outbound_rules: The outbound rules. + :type outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.OutboundRule] + :ivar resource_guid: The resource GUID property of the load balancer resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the load balancer resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'LoadBalancerSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[FrontendIPConfiguration]'}, + 'backend_address_pools': {'key': 'properties.backendAddressPools', 'type': '[BackendAddressPool]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[LoadBalancingRule]'}, + 'probes': {'key': 'properties.probes', 'type': '[Probe]'}, + 'inbound_nat_rules': {'key': 'properties.inboundNatRules', 'type': '[InboundNatRule]'}, + 'inbound_nat_pools': {'key': 'properties.inboundNatPools', 'type': '[InboundNatPool]'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[OutboundRule]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancer, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.sku = kwargs.get('sku', None) + self.etag = None + self.frontend_ip_configurations = kwargs.get('frontend_ip_configurations', None) + self.backend_address_pools = kwargs.get('backend_address_pools', None) + self.load_balancing_rules = kwargs.get('load_balancing_rules', None) + self.probes = kwargs.get('probes', None) + self.inbound_nat_rules = kwargs.get('inbound_nat_rules', None) + self.inbound_nat_pools = kwargs.get('inbound_nat_pools', None) + self.outbound_rules = kwargs.get('outbound_rules', None) + self.resource_guid = None + self.provisioning_state = None + + +class LoadBalancerBackendAddress(msrest.serialization.Model): + """Load balancer backend addresses. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the backend address. + :type name: str + :param virtual_network: Reference to an existing virtual network. + :type virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ip_address: IP Address belonging to the referenced virtual network. + :type ip_address: str + :ivar network_interface_ip_configuration: Reference to IP address defined in network + interfaces. + :vartype network_interface_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param load_balancer_frontend_ip_configuration: Reference to the frontend ip address + configuration defined in regional loadbalancer. + :type load_balancer_frontend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'network_interface_ip_configuration': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'SubResource'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'network_interface_ip_configuration': {'key': 'properties.networkInterfaceIPConfiguration', 'type': 'SubResource'}, + 'load_balancer_frontend_ip_configuration': {'key': 'properties.loadBalancerFrontendIPConfiguration', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerBackendAddress, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.virtual_network = kwargs.get('virtual_network', None) + self.ip_address = kwargs.get('ip_address', None) + self.network_interface_ip_configuration = None + self.load_balancer_frontend_ip_configuration = kwargs.get('load_balancer_frontend_ip_configuration', None) + + +class LoadBalancerBackendAddressPoolListResult(msrest.serialization.Model): + """Response for ListBackendAddressPool API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of backend address pools in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackendAddressPool]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerBackendAddressPoolListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerFrontendIPConfigurationListResult(msrest.serialization.Model): + """Response for ListFrontendIPConfiguration API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of frontend IP configurations in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FrontendIPConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerFrontendIPConfigurationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerListResult(msrest.serialization.Model): + """Response for ListLoadBalancers API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancers in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerLoadBalancingRuleListResult(msrest.serialization.Model): + """Response for ListLoadBalancingRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancing rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancingRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerLoadBalancingRuleListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerOutboundRuleListResult(msrest.serialization.Model): + """Response for ListOutboundRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of outbound rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.OutboundRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerOutboundRuleListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerProbeListResult(msrest.serialization.Model): + """Response for ListProbe API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of probes in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Probe] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Probe]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerProbeListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LoadBalancerSku(msrest.serialization.Model): + """SKU of a load balancer. + + :param name: Name of a load balancer SKU. Possible values include: "Basic", "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSkuName + :param tier: Tier of a load balancer SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancerSku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + + +class LoadBalancingRule(SubResource): + """A load balancing rule for a load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of load balancing rules + used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_address_pool: A reference to a pool of DIPs. Inbound traffic is randomly load + balanced across IPs in the backend IPs. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param probe: The reference to the load balancer probe used by the load balancing rule. + :type probe: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: The reference to the transport protocol used by the load balancing rule. + Possible values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param load_distribution: The load distribution policy for this rule. Possible values include: + "Default", "SourceIP", "SourceIPProtocol". + :type load_distribution: str or ~azure.mgmt.network.v2020_08_01.models.LoadDistribution + :param frontend_port: The port for the external endpoint. Port numbers for each rule must be + unique within the Load Balancer. Acceptable values are between 0 and 65534. Note that value 0 + enables "Any Port". + :type frontend_port: int + :param backend_port: The port used for internal connections on the endpoint. Acceptable values + are between 0 and 65535. Note that value 0 enables "Any Port". + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :param disable_outbound_snat: Configures SNAT for the VMs in the backend pool to use the + publicIP address specified in the frontend of the load balancing rule. + :type disable_outbound_snat: bool + :ivar provisioning_state: The provisioning state of the load balancing rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'probe': {'key': 'properties.probe', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'load_distribution': {'key': 'properties.loadDistribution', 'type': 'str'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'disable_outbound_snat': {'key': 'properties.disableOutboundSnat', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancingRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.frontend_ip_configuration = kwargs.get('frontend_ip_configuration', None) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.probe = kwargs.get('probe', None) + self.protocol = kwargs.get('protocol', None) + self.load_distribution = kwargs.get('load_distribution', None) + self.frontend_port = kwargs.get('frontend_port', None) + self.backend_port = kwargs.get('backend_port', None) + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + self.enable_floating_ip = kwargs.get('enable_floating_ip', None) + self.enable_tcp_reset = kwargs.get('enable_tcp_reset', None) + self.disable_outbound_snat = kwargs.get('disable_outbound_snat', None) + self.provisioning_state = None + + +class LocalNetworkGateway(Resource): + """A common class for general resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param local_network_address_space: Local network site address space. + :type local_network_address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param gateway_ip_address: IP address of local network gateway. + :type gateway_ip_address: str + :param fqdn: FQDN of local network gateway. + :type fqdn: str + :param bgp_settings: Local network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar resource_guid: The resource GUID property of the local network gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the local network gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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'}, + 'local_network_address_space': {'key': 'properties.localNetworkAddressSpace', 'type': 'AddressSpace'}, + 'gateway_ip_address': {'key': 'properties.gatewayIpAddress', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LocalNetworkGateway, self).__init__(**kwargs) + self.etag = None + self.local_network_address_space = kwargs.get('local_network_address_space', None) + self.gateway_ip_address = kwargs.get('gateway_ip_address', None) + self.fqdn = kwargs.get('fqdn', None) + self.bgp_settings = kwargs.get('bgp_settings', None) + self.resource_guid = None + self.provisioning_state = None + + +class LocalNetworkGatewayListResult(msrest.serialization.Model): + """Response for ListLocalNetworkGateways API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of local network gateways that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LocalNetworkGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LocalNetworkGatewayListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class LogSpecification(msrest.serialization.Model): + """Description of logging specification. + + :param name: The name of the specification. + :type name: str + :param display_name: The display name of the specification. + :type display_name: str + :param blob_duration: Duration of the blob. + :type blob_duration: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', '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) + + +class ManagedRuleGroupOverride(msrest.serialization.Model): + """Defines a managed rule group override setting. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The managed rule group to override. + :type rule_group_name: str + :param rules: List of rules that will be disabled. If none specified, all rules in the group + will be disabled. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleOverride] + """ + + _validation = { + 'rule_group_name': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[ManagedRuleOverride]'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedRuleGroupOverride, self).__init__(**kwargs) + self.rule_group_name = kwargs['rule_group_name'] + self.rules = kwargs.get('rules', None) + + +class ManagedRuleOverride(msrest.serialization.Model): + """Defines a managed rule group override setting. + + All required parameters must be populated in order to send to Azure. + + :param rule_id: Required. Identifier for the managed rule. + :type rule_id: str + :param state: The state of the managed rule. Defaults to Disabled if not specified. Possible + values include: "Disabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ManagedRuleEnabledState + """ + + _validation = { + 'rule_id': {'required': True}, + } + + _attribute_map = { + 'rule_id': {'key': 'ruleId', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedRuleOverride, self).__init__(**kwargs) + self.rule_id = kwargs['rule_id'] + self.state = kwargs.get('state', None) + + +class ManagedRulesDefinition(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param exclusions: The Exclusions that are applied on the policy. + :type exclusions: list[~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntry] + :param managed_rule_sets: Required. The managed rule sets that are associated with the policy. + :type managed_rule_sets: list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleSet] + """ + + _validation = { + 'managed_rule_sets': {'required': True}, + } + + _attribute_map = { + 'exclusions': {'key': 'exclusions', 'type': '[OwaspCrsExclusionEntry]'}, + 'managed_rule_sets': {'key': 'managedRuleSets', 'type': '[ManagedRuleSet]'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedRulesDefinition, self).__init__(**kwargs) + self.exclusions = kwargs.get('exclusions', None) + self.managed_rule_sets = kwargs['managed_rule_sets'] + + +class ManagedRuleSet(msrest.serialization.Model): + """Defines a managed rule set. + + All required parameters must be populated in order to send to Azure. + + :param rule_set_type: Required. Defines the rule set type to use. + :type rule_set_type: str + :param rule_set_version: Required. Defines the version of the rule set to use. + :type rule_set_version: str + :param rule_group_overrides: Defines the rule group overrides to apply to the rule set. + :type rule_group_overrides: + list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleGroupOverride] + """ + + _validation = { + 'rule_set_type': {'required': True}, + 'rule_set_version': {'required': True}, + } + + _attribute_map = { + 'rule_set_type': {'key': 'ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'ruleSetVersion', 'type': 'str'}, + 'rule_group_overrides': {'key': 'ruleGroupOverrides', 'type': '[ManagedRuleGroupOverride]'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedRuleSet, self).__init__(**kwargs) + self.rule_set_type = kwargs['rule_set_type'] + self.rule_set_version = kwargs['rule_set_version'] + self.rule_group_overrides = kwargs.get('rule_group_overrides', None) + + +class ManagedServiceIdentity(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 system assigned identity. This property will only + be provided for a system assigned identity. + :vartype principal_id: str + :ivar tenant_id: The tenant id of the system assigned identity. This property will only be + provided for a system assigned identity. + :vartype tenant_id: str + :param type: The type of identity used for the resource. The type 'SystemAssigned, + UserAssigned' includes both an implicitly created identity and a set of user assigned + identities. The type 'None' will remove any identities from the virtual machine. Possible + values include: "SystemAssigned", "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ResourceIdentityType + :param user_assigned_identities: The list of user identities associated with 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.network.v2020_08_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _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': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedServiceIdentity, 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 MatchCondition(msrest.serialization.Model): + """Define match conditions. + + All required parameters must be populated in order to send to Azure. + + :param match_variables: Required. List of match variables. + :type match_variables: list[~azure.mgmt.network.v2020_08_01.models.MatchVariable] + :param operator: Required. The operator to be matched. Possible values include: "IPMatch", + "Equal", "Contains", "LessThan", "GreaterThan", "LessThanOrEqual", "GreaterThanOrEqual", + "BeginsWith", "EndsWith", "Regex", "GeoMatch". + :type operator: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallOperator + :param negation_conditon: Whether this is negate condition or not. + :type negation_conditon: bool + :param match_values: Required. Match value. + :type match_values: list[str] + :param transforms: List of transforms. + :type transforms: list[str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallTransform] + """ + + _validation = { + 'match_variables': {'required': True}, + 'operator': {'required': True}, + 'match_values': {'required': True}, + } + + _attribute_map = { + 'match_variables': {'key': 'matchVariables', 'type': '[MatchVariable]'}, + 'operator': {'key': 'operator', 'type': 'str'}, + 'negation_conditon': {'key': 'negationConditon', 'type': 'bool'}, + 'match_values': {'key': 'matchValues', 'type': '[str]'}, + 'transforms': {'key': 'transforms', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(MatchCondition, self).__init__(**kwargs) + self.match_variables = kwargs['match_variables'] + self.operator = kwargs['operator'] + self.negation_conditon = kwargs.get('negation_conditon', None) + self.match_values = kwargs['match_values'] + self.transforms = kwargs.get('transforms', None) + + +class MatchedRule(msrest.serialization.Model): + """Matched rule. + + :param rule_name: Name of the matched network security rule. + :type rule_name: str + :param action: The network traffic is allowed or denied. Possible values are 'Allow' and + 'Deny'. + :type action: str + """ + + _attribute_map = { + 'rule_name': {'key': 'ruleName', 'type': 'str'}, + 'action': {'key': 'action', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MatchedRule, self).__init__(**kwargs) + self.rule_name = kwargs.get('rule_name', None) + self.action = kwargs.get('action', None) + + +class MatchVariable(msrest.serialization.Model): + """Define match variables. + + All required parameters must be populated in order to send to Azure. + + :param variable_name: Required. Match Variable. Possible values include: "RemoteAddr", + "RequestMethod", "QueryString", "PostArgs", "RequestUri", "RequestHeaders", "RequestBody", + "RequestCookies". + :type variable_name: str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallMatchVariable + :param selector: The selector of match variable. + :type selector: str + """ + + _validation = { + 'variable_name': {'required': True}, + } + + _attribute_map = { + 'variable_name': {'key': 'variableName', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MatchVariable, self).__init__(**kwargs) + self.variable_name = kwargs['variable_name'] + self.selector = kwargs.get('selector', None) + + +class MetricSpecification(msrest.serialization.Model): + """Description of metrics specification. + + :param name: The name of the metric. + :type name: str + :param display_name: The display name of the metric. + :type display_name: str + :param display_description: The description of the metric. + :type display_description: str + :param unit: Units the metric to be displayed in. + :type unit: str + :param aggregation_type: The aggregation type. + :type aggregation_type: str + :param availabilities: List of availability. + :type availabilities: list[~azure.mgmt.network.v2020_08_01.models.Availability] + :param enable_regional_mdm_account: Whether regional MDM account enabled. + :type enable_regional_mdm_account: bool + :param fill_gap_with_zero: Whether gaps would be filled with zeros. + :type fill_gap_with_zero: bool + :param metric_filter_pattern: Pattern for the filter of the metric. + :type metric_filter_pattern: str + :param dimensions: List of dimensions. + :type dimensions: list[~azure.mgmt.network.v2020_08_01.models.Dimension] + :param is_internal: Whether the metric is internal. + :type is_internal: bool + :param source_mdm_account: The source MDM account. + :type source_mdm_account: str + :param source_mdm_namespace: The source MDM namespace. + :type source_mdm_namespace: str + :param resource_id_dimension_name_override: The resource Id dimension name override. + :type resource_id_dimension_name_override: 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'}, + 'availabilities': {'key': 'availabilities', 'type': '[Availability]'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'resource_id_dimension_name_override': {'key': 'resourceIdDimensionNameOverride', '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.availabilities = kwargs.get('availabilities', None) + self.enable_regional_mdm_account = kwargs.get('enable_regional_mdm_account', None) + self.fill_gap_with_zero = kwargs.get('fill_gap_with_zero', None) + self.metric_filter_pattern = kwargs.get('metric_filter_pattern', None) + self.dimensions = kwargs.get('dimensions', None) + self.is_internal = kwargs.get('is_internal', None) + self.source_mdm_account = kwargs.get('source_mdm_account', None) + self.source_mdm_namespace = kwargs.get('source_mdm_namespace', None) + self.resource_id_dimension_name_override = kwargs.get('resource_id_dimension_name_override', None) + + +class NatGateway(Resource): + """Nat Gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 sku: The nat gateway SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.NatGatewaySku + :param zones: A list of availability zones denoting the zone in which Nat Gateway should be + deployed. + :type zones: list[str] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param idle_timeout_in_minutes: The idle timeout of the nat gateway. + :type idle_timeout_in_minutes: int + :param public_ip_addresses: An array of public ip addresses associated with the nat gateway + resource. + :type public_ip_addresses: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param public_ip_prefixes: An array of public ip prefixes associated with the nat gateway + resource. + :type public_ip_prefixes: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar subnets: An array of references to the subnets using this nat gateway resource. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_guid: The resource GUID property of the NAT gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the NAT gateway resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'resource_guid': {'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}'}, + 'sku': {'key': 'sku', 'type': 'NatGatewaySku'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'public_ip_addresses': {'key': 'properties.publicIpAddresses', 'type': '[SubResource]'}, + 'public_ip_prefixes': {'key': 'properties.publicIpPrefixes', 'type': '[SubResource]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[SubResource]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NatGateway, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.zones = kwargs.get('zones', None) + self.etag = None + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + self.public_ip_addresses = kwargs.get('public_ip_addresses', None) + self.public_ip_prefixes = kwargs.get('public_ip_prefixes', None) + self.subnets = None + self.resource_guid = None + self.provisioning_state = None + + +class NatGatewayListResult(msrest.serialization.Model): + """Response for ListNatGateways API service call. + + :param value: A list of Nat Gateways that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NatGateway] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NatGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NatGatewayListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NatGatewaySku(msrest.serialization.Model): + """SKU of nat gateway. + + :param name: Name of Nat Gateway SKU. Possible values include: "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.NatGatewaySkuName + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NatGatewaySku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + + +class NatRule(FirewallPolicyRule): + """Rule of type nat. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param ip_protocols: Array of FirewallPolicyRuleNetworkProtocols. + :type ip_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleNetworkProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param translated_address: The translated address for this NAT rule. + :type translated_address: str + :param translated_port: The translated port for this NAT rule. + :type translated_port: str + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param translated_fqdn: The translated FQDN for this NAT rule. + :type translated_fqdn: str + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'ip_protocols': {'key': 'ipProtocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'translated_address': {'key': 'translatedAddress', 'type': 'str'}, + 'translated_port': {'key': 'translatedPort', 'type': 'str'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'translated_fqdn': {'key': 'translatedFqdn', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NatRule, self).__init__(**kwargs) + self.rule_type = 'NatRule' # type: str + self.ip_protocols = kwargs.get('ip_protocols', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.destination_ports = kwargs.get('destination_ports', None) + self.translated_address = kwargs.get('translated_address', None) + self.translated_port = kwargs.get('translated_port', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + self.translated_fqdn = kwargs.get('translated_fqdn', None) + + +class NetworkConfigurationDiagnosticParameters(msrest.serialization.Model): + """Parameters to get network configuration diagnostic. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the target resource to perform network + configuration diagnostic. Valid options are VM, NetworkInterface, VMSS/NetworkInterface and + Application Gateway. + :type target_resource_id: str + :param verbosity_level: Verbosity level. Possible values include: "Normal", "Minimum", "Full". + :type verbosity_level: str or ~azure.mgmt.network.v2020_08_01.models.VerbosityLevel + :param profiles: Required. List of network configuration diagnostic profiles. + :type profiles: + list[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticProfile] + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'profiles': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'verbosity_level': {'key': 'verbosityLevel', 'type': 'str'}, + 'profiles': {'key': 'profiles', 'type': '[NetworkConfigurationDiagnosticProfile]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkConfigurationDiagnosticParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + self.verbosity_level = kwargs.get('verbosity_level', None) + self.profiles = kwargs['profiles'] + + +class NetworkConfigurationDiagnosticProfile(msrest.serialization.Model): + """Parameters to compare with network configuration. + + All required parameters must be populated in order to send to Azure. + + :param direction: Required. The direction of the traffic. Possible values include: "Inbound", + "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.Direction + :param protocol: Required. Protocol to be verified on. Accepted values are '*', TCP, UDP. + :type protocol: str + :param source: Required. Traffic source. Accepted values are '*', IP Address/CIDR, Service Tag. + :type source: str + :param destination: Required. Traffic destination. Accepted values are: '*', IP Address/CIDR, + Service Tag. + :type destination: str + :param destination_port: Required. Traffic destination port. Accepted values are '*' and a + single port in the range (0 - 65535). + :type destination_port: str + """ + + _validation = { + 'direction': {'required': True}, + 'protocol': {'required': True}, + 'source': {'required': True}, + 'destination': {'required': True}, + 'destination_port': {'required': True}, + } + + _attribute_map = { + 'direction': {'key': 'direction', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'destination': {'key': 'destination', 'type': 'str'}, + 'destination_port': {'key': 'destinationPort', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkConfigurationDiagnosticProfile, self).__init__(**kwargs) + self.direction = kwargs['direction'] + self.protocol = kwargs['protocol'] + self.source = kwargs['source'] + self.destination = kwargs['destination'] + self.destination_port = kwargs['destination_port'] + + +class NetworkConfigurationDiagnosticResponse(msrest.serialization.Model): + """Results of network configuration diagnostic on the target resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar results: List of network configuration diagnostic results. + :vartype results: + list[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticResult] + """ + + _validation = { + 'results': {'readonly': True}, + } + + _attribute_map = { + 'results': {'key': 'results', 'type': '[NetworkConfigurationDiagnosticResult]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkConfigurationDiagnosticResponse, self).__init__(**kwargs) + self.results = None + + +class NetworkConfigurationDiagnosticResult(msrest.serialization.Model): + """Network configuration diagnostic result corresponded to provided traffic query. + + :param profile: Network configuration diagnostic profile. + :type profile: ~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticProfile + :param network_security_group_result: Network security group result. + :type network_security_group_result: + ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupResult + """ + + _attribute_map = { + 'profile': {'key': 'profile', 'type': 'NetworkConfigurationDiagnosticProfile'}, + 'network_security_group_result': {'key': 'networkSecurityGroupResult', 'type': 'NetworkSecurityGroupResult'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkConfigurationDiagnosticResult, self).__init__(**kwargs) + self.profile = kwargs.get('profile', None) + self.network_security_group_result = kwargs.get('network_security_group_result', None) + + +class NetworkIntentPolicy(Resource): + """Network Intent Policy resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkIntentPolicy, self).__init__(**kwargs) + self.etag = None + + +class NetworkIntentPolicyConfiguration(msrest.serialization.Model): + """Details of NetworkIntentPolicyConfiguration for PrepareNetworkPoliciesRequest. + + :param network_intent_policy_name: The name of the Network Intent Policy for storing in target + subscription. + :type network_intent_policy_name: str + :param source_network_intent_policy: Source network intent policy. + :type source_network_intent_policy: ~azure.mgmt.network.v2020_08_01.models.NetworkIntentPolicy + """ + + _attribute_map = { + 'network_intent_policy_name': {'key': 'networkIntentPolicyName', 'type': 'str'}, + 'source_network_intent_policy': {'key': 'sourceNetworkIntentPolicy', 'type': 'NetworkIntentPolicy'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkIntentPolicyConfiguration, self).__init__(**kwargs) + self.network_intent_policy_name = kwargs.get('network_intent_policy_name', None) + self.source_network_intent_policy = kwargs.get('source_network_intent_policy', None) + + +class NetworkInterface(Resource): + """A network interface in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the network interface. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar virtual_machine: The reference to a virtual machine. + :vartype virtual_machine: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param network_security_group: The reference to the NetworkSecurityGroup resource. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :ivar private_endpoint: A reference to the private endpoint to which the network interface is + linked. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param ip_configurations: A list of IPConfigurations of the network interface. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar tap_configurations: A list of TapConfigurations of the network interface. + :vartype tap_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :param dns_settings: The DNS settings in network interface. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceDnsSettings + :ivar mac_address: The MAC address of the network interface. + :vartype mac_address: str + :ivar primary: Whether this is a primary network interface on a virtual machine. + :vartype primary: bool + :param enable_accelerated_networking: If the network interface is accelerated networking + enabled. + :type enable_accelerated_networking: bool + :param enable_ip_forwarding: Indicates whether IP forwarding is enabled on this network + interface. + :type enable_ip_forwarding: bool + :ivar hosted_workloads: A list of references to linked BareMetal resources. + :vartype hosted_workloads: list[str] + :ivar dscp_configuration: A reference to the dscp configuration to which the network interface + is linked. + :vartype dscp_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar resource_guid: The resource GUID property of the network interface resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network interface resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_machine': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'tap_configurations': {'readonly': True}, + 'mac_address': {'readonly': True}, + 'primary': {'readonly': True}, + 'hosted_workloads': {'readonly': True}, + 'dscp_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'virtual_machine': {'key': 'properties.virtualMachine', 'type': 'SubResource'}, + 'network_security_group': {'key': 'properties.networkSecurityGroup', 'type': 'NetworkSecurityGroup'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'tap_configurations': {'key': 'properties.tapConfigurations', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'NetworkInterfaceDnsSettings'}, + 'mac_address': {'key': 'properties.macAddress', 'type': 'str'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'enable_accelerated_networking': {'key': 'properties.enableAcceleratedNetworking', 'type': 'bool'}, + 'enable_ip_forwarding': {'key': 'properties.enableIPForwarding', 'type': 'bool'}, + 'hosted_workloads': {'key': 'properties.hostedWorkloads', 'type': '[str]'}, + 'dscp_configuration': {'key': 'properties.dscpConfiguration', 'type': 'SubResource'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterface, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.etag = None + self.virtual_machine = None + self.network_security_group = kwargs.get('network_security_group', None) + self.private_endpoint = None + self.ip_configurations = kwargs.get('ip_configurations', None) + self.tap_configurations = None + self.dns_settings = kwargs.get('dns_settings', None) + self.mac_address = None + self.primary = None + self.enable_accelerated_networking = kwargs.get('enable_accelerated_networking', None) + self.enable_ip_forwarding = kwargs.get('enable_ip_forwarding', None) + self.hosted_workloads = None + self.dscp_configuration = None + self.resource_guid = None + self.provisioning_state = None + + +class NetworkInterfaceAssociation(msrest.serialization.Model): + """Network interface and its custom security rules. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Network interface ID. + :vartype id: str + :param security_rules: Collection of custom security rules. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rules': {'key': 'securityRules', 'type': '[SecurityRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceAssociation, self).__init__(**kwargs) + self.id = None + self.security_rules = kwargs.get('security_rules', None) + + +class NetworkInterfaceDnsSettings(msrest.serialization.Model): + """DNS settings of a network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param dns_servers: List of DNS servers IP addresses. Use 'AzureProvidedDNS' to switch to azure + provided DNS resolution. 'AzureProvidedDNS' value cannot be combined with other IPs, it must be + the only value in dnsServers collection. + :type dns_servers: list[str] + :ivar applied_dns_servers: If the VM that uses this NIC is part of an Availability Set, then + this list will have the union of all DNS servers from all NICs that are part of the + Availability Set. This property is what is configured on each of those VMs. + :vartype applied_dns_servers: list[str] + :param internal_dns_name_label: Relative DNS name for this NIC used for internal communications + between VMs in the same virtual network. + :type internal_dns_name_label: str + :ivar internal_fqdn: Fully qualified DNS name supporting internal communications between VMs in + the same virtual network. + :vartype internal_fqdn: str + :ivar internal_domain_name_suffix: Even if internalDnsNameLabel is not specified, a DNS entry + is created for the primary NIC of the VM. This DNS name can be constructed by concatenating the + VM name with the value of internalDomainNameSuffix. + :vartype internal_domain_name_suffix: str + """ + + _validation = { + 'applied_dns_servers': {'readonly': True}, + 'internal_fqdn': {'readonly': True}, + 'internal_domain_name_suffix': {'readonly': True}, + } + + _attribute_map = { + 'dns_servers': {'key': 'dnsServers', 'type': '[str]'}, + 'applied_dns_servers': {'key': 'appliedDnsServers', 'type': '[str]'}, + 'internal_dns_name_label': {'key': 'internalDnsNameLabel', 'type': 'str'}, + 'internal_fqdn': {'key': 'internalFqdn', 'type': 'str'}, + 'internal_domain_name_suffix': {'key': 'internalDomainNameSuffix', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceDnsSettings, self).__init__(**kwargs) + self.dns_servers = kwargs.get('dns_servers', None) + self.applied_dns_servers = None + self.internal_dns_name_label = kwargs.get('internal_dns_name_label', None) + self.internal_fqdn = None + self.internal_domain_name_suffix = None + + +class NetworkInterfaceIPConfiguration(SubResource): + """IPConfiguration in a network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_network_taps: The reference to Virtual Network Taps. + :type virtual_network_taps: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :param application_gateway_backend_address_pools: The reference to + ApplicationGatewayBackendAddressPool resource. + :type application_gateway_backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool] + :param load_balancer_backend_address_pools: The reference to LoadBalancerBackendAddressPool + resource. + :type load_balancer_backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :param load_balancer_inbound_nat_rules: A list of references of LoadBalancerInboundNatRules. + :type load_balancer_inbound_nat_rules: + list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :param private_ip_address: Private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param private_ip_address_version: Whether the specific IP configuration is IPv4 or IPv6. + Default is IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param subnet: Subnet bound to the IP configuration. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param primary: Whether this is a primary customer address on the network interface. + :type primary: bool + :param public_ip_address: Public IP address bound to the IP configuration. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :param application_security_groups: Application security groups in which the IP configuration + is included. + :type application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :ivar provisioning_state: The provisioning state of the network interface IP configuration. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar private_link_connection_properties: PrivateLinkConnection properties for the network + interface. + :vartype private_link_connection_properties: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'private_link_connection_properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'virtual_network_taps': {'key': 'properties.virtualNetworkTaps', 'type': '[VirtualNetworkTap]'}, + 'application_gateway_backend_address_pools': {'key': 'properties.applicationGatewayBackendAddressPools', 'type': '[ApplicationGatewayBackendAddressPool]'}, + 'load_balancer_backend_address_pools': {'key': 'properties.loadBalancerBackendAddressPools', 'type': '[BackendAddressPool]'}, + 'load_balancer_inbound_nat_rules': {'key': 'properties.loadBalancerInboundNatRules', 'type': '[InboundNatRule]'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'application_security_groups': {'key': 'properties.applicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_connection_properties': {'key': 'properties.privateLinkConnectionProperties', 'type': 'NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.virtual_network_taps = kwargs.get('virtual_network_taps', None) + self.application_gateway_backend_address_pools = kwargs.get('application_gateway_backend_address_pools', None) + self.load_balancer_backend_address_pools = kwargs.get('load_balancer_backend_address_pools', None) + self.load_balancer_inbound_nat_rules = kwargs.get('load_balancer_inbound_nat_rules', None) + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.private_ip_address_version = kwargs.get('private_ip_address_version', None) + self.subnet = kwargs.get('subnet', None) + self.primary = kwargs.get('primary', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.application_security_groups = kwargs.get('application_security_groups', None) + self.provisioning_state = None + self.private_link_connection_properties = None + + +class NetworkInterfaceIPConfigurationListResult(msrest.serialization.Model): + """Response for list ip configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ip configurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceIPConfigurationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties(msrest.serialization.Model): + """PrivateLinkConnection properties for the network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: The group ID for current private link connection. + :vartype group_id: str + :ivar required_member_name: The required member name for current private link connection. + :vartype required_member_name: str + :ivar fqdns: List of FQDNs for current private link connection. + :vartype fqdns: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_member_name': {'readonly': True}, + 'fqdns': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_member_name': {'key': 'requiredMemberName', 'type': 'str'}, + 'fqdns': {'key': 'fqdns', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties, self).__init__(**kwargs) + self.group_id = None + self.required_member_name = None + self.fqdns = None + + +class NetworkInterfaceListResult(msrest.serialization.Model): + """Response for the ListNetworkInterface API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of network interfaces in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterface]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class NetworkInterfaceLoadBalancerListResult(msrest.serialization.Model): + """Response for list ip configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceLoadBalancerListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class NetworkInterfaceTapConfiguration(SubResource): + """Tap configuration in a Network Interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Sub Resource type. + :vartype type: str + :param virtual_network_tap: The reference to the Virtual Network Tap resource. + :type virtual_network_tap: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :ivar provisioning_state: The provisioning state of the network interface tap configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'virtual_network_tap': {'key': 'properties.virtualNetworkTap', 'type': 'VirtualNetworkTap'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceTapConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.virtual_network_tap = kwargs.get('virtual_network_tap', None) + self.provisioning_state = None + + +class NetworkInterfaceTapConfigurationListResult(msrest.serialization.Model): + """Response for list tap configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of tap configurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceTapConfigurationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class NetworkProfile(Resource): + """Network profile resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar container_network_interfaces: List of child container network interfaces. + :vartype container_network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterface] + :param container_network_interface_configurations: List of chid container network interface + configurations. + :type container_network_interface_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceConfiguration] + :ivar resource_guid: The resource GUID property of the network profile resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network profile resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'container_network_interfaces': {'readonly': True}, + 'resource_guid': {'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'}, + 'container_network_interfaces': {'key': 'properties.containerNetworkInterfaces', 'type': '[ContainerNetworkInterface]'}, + 'container_network_interface_configurations': {'key': 'properties.containerNetworkInterfaceConfigurations', 'type': '[ContainerNetworkInterfaceConfiguration]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkProfile, self).__init__(**kwargs) + self.etag = None + self.container_network_interfaces = None + self.container_network_interface_configurations = kwargs.get('container_network_interface_configurations', None) + self.resource_guid = None + self.provisioning_state = None + + +class NetworkProfileListResult(msrest.serialization.Model): + """Response for ListNetworkProfiles API service call. + + :param value: A list of network profiles that exist in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkProfile] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkProfile]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkProfileListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NetworkRule(FirewallPolicyRule): + """Rule of type network. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param ip_protocols: Array of FirewallPolicyRuleNetworkProtocols. + :type ip_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleNetworkProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + :param destination_fqdns: List of destination FQDNs. + :type destination_fqdns: list[str] + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'ip_protocols': {'key': 'ipProtocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + 'destination_fqdns': {'key': 'destinationFqdns', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkRule, self).__init__(**kwargs) + self.rule_type = 'NetworkRule' # type: str + self.ip_protocols = kwargs.get('ip_protocols', None) + self.source_addresses = kwargs.get('source_addresses', None) + self.destination_addresses = kwargs.get('destination_addresses', None) + self.destination_ports = kwargs.get('destination_ports', None) + self.source_ip_groups = kwargs.get('source_ip_groups', None) + self.destination_ip_groups = kwargs.get('destination_ip_groups', None) + self.destination_fqdns = kwargs.get('destination_fqdns', None) + + +class NetworkSecurityGroup(Resource): + """NetworkSecurityGroup resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param security_rules: A collection of security rules of the network security group. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :ivar default_security_rules: The default security rules of network security group. + :vartype default_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :ivar network_interfaces: A collection of references to network interfaces. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :ivar flow_logs: A collection of references to flow log resources. + :vartype flow_logs: list[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :ivar resource_guid: The resource GUID property of the network security group resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network security group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'default_security_rules': {'readonly': True}, + 'network_interfaces': {'readonly': True}, + 'subnets': {'readonly': True}, + 'flow_logs': {'readonly': True}, + 'resource_guid': {'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'}, + 'security_rules': {'key': 'properties.securityRules', 'type': '[SecurityRule]'}, + 'default_security_rules': {'key': 'properties.defaultSecurityRules', 'type': '[SecurityRule]'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'flow_logs': {'key': 'properties.flowLogs', 'type': '[FlowLog]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkSecurityGroup, self).__init__(**kwargs) + self.etag = None + self.security_rules = kwargs.get('security_rules', None) + self.default_security_rules = None + self.network_interfaces = None + self.subnets = None + self.flow_logs = None + self.resource_guid = None + self.provisioning_state = None + + +class NetworkSecurityGroupListResult(msrest.serialization.Model): + """Response for ListNetworkSecurityGroups API service call. + + :param value: A list of NetworkSecurityGroup resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkSecurityGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NetworkSecurityGroupResult(msrest.serialization.Model): + """Network configuration diagnostic result corresponded provided traffic query. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param security_rule_access_result: The network traffic is allowed or denied. Possible values + include: "Allow", "Deny". + :type security_rule_access_result: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :ivar evaluated_network_security_groups: List of results network security groups diagnostic. + :vartype evaluated_network_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.EvaluatedNetworkSecurityGroup] + """ + + _validation = { + 'evaluated_network_security_groups': {'readonly': True}, + } + + _attribute_map = { + 'security_rule_access_result': {'key': 'securityRuleAccessResult', 'type': 'str'}, + 'evaluated_network_security_groups': {'key': 'evaluatedNetworkSecurityGroups', 'type': '[EvaluatedNetworkSecurityGroup]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkSecurityGroupResult, self).__init__(**kwargs) + self.security_rule_access_result = kwargs.get('security_rule_access_result', None) + self.evaluated_network_security_groups = None + + +class NetworkSecurityRulesEvaluationResult(msrest.serialization.Model): + """Network security rules evaluation result. + + :param name: Name of the network security rule. + :type name: str + :param protocol_matched: Value indicating whether protocol is matched. + :type protocol_matched: bool + :param source_matched: Value indicating whether source is matched. + :type source_matched: bool + :param source_port_matched: Value indicating whether source port is matched. + :type source_port_matched: bool + :param destination_matched: Value indicating whether destination is matched. + :type destination_matched: bool + :param destination_port_matched: Value indicating whether destination port is matched. + :type destination_port_matched: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'protocol_matched': {'key': 'protocolMatched', 'type': 'bool'}, + 'source_matched': {'key': 'sourceMatched', 'type': 'bool'}, + 'source_port_matched': {'key': 'sourcePortMatched', 'type': 'bool'}, + 'destination_matched': {'key': 'destinationMatched', 'type': 'bool'}, + 'destination_port_matched': {'key': 'destinationPortMatched', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkSecurityRulesEvaluationResult, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.protocol_matched = kwargs.get('protocol_matched', None) + self.source_matched = kwargs.get('source_matched', None) + self.source_port_matched = kwargs.get('source_port_matched', None) + self.destination_matched = kwargs.get('destination_matched', None) + self.destination_port_matched = kwargs.get('destination_port_matched', None) + + +class NetworkVirtualAppliance(Resource): + """NetworkVirtualAppliance Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 identity: The service principal that has read access to cloud-init and config blob. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param nva_sku: Network Virtual Appliance SKU. + :type nva_sku: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSkuProperties + :ivar address_prefix: Address Prefix. + :vartype address_prefix: str + :param boot_strap_configuration_blobs: BootStrapConfigurationBlobs storage URLs. + :type boot_strap_configuration_blobs: list[str] + :param virtual_hub: The Virtual Hub where Network Virtual Appliance is being deployed. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param cloud_init_configuration_blobs: CloudInitConfigurationBlob storage URLs. + :type cloud_init_configuration_blobs: list[str] + :param cloud_init_configuration: CloudInitConfiguration string in plain text. + :type cloud_init_configuration: str + :param virtual_appliance_asn: VirtualAppliance ASN. + :type virtual_appliance_asn: long + :ivar virtual_appliance_nics: List of Virtual Appliance Network Interfaces. + :vartype virtual_appliance_nics: + list[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceNicProperties] + :ivar virtual_appliance_sites: List of references to VirtualApplianceSite. + :vartype virtual_appliance_sites: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar inbound_security_rules: List of references to InboundSecurityRules. + :vartype inbound_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'address_prefix': {'readonly': True}, + 'virtual_appliance_asn': {'maximum': 4294967295, 'minimum': 0}, + 'virtual_appliance_nics': {'readonly': True}, + 'virtual_appliance_sites': {'readonly': True}, + 'inbound_security_rules': {'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}'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'nva_sku': {'key': 'properties.nvaSku', 'type': 'VirtualApplianceSkuProperties'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'boot_strap_configuration_blobs': {'key': 'properties.bootStrapConfigurationBlobs', 'type': '[str]'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'cloud_init_configuration_blobs': {'key': 'properties.cloudInitConfigurationBlobs', 'type': '[str]'}, + 'cloud_init_configuration': {'key': 'properties.cloudInitConfiguration', 'type': 'str'}, + 'virtual_appliance_asn': {'key': 'properties.virtualApplianceAsn', 'type': 'long'}, + 'virtual_appliance_nics': {'key': 'properties.virtualApplianceNics', 'type': '[VirtualApplianceNicProperties]'}, + 'virtual_appliance_sites': {'key': 'properties.virtualApplianceSites', 'type': '[SubResource]'}, + 'inbound_security_rules': {'key': 'properties.inboundSecurityRules', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualAppliance, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.etag = None + self.nva_sku = kwargs.get('nva_sku', None) + self.address_prefix = None + self.boot_strap_configuration_blobs = kwargs.get('boot_strap_configuration_blobs', None) + self.virtual_hub = kwargs.get('virtual_hub', None) + self.cloud_init_configuration_blobs = kwargs.get('cloud_init_configuration_blobs', None) + self.cloud_init_configuration = kwargs.get('cloud_init_configuration', None) + self.virtual_appliance_asn = kwargs.get('virtual_appliance_asn', None) + self.virtual_appliance_nics = None + self.virtual_appliance_sites = None + self.inbound_security_rules = None + self.provisioning_state = None + + +class NetworkVirtualApplianceListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualAppliances API service call. + + :param value: List of Network Virtual Appliances. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkVirtualAppliance]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NetworkVirtualApplianceSiteListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualApplianceSites API service call. + + :param value: List of Network Virtual Appliance sites. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualApplianceSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceSiteListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NetworkVirtualApplianceSku(Resource): + """Definition of the NetworkVirtualApplianceSkus resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar vendor: Network Virtual Appliance Sku vendor. + :vartype vendor: str + :ivar available_versions: Available Network Virtual Appliance versions. + :vartype available_versions: list[str] + :param available_scale_units: The list of scale units available. + :type available_scale_units: + list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSkuInstances] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'vendor': {'readonly': True}, + 'available_versions': {'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'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'available_versions': {'key': 'properties.availableVersions', 'type': '[str]'}, + 'available_scale_units': {'key': 'properties.availableScaleUnits', 'type': '[NetworkVirtualApplianceSkuInstances]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceSku, self).__init__(**kwargs) + self.etag = None + self.vendor = None + self.available_versions = None + self.available_scale_units = kwargs.get('available_scale_units', None) + + +class NetworkVirtualApplianceSkuInstances(msrest.serialization.Model): + """List of available Sku and instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar scale_unit: Scale Unit. + :vartype scale_unit: str + :ivar instance_count: Instance Count. + :vartype instance_count: int + """ + + _validation = { + 'scale_unit': {'readonly': True}, + 'instance_count': {'readonly': True}, + } + + _attribute_map = { + 'scale_unit': {'key': 'scaleUnit', 'type': 'str'}, + 'instance_count': {'key': 'instanceCount', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceSkuInstances, self).__init__(**kwargs) + self.scale_unit = None + self.instance_count = None + + +class NetworkVirtualApplianceSkuListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualApplianceSkus API service call. + + :param value: List of Network Virtual Appliance Skus that are available. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSku] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkVirtualApplianceSku]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceSkuListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NetworkWatcher(Resource): + """Network watcher in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the network watcher resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkWatcher, self).__init__(**kwargs) + self.etag = None + self.provisioning_state = None + + +class NetworkWatcherListResult(msrest.serialization.Model): + """Response for ListNetworkWatchers API service call. + + :param value: List of network watcher resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkWatcher] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkWatcher]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkWatcherListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class NextHopParameters(msrest.serialization.Model): + """Parameters that define the source and destination endpoint. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The resource identifier of the target resource against + which the action is to be performed. + :type target_resource_id: str + :param source_ip_address: Required. The source IP address. + :type source_ip_address: str + :param destination_ip_address: Required. The destination IP address. + :type destination_ip_address: str + :param target_nic_resource_id: The NIC ID. (If VM has multiple NICs and IP forwarding is + enabled on any of the nics, then this parameter must be specified. Otherwise optional). + :type target_nic_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'source_ip_address': {'required': True}, + 'destination_ip_address': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'source_ip_address': {'key': 'sourceIPAddress', 'type': 'str'}, + 'destination_ip_address': {'key': 'destinationIPAddress', 'type': 'str'}, + 'target_nic_resource_id': {'key': 'targetNicResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NextHopParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + self.source_ip_address = kwargs['source_ip_address'] + self.destination_ip_address = kwargs['destination_ip_address'] + self.target_nic_resource_id = kwargs.get('target_nic_resource_id', None) + + +class NextHopResult(msrest.serialization.Model): + """The information about next hop from the specified VM. + + :param next_hop_type: Next hop type. Possible values include: "Internet", "VirtualAppliance", + "VirtualNetworkGateway", "VnetLocal", "HyperNetGateway", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.NextHopType + :param next_hop_ip_address: Next hop IP Address. + :type next_hop_ip_address: str + :param route_table_id: The resource identifier for the route table associated with the route + being returned. If the route being returned does not correspond to any user created routes then + this field will be the string 'System Route'. + :type route_table_id: str + """ + + _attribute_map = { + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + 'route_table_id': {'key': 'routeTableId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NextHopResult, self).__init__(**kwargs) + self.next_hop_type = kwargs.get('next_hop_type', None) + self.next_hop_ip_address = kwargs.get('next_hop_ip_address', None) + self.route_table_id = kwargs.get('route_table_id', None) + + +class O365BreakOutCategoryPolicies(msrest.serialization.Model): + """Office365 breakout categories. + + :param allow: Flag to control allow category. + :type allow: bool + :param optimize: Flag to control optimize category. + :type optimize: bool + :param default: Flag to control default category. + :type default: bool + """ + + _attribute_map = { + 'allow': {'key': 'allow', 'type': 'bool'}, + 'optimize': {'key': 'optimize', 'type': 'bool'}, + 'default': {'key': 'default', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(O365BreakOutCategoryPolicies, self).__init__(**kwargs) + self.allow = kwargs.get('allow', None) + self.optimize = kwargs.get('optimize', None) + self.default = kwargs.get('default', None) + + +class O365PolicyProperties(msrest.serialization.Model): + """The Office365 breakout policy. + + :param break_out_categories: Office365 breakout categories. + :type break_out_categories: ~azure.mgmt.network.v2020_08_01.models.O365BreakOutCategoryPolicies + """ + + _attribute_map = { + 'break_out_categories': {'key': 'breakOutCategories', 'type': 'O365BreakOutCategoryPolicies'}, + } + + def __init__( + self, + **kwargs + ): + super(O365PolicyProperties, self).__init__(**kwargs) + self.break_out_categories = kwargs.get('break_out_categories', None) + + +class Office365PolicyProperties(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param break_out_categories: Office 365 breakout categories. + :type break_out_categories: ~azure.mgmt.network.v2020_08_01.models.BreakOutCategoryPolicies + """ + + _attribute_map = { + 'break_out_categories': {'key': 'breakOutCategories', 'type': 'BreakOutCategoryPolicies'}, + } + + def __init__( + self, + **kwargs + ): + super(Office365PolicyProperties, self).__init__(**kwargs) + self.break_out_categories = kwargs.get('break_out_categories', None) + + +class Operation(msrest.serialization.Model): + """Network REST API operation definition. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: Display metadata associated with the operation. + :type display: ~azure.mgmt.network.v2020_08_01.models.OperationDisplay + :param origin: Origin of the operation. + :type origin: str + :param service_specification: Specification of the service. + :type service_specification: + ~azure.mgmt.network.v2020_08_01.models.OperationPropertiesFormatServiceSpecification + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'service_specification': {'key': 'properties.serviceSpecification', 'type': 'OperationPropertiesFormatServiceSpecification'}, + } + + def __init__( + self, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + self.origin = kwargs.get('origin', None) + self.service_specification = kwargs.get('service_specification', None) + + +class OperationDisplay(msrest.serialization.Model): + """Display metadata associated with the operation. + + :param provider: Service provider: Microsoft Network. + :type provider: str + :param resource: Resource on which the operation is performed. + :type resource: str + :param operation: Type of the operation: get, read, 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 Network operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Network operations supported by the Network resource provider. + :type value: list[~azure.mgmt.network.v2020_08_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 OperationPropertiesFormatServiceSpecification(msrest.serialization.Model): + """Specification of the service. + + :param metric_specifications: Operation service specification. + :type metric_specifications: list[~azure.mgmt.network.v2020_08_01.models.MetricSpecification] + :param log_specifications: Operation log specification. + :type log_specifications: list[~azure.mgmt.network.v2020_08_01.models.LogSpecification] + """ + + _attribute_map = { + 'metric_specifications': {'key': 'metricSpecifications', 'type': '[MetricSpecification]'}, + 'log_specifications': {'key': 'logSpecifications', 'type': '[LogSpecification]'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationPropertiesFormatServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = kwargs.get('metric_specifications', None) + self.log_specifications = kwargs.get('log_specifications', None) + + +class OutboundRule(SubResource): + """Outbound rule of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of outbound rules used by + the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param allocated_outbound_ports: The number of outbound ports to be used for NAT. + :type allocated_outbound_ports: int + :param frontend_ip_configurations: The Frontend IP addresses of the load balancer. + :type frontend_ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param backend_address_pool: A reference to a pool of DIPs. Outbound traffic is randomly load + balanced across IPs in the backend IPs. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the outbound rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param protocol: The protocol for the outbound rule in load balancer. Possible values include: + "Tcp", "Udp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerOutboundRuleProtocol + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. + :type idle_timeout_in_minutes: int + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allocated_outbound_ports': {'key': 'properties.allocatedOutboundPorts', 'type': 'int'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[SubResource]'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(OutboundRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.allocated_outbound_ports = kwargs.get('allocated_outbound_ports', None) + self.frontend_ip_configurations = kwargs.get('frontend_ip_configurations', None) + self.backend_address_pool = kwargs.get('backend_address_pool', None) + self.provisioning_state = None + self.protocol = kwargs.get('protocol', None) + self.enable_tcp_reset = kwargs.get('enable_tcp_reset', None) + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + + +class OwaspCrsExclusionEntry(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param match_variable: Required. The variable to be excluded. Possible values include: + "RequestHeaderNames", "RequestCookieNames", "RequestArgNames". + :type match_variable: str or + ~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntryMatchVariable + :param selector_match_operator: Required. When matchVariable is a collection, operate on the + selector to specify which elements in the collection this exclusion applies to. Possible values + include: "Equals", "Contains", "StartsWith", "EndsWith", "EqualsAny". + :type selector_match_operator: str or + ~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntrySelectorMatchOperator + :param selector: Required. When matchVariable is a collection, operator used to specify which + elements in the collection this exclusion applies to. + :type selector: str + """ + + _validation = { + 'match_variable': {'required': True}, + 'selector_match_operator': {'required': True}, + 'selector': {'required': True}, + } + + _attribute_map = { + 'match_variable': {'key': 'matchVariable', 'type': 'str'}, + 'selector_match_operator': {'key': 'selectorMatchOperator', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OwaspCrsExclusionEntry, self).__init__(**kwargs) + self.match_variable = kwargs['match_variable'] + self.selector_match_operator = kwargs['selector_match_operator'] + self.selector = kwargs['selector'] + + +class P2SConnectionConfiguration(SubResource): + """P2SConnectionConfiguration Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param vpn_client_address_pool: The reference to the address space resource which represents + Address space for P2S VpnClient. + :type vpn_client_address_pool: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + :param enable_internet_security: Flag indicating whether the enable internet security flag is + turned on for the P2S Connections or not. + :type enable_internet_security: bool + :ivar provisioning_state: The provisioning state of the P2SConnectionConfiguration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'vpn_client_address_pool': {'key': 'properties.vpnClientAddressPool', 'type': 'AddressSpace'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SConnectionConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.vpn_client_address_pool = kwargs.get('vpn_client_address_pool', None) + self.routing_configuration = kwargs.get('routing_configuration', None) + self.enable_internet_security = kwargs.get('enable_internet_security', None) + self.provisioning_state = None + + +class P2SVpnConnectionHealth(msrest.serialization.Model): + """P2S Vpn connection detailed health written to sas url. + + :param sas_url: Returned sas url of the blob to which the p2s vpn connection detailed health + will be written. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SVpnConnectionHealth, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + + +class P2SVpnConnectionHealthRequest(msrest.serialization.Model): + """List of P2S Vpn connection health request. + + :param vpn_user_names_filter: The list of p2s vpn user names whose p2s vpn connection detailed + health to retrieve for. + :type vpn_user_names_filter: list[str] + :param output_blob_sas_url: The sas-url to download the P2S Vpn connection health detail. + :type output_blob_sas_url: str + """ + + _attribute_map = { + 'vpn_user_names_filter': {'key': 'vpnUserNamesFilter', 'type': '[str]'}, + 'output_blob_sas_url': {'key': 'outputBlobSasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SVpnConnectionHealthRequest, self).__init__(**kwargs) + self.vpn_user_names_filter = kwargs.get('vpn_user_names_filter', None) + self.output_blob_sas_url = kwargs.get('output_blob_sas_url', None) + + +class P2SVpnConnectionRequest(msrest.serialization.Model): + """List of p2s vpn connections to be disconnected. + + :param vpn_connection_ids: List of p2s vpn connection Ids. + :type vpn_connection_ids: list[str] + """ + + _attribute_map = { + 'vpn_connection_ids': {'key': 'vpnConnectionIds', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SVpnConnectionRequest, self).__init__(**kwargs) + self.vpn_connection_ids = kwargs.get('vpn_connection_ids', None) + + +class P2SVpnGateway(Resource): + """P2SVpnGateway Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_hub: The VirtualHub to which the gateway belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param p2_s_connection_configurations: List of all p2s connection configurations of the + gateway. + :type p2_s_connection_configurations: + list[~azure.mgmt.network.v2020_08_01.models.P2SConnectionConfiguration] + :ivar provisioning_state: The provisioning state of the P2S VPN gateway resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_gateway_scale_unit: The scale unit for this p2s vpn gateway. + :type vpn_gateway_scale_unit: int + :param vpn_server_configuration: The VpnServerConfiguration to which the p2sVpnGateway is + attached to. + :type vpn_server_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar vpn_client_connection_health: All P2S VPN clients' connection health status. + :vartype vpn_client_connection_health: + ~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealth + :param custom_dns_servers: List of all customer specified DNS servers IP addresses. + :type custom_dns_servers: list[str] + :param is_routing_preference_internet: Enable Routing Preference property for the Public IP + Interface of the P2SVpnGateway. + :type is_routing_preference_internet: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'vpn_client_connection_health': {'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'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'p2_s_connection_configurations': {'key': 'properties.p2SConnectionConfigurations', 'type': '[P2SConnectionConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_gateway_scale_unit': {'key': 'properties.vpnGatewayScaleUnit', 'type': 'int'}, + 'vpn_server_configuration': {'key': 'properties.vpnServerConfiguration', 'type': 'SubResource'}, + 'vpn_client_connection_health': {'key': 'properties.vpnClientConnectionHealth', 'type': 'VpnClientConnectionHealth'}, + 'custom_dns_servers': {'key': 'properties.customDnsServers', 'type': '[str]'}, + 'is_routing_preference_internet': {'key': 'properties.isRoutingPreferenceInternet', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SVpnGateway, self).__init__(**kwargs) + self.etag = None + self.virtual_hub = kwargs.get('virtual_hub', None) + self.p2_s_connection_configurations = kwargs.get('p2_s_connection_configurations', None) + self.provisioning_state = None + self.vpn_gateway_scale_unit = kwargs.get('vpn_gateway_scale_unit', None) + self.vpn_server_configuration = kwargs.get('vpn_server_configuration', None) + self.vpn_client_connection_health = None + self.custom_dns_servers = kwargs.get('custom_dns_servers', None) + self.is_routing_preference_internet = kwargs.get('is_routing_preference_internet', None) + + +class P2SVpnProfileParameters(msrest.serialization.Model): + """Vpn Client Parameters for package generation. + + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + """ + + _attribute_map = { + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(P2SVpnProfileParameters, self).__init__(**kwargs) + self.authentication_method = kwargs.get('authentication_method', None) + + +class PacketCapture(msrest.serialization.Model): + """Parameters that define the create packet capture operation. + + All required parameters must be populated in order to send to Azure. + + :param target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + } + + _attribute_map = { + 'target': {'key': 'properties.target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'properties.bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'properties.totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'properties.timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'properties.storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'properties.filters', 'type': '[PacketCaptureFilter]'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCapture, self).__init__(**kwargs) + self.target = kwargs['target'] + self.bytes_to_capture_per_packet = kwargs.get('bytes_to_capture_per_packet', 0) + self.total_bytes_per_session = kwargs.get('total_bytes_per_session', 1073741824) + self.time_limit_in_seconds = kwargs.get('time_limit_in_seconds', 18000) + self.storage_location = kwargs['storage_location'] + self.filters = kwargs.get('filters', None) + + +class PacketCaptureFilter(msrest.serialization.Model): + """Filter that is applied to packet capture request. Multiple filters can be applied. + + :param protocol: Protocol to be filtered on. Possible values include: "TCP", "UDP", "Any". + Default value: "Any". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.PcProtocol + :param local_ip_address: Local IP Address to be filtered on. Notation: "127.0.0.1" for single + address entry. "127.0.0.1-127.0.0.255" for range. "127.0.0.1;127.0.0.5"? for multiple entries. + Multiple ranges not currently supported. Mixing ranges with multiple entries not currently + supported. Default = null. + :type local_ip_address: str + :param remote_ip_address: Local IP Address to be filtered on. Notation: "127.0.0.1" for single + address entry. "127.0.0.1-127.0.0.255" for range. "127.0.0.1;127.0.0.5;" for multiple entries. + Multiple ranges not currently supported. Mixing ranges with multiple entries not currently + supported. Default = null. + :type remote_ip_address: str + :param local_port: Local port to be filtered on. Notation: "80" for single port entry."80-85" + for range. "80;443;" for multiple entries. Multiple ranges not currently supported. Mixing + ranges with multiple entries not currently supported. Default = null. + :type local_port: str + :param remote_port: Remote port to be filtered on. Notation: "80" for single port entry."80-85" + for range. "80;443;" for multiple entries. Multiple ranges not currently supported. Mixing + ranges with multiple entries not currently supported. Default = null. + :type remote_port: str + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'local_ip_address': {'key': 'localIPAddress', 'type': 'str'}, + 'remote_ip_address': {'key': 'remoteIPAddress', 'type': 'str'}, + 'local_port': {'key': 'localPort', 'type': 'str'}, + 'remote_port': {'key': 'remotePort', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureFilter, self).__init__(**kwargs) + self.protocol = kwargs.get('protocol', "Any") + self.local_ip_address = kwargs.get('local_ip_address', None) + self.remote_ip_address = kwargs.get('remote_ip_address', None) + self.local_port = kwargs.get('local_port', None) + self.remote_port = kwargs.get('remote_port', None) + + +class PacketCaptureListResult(msrest.serialization.Model): + """List of packet capture sessions. + + :param value: Information about packet capture sessions. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PacketCaptureResult]'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class PacketCaptureParameters(msrest.serialization.Model): + """Parameters that define the create packet capture operation. + + All required parameters must be populated in order to send to Azure. + + :param target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + } + + _attribute_map = { + 'target': {'key': 'target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'filters', 'type': '[PacketCaptureFilter]'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureParameters, self).__init__(**kwargs) + self.target = kwargs['target'] + self.bytes_to_capture_per_packet = kwargs.get('bytes_to_capture_per_packet', 0) + self.total_bytes_per_session = kwargs.get('total_bytes_per_session', 1073741824) + self.time_limit_in_seconds = kwargs.get('time_limit_in_seconds', 18000) + self.storage_location = kwargs['storage_location'] + self.filters = kwargs.get('filters', None) + + +class PacketCaptureQueryStatusResult(msrest.serialization.Model): + """Status of packet capture session. + + :param name: The name of the packet capture resource. + :type name: str + :param id: The ID of the packet capture resource. + :type id: str + :param capture_start_time: The start time of the packet capture session. + :type capture_start_time: ~datetime.datetime + :param packet_capture_status: The status of the packet capture session. Possible values + include: "NotStarted", "Running", "Stopped", "Error", "Unknown". + :type packet_capture_status: str or ~azure.mgmt.network.v2020_08_01.models.PcStatus + :param stop_reason: The reason the current packet capture session was stopped. + :type stop_reason: str + :param packet_capture_error: List of errors of packet capture session. + :type packet_capture_error: list[str or ~azure.mgmt.network.v2020_08_01.models.PcError] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'capture_start_time': {'key': 'captureStartTime', 'type': 'iso-8601'}, + 'packet_capture_status': {'key': 'packetCaptureStatus', 'type': 'str'}, + 'stop_reason': {'key': 'stopReason', 'type': 'str'}, + 'packet_capture_error': {'key': 'packetCaptureError', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureQueryStatusResult, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.capture_start_time = kwargs.get('capture_start_time', None) + self.packet_capture_status = kwargs.get('packet_capture_status', None) + self.stop_reason = kwargs.get('stop_reason', None) + self.packet_capture_error = kwargs.get('packet_capture_error', None) + + +class PacketCaptureResult(msrest.serialization.Model): + """Information about packet capture session. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: Name of the packet capture session. + :vartype name: str + :ivar id: ID of the packet capture operation. + :vartype id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param target: The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + :ivar provisioning_state: The provisioning state of the packet capture session. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'etag': {'readonly': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'target': {'key': 'properties.target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'properties.bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'properties.totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'properties.timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'properties.storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'properties.filters', 'type': '[PacketCaptureFilter]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.etag = None + self.target = kwargs.get('target', None) + self.bytes_to_capture_per_packet = kwargs.get('bytes_to_capture_per_packet', 0) + self.total_bytes_per_session = kwargs.get('total_bytes_per_session', 1073741824) + self.time_limit_in_seconds = kwargs.get('time_limit_in_seconds', 18000) + self.storage_location = kwargs.get('storage_location', None) + self.filters = kwargs.get('filters', None) + self.provisioning_state = None + + +class PacketCaptureResultProperties(PacketCaptureParameters): + """The properties of a packet capture session. + + Variables are only 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 target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + :ivar provisioning_state: The provisioning state of the packet capture session. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'target': {'key': 'target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'filters', 'type': '[PacketCaptureFilter]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureResultProperties, self).__init__(**kwargs) + self.provisioning_state = None + + +class PacketCaptureStorageLocation(msrest.serialization.Model): + """The storage location for a packet capture session. + + :param storage_id: The ID of the storage account to save the packet capture session. Required + if no local file path is provided. + :type storage_id: str + :param storage_path: The URI of the storage path to save the packet capture. Must be a well- + formed URI describing the location to save the packet capture. + :type storage_path: str + :param file_path: A valid local path on the targeting VM. Must include the name of the capture + file (*.cap). For linux virtual machine it must start with /var/captures. Required if no + storage ID is provided, otherwise optional. + :type file_path: str + """ + + _attribute_map = { + 'storage_id': {'key': 'storageId', 'type': 'str'}, + 'storage_path': {'key': 'storagePath', 'type': 'str'}, + 'file_path': {'key': 'filePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PacketCaptureStorageLocation, self).__init__(**kwargs) + self.storage_id = kwargs.get('storage_id', None) + self.storage_path = kwargs.get('storage_path', None) + self.file_path = kwargs.get('file_path', None) + + +class PatchRouteFilter(SubResource): + """Route Filter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :vartype name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param rules: Collection of RouteFilterRules contained within a route filter. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :ivar peerings: A collection of references to express route circuit peerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar ipv6_peerings: A collection of references to express route circuit ipv6 peerings. + :vartype ipv6_peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar provisioning_state: The provisioning state of the route filter resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peerings': {'readonly': True}, + 'ipv6_peerings': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'rules': {'key': 'properties.rules', 'type': '[RouteFilterRule]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'ipv6_peerings': {'key': 'properties.ipv6Peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PatchRouteFilter, self).__init__(**kwargs) + self.name = None + self.etag = None + self.type = None + self.tags = kwargs.get('tags', None) + self.rules = kwargs.get('rules', None) + self.peerings = None + self.ipv6_peerings = None + self.provisioning_state = None + + +class PatchRouteFilterRule(SubResource): + """Route Filter Rule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :vartype name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param access: The access type of the rule. Possible values include: "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param route_filter_rule_type: The rule type of the rule. Possible values include: "Community". + :type route_filter_rule_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleType + :param communities: The collection for bgp community values to filter on. e.g. + ['12076:5010','12076:5020']. + :type communities: list[str] + :ivar provisioning_state: The provisioning state of the route filter rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'route_filter_rule_type': {'key': 'properties.routeFilterRuleType', 'type': 'str'}, + 'communities': {'key': 'properties.communities', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PatchRouteFilterRule, self).__init__(**kwargs) + self.name = None + self.etag = None + self.access = kwargs.get('access', None) + self.route_filter_rule_type = kwargs.get('route_filter_rule_type', None) + self.communities = kwargs.get('communities', None) + self.provisioning_state = None + + +class PeerExpressRouteCircuitConnection(SubResource): + """Peer Express Route Circuit Connection in an ExpressRouteCircuitPeering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the circuit. + :type express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param peer_express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the peered circuit. + :type peer_express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: /29 IP address space to carve out Customer addresses for tunnels. + :type address_prefix: str + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + :param connection_name: The name of the express route circuit connection resource. + :type connection_name: str + :param auth_resource_guid: The resource guid of the authorization used for the express route + circuit connection. + :type auth_resource_guid: str + :ivar provisioning_state: The provisioning state of the peer express route circuit connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'circuit_connection_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'SubResource'}, + 'peer_express_route_circuit_peering': {'key': 'properties.peerExpressRouteCircuitPeering', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'circuit_connection_status': {'key': 'properties.circuitConnectionStatus', 'type': 'str'}, + 'connection_name': {'key': 'properties.connectionName', 'type': 'str'}, + 'auth_resource_guid': {'key': 'properties.authResourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PeerExpressRouteCircuitConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.express_route_circuit_peering = kwargs.get('express_route_circuit_peering', None) + self.peer_express_route_circuit_peering = kwargs.get('peer_express_route_circuit_peering', None) + self.address_prefix = kwargs.get('address_prefix', None) + self.circuit_connection_status = None + self.connection_name = kwargs.get('connection_name', None) + self.auth_resource_guid = kwargs.get('auth_resource_guid', None) + self.provisioning_state = None + + +class PeerExpressRouteCircuitConnectionListResult(msrest.serialization.Model): + """Response for ListPeeredConnections API service call retrieves all global reach peer circuit connections that belongs to a Private Peering for an ExpressRouteCircuit. + + :param value: The global reach peer circuit connection associated with Private Peering in an + ExpressRoute Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PeerExpressRouteCircuitConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PeerExpressRouteCircuitConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class PeerRoute(msrest.serialization.Model): + """Peer routing details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The peer's local address. + :vartype local_address: str + :ivar network: The route's network prefix. + :vartype network: str + :ivar next_hop: The route's next hop. + :vartype next_hop: str + :ivar source_peer: The peer this route was learned from. + :vartype source_peer: str + :ivar origin: The source this route was learned from. + :vartype origin: str + :ivar as_path: The route's AS path sequence. + :vartype as_path: str + :ivar weight: The route's weight. + :vartype weight: int + """ + + _validation = { + 'local_address': {'readonly': True}, + 'network': {'readonly': True}, + 'next_hop': {'readonly': True}, + 'source_peer': {'readonly': True}, + 'origin': {'readonly': True}, + 'as_path': {'readonly': True}, + 'weight': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'source_peer': {'key': 'sourcePeer', 'type': 'str'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PeerRoute, self).__init__(**kwargs) + self.local_address = None + self.network = None + self.next_hop = None + self.source_peer = None + self.origin = None + self.as_path = None + self.weight = None + + +class PeerRouteList(msrest.serialization.Model): + """List of virtual router peer routes. + + :param value: List of peer routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PeerRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PeerRoute]'}, + } + + def __init__( + self, + **kwargs + ): + super(PeerRouteList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class PolicySettings(msrest.serialization.Model): + """Defines contents of a web application firewall global configuration. + + :param state: The state of the policy. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallEnabledState + :param mode: The mode of the policy. Possible values include: "Prevention", "Detection". + :type mode: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallMode + :param request_body_check: Whether to allow WAF to check request Body. + :type request_body_check: bool + :param max_request_body_size_in_kb: Maximum request body size in Kb for WAF. + :type max_request_body_size_in_kb: int + :param file_upload_limit_in_mb: Maximum file upload size in Mb for WAF. + :type file_upload_limit_in_mb: int + """ + + _validation = { + 'max_request_body_size_in_kb': {'maximum': 128, 'minimum': 8}, + 'file_upload_limit_in_mb': {'minimum': 0}, + } + + _attribute_map = { + 'state': {'key': 'state', 'type': 'str'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'request_body_check': {'key': 'requestBodyCheck', 'type': 'bool'}, + 'max_request_body_size_in_kb': {'key': 'maxRequestBodySizeInKb', 'type': 'int'}, + 'file_upload_limit_in_mb': {'key': 'fileUploadLimitInMb', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicySettings, self).__init__(**kwargs) + self.state = kwargs.get('state', None) + self.mode = kwargs.get('mode', None) + self.request_body_check = kwargs.get('request_body_check', None) + self.max_request_body_size_in_kb = kwargs.get('max_request_body_size_in_kb', None) + self.file_upload_limit_in_mb = kwargs.get('file_upload_limit_in_mb', None) + + +class PrepareNetworkPoliciesRequest(msrest.serialization.Model): + """Details of PrepareNetworkPolicies for Subnet. + + :param service_name: The name of the service for which subnet is being prepared for. + :type service_name: str + :param network_intent_policy_configurations: A list of NetworkIntentPolicyConfiguration. + :type network_intent_policy_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkIntentPolicyConfiguration] + """ + + _attribute_map = { + 'service_name': {'key': 'serviceName', 'type': 'str'}, + 'network_intent_policy_configurations': {'key': 'networkIntentPolicyConfigurations', 'type': '[NetworkIntentPolicyConfiguration]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrepareNetworkPoliciesRequest, self).__init__(**kwargs) + self.service_name = kwargs.get('service_name', None) + self.network_intent_policy_configurations = kwargs.get('network_intent_policy_configurations', None) + + +class PrivateDnsZoneConfig(msrest.serialization.Model): + """PrivateDnsZoneConfig resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :param private_dns_zone_id: The resource id of the private dns zone. + :type private_dns_zone_id: str + :ivar record_sets: A collection of information regarding a recordSet, holding information to + identify private resources. + :vartype record_sets: list[~azure.mgmt.network.v2020_08_01.models.RecordSet] + """ + + _validation = { + 'record_sets': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'private_dns_zone_id': {'key': 'properties.privateDnsZoneId', 'type': 'str'}, + 'record_sets': {'key': 'properties.recordSets', 'type': '[RecordSet]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateDnsZoneConfig, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.private_dns_zone_id = kwargs.get('private_dns_zone_id', None) + self.record_sets = None + + +class PrivateDnsZoneGroup(SubResource): + """Private dns zone group resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the private dns zone group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_dns_zone_configs: A collection of private dns zone configurations of the private + dns zone group. + :type private_dns_zone_configs: + list[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneConfig] + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_dns_zone_configs': {'key': 'properties.privateDnsZoneConfigs', 'type': '[PrivateDnsZoneConfig]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateDnsZoneGroup, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.provisioning_state = None + self.private_dns_zone_configs = kwargs.get('private_dns_zone_configs', None) + + +class PrivateDnsZoneGroupListResult(msrest.serialization.Model): + """Response for the ListPrivateDnsZoneGroups API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of private dns zone group resources in a private endpoint. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateDnsZoneGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateDnsZoneGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class PrivateEndpoint(Resource): + """Private endpoint resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param subnet: The ID of the subnet from which the private IP will be allocated. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :ivar network_interfaces: An array of references to the network interfaces created for this + private endpoint. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar provisioning_state: The provisioning state of the private endpoint resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_link_service_connections: A grouping of information about the connection to the + remote resource. + :type private_link_service_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnection] + :param manual_private_link_service_connections: A grouping of information about the connection + to the remote resource. Used when the network admin does not have access to approve connections + to the remote resource. + :type manual_private_link_service_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnection] + :param custom_dns_configs: An array of custom dns configurations. + :type custom_dns_configs: + list[~azure.mgmt.network.v2020_08_01.models.CustomDnsConfigPropertiesFormat] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interfaces': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_service_connections': {'key': 'properties.privateLinkServiceConnections', 'type': '[PrivateLinkServiceConnection]'}, + 'manual_private_link_service_connections': {'key': 'properties.manualPrivateLinkServiceConnections', 'type': '[PrivateLinkServiceConnection]'}, + 'custom_dns_configs': {'key': 'properties.customDnsConfigs', 'type': '[CustomDnsConfigPropertiesFormat]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpoint, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.etag = None + self.subnet = kwargs.get('subnet', None) + self.network_interfaces = None + self.provisioning_state = None + self.private_link_service_connections = kwargs.get('private_link_service_connections', None) + self.manual_private_link_service_connections = kwargs.get('manual_private_link_service_connections', None) + self.custom_dns_configs = kwargs.get('custom_dns_configs', None) + + +class PrivateEndpointConnection(SubResource): + """PrivateEndpointConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: The resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar private_endpoint: The resource of private end point. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param private_link_service_connection_state: A collection of information about the state of + the connection between service consumer and provider. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + :ivar provisioning_state: The provisioning state of the private endpoint connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar link_identifier: The consumer link id. + :vartype link_identifier: str + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'link_identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'link_identifier': {'key': 'properties.linkIdentifier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpointConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.private_endpoint = None + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + self.provisioning_state = None + self.link_identifier = None + + +class PrivateEndpointConnectionListResult(msrest.serialization.Model): + """Response for the ListPrivateEndpointConnection API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of PrivateEndpointConnection resources for a specific private link + service. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateEndpointConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpointConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class PrivateEndpointListResult(msrest.serialization.Model): + """Response for the ListPrivateEndpoints API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of private endpoint resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpointListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class PrivateLinkService(Resource): + """Private link service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param load_balancer_frontend_ip_configurations: An array of references to the load balancer IP + configurations. + :type load_balancer_frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :param ip_configurations: An array of private link service IP configurations. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceIpConfiguration] + :ivar network_interfaces: An array of references to the network interfaces created for this + private link service. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar provisioning_state: The provisioning state of the private link service resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar private_endpoint_connections: An array of list about connections to the private endpoint. + :vartype private_endpoint_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection] + :param visibility: The visibility list of the private link service. + :type visibility: ~azure.mgmt.network.v2020_08_01.models.ResourceSet + :param auto_approval: The auto-approval list of the private link service. + :type auto_approval: ~azure.mgmt.network.v2020_08_01.models.ResourceSet + :param fqdns: The list of Fqdn. + :type fqdns: list[str] + :ivar alias: The alias of the private link service. + :vartype alias: str + :param enable_proxy_protocol: Whether the private link service is enabled for proxy protocol or + not. + :type enable_proxy_protocol: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interfaces': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'private_endpoint_connections': {'readonly': True}, + 'alias': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'load_balancer_frontend_ip_configurations': {'key': 'properties.loadBalancerFrontendIpConfigurations', 'type': '[FrontendIPConfiguration]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[PrivateLinkServiceIpConfiguration]'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint_connections': {'key': 'properties.privateEndpointConnections', 'type': '[PrivateEndpointConnection]'}, + 'visibility': {'key': 'properties.visibility', 'type': 'ResourceSet'}, + 'auto_approval': {'key': 'properties.autoApproval', 'type': 'ResourceSet'}, + 'fqdns': {'key': 'properties.fqdns', 'type': '[str]'}, + 'alias': {'key': 'properties.alias', 'type': 'str'}, + 'enable_proxy_protocol': {'key': 'properties.enableProxyProtocol', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkService, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.etag = None + self.load_balancer_frontend_ip_configurations = kwargs.get('load_balancer_frontend_ip_configurations', None) + self.ip_configurations = kwargs.get('ip_configurations', None) + self.network_interfaces = None + self.provisioning_state = None + self.private_endpoint_connections = None + self.visibility = kwargs.get('visibility', None) + self.auto_approval = kwargs.get('auto_approval', None) + self.fqdns = kwargs.get('fqdns', None) + self.alias = None + self.enable_proxy_protocol = kwargs.get('enable_proxy_protocol', None) + + +class PrivateLinkServiceConnection(SubResource): + """PrivateLinkServiceConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: The resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the private link service connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_link_service_id: The resource id of private link service. + :type private_link_service_id: str + :param group_ids: The ID(s) of the group(s) obtained from the remote resource that this private + endpoint should connect to. + :type group_ids: list[str] + :param request_message: A message passed to the owner of the remote resource with this + connection request. Restricted to 140 chars. + :type request_message: str + :param private_link_service_connection_state: A collection of read-only information about the + state of the connection to the remote resource. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_service_id': {'key': 'properties.privateLinkServiceId', 'type': 'str'}, + 'group_ids': {'key': 'properties.groupIds', 'type': '[str]'}, + 'request_message': {'key': 'properties.requestMessage', 'type': 'str'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServiceConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.type = None + self.etag = None + self.provisioning_state = None + self.private_link_service_id = kwargs.get('private_link_service_id', None) + self.group_ids = kwargs.get('group_ids', None) + self.request_message = kwargs.get('request_message', None) + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + + +class PrivateLinkServiceConnectionState(msrest.serialization.Model): + """A collection of information about the state of the connection between service consumer and provider. + + :param status: Indicates whether the connection has been Approved/Rejected/Removed by the owner + of the service. + :type status: str + :param description: The reason for approval/rejection of the connection. + :type description: str + :param actions_required: A message indicating if changes on the service provider require any + updates on the consumer. + :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(PrivateLinkServiceConnectionState, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.description = kwargs.get('description', None) + self.actions_required = kwargs.get('actions_required', None) + + +class PrivateLinkServiceIpConfiguration(SubResource): + """The private link service ip configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of private link service ip configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: The resource type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param primary: Whether the ip configuration is primary or not. + :type primary: bool + :ivar provisioning_state: The provisioning state of the private link service IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_ip_address_version: Whether the specific IP configuration is IPv4 or IPv6. + Default is IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServiceIpConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.private_ip_address = kwargs.get('private_ip_address', None) + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.primary = kwargs.get('primary', None) + self.provisioning_state = None + self.private_ip_address_version = kwargs.get('private_ip_address_version', None) + + +class PrivateLinkServiceListResult(msrest.serialization.Model): + """Response for the ListPrivateLinkService API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of PrivateLinkService resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkService] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkService]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServiceListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ResourceSet(msrest.serialization.Model): + """The base resource set for visibility and auto-approval. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceSet, self).__init__(**kwargs) + self.subscriptions = kwargs.get('subscriptions', None) + + +class PrivateLinkServicePropertiesAutoApproval(ResourceSet): + """The auto-approval list of the private link service. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServicePropertiesAutoApproval, self).__init__(**kwargs) + + +class PrivateLinkServicePropertiesVisibility(ResourceSet): + """The visibility list of the private link service. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServicePropertiesVisibility, self).__init__(**kwargs) + + +class PrivateLinkServiceVisibility(msrest.serialization.Model): + """Response for the CheckPrivateLinkServiceVisibility API service call. + + :param visible: Private Link Service Visibility (True/False). + :type visible: bool + """ + + _attribute_map = { + 'visible': {'key': 'visible', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkServiceVisibility, self).__init__(**kwargs) + self.visible = kwargs.get('visible', None) + + +class Probe(SubResource): + """A load balancer probe. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of probes used by the load + balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar load_balancing_rules: The load balancer rules that use this probe. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param protocol: The protocol of the end point. If 'Tcp' is specified, a received ACK is + required for the probe to be successful. If 'Http' or 'Https' is specified, a 200 OK response + from the specifies URI is required for the probe to be successful. Possible values include: + "Http", "Tcp", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ProbeProtocol + :param port: The port for communicating the probe. Possible values range from 1 to 65535, + inclusive. + :type port: int + :param interval_in_seconds: The interval, in seconds, for how frequently to probe the endpoint + for health status. Typically, the interval is slightly less than half the allocated timeout + period (in seconds) which allows two full probes before taking the instance out of rotation. + The default value is 15, the minimum value is 5. + :type interval_in_seconds: int + :param number_of_probes: The number of probes where if no response, will result in stopping + further traffic from being delivered to the endpoint. This values allows endpoints to be taken + out of rotation faster or slower than the typical times used in Azure. + :type number_of_probes: int + :param request_path: The URI used for requesting health status from the VM. Path is required if + a protocol is set to http. Otherwise, it is not allowed. There is no default value. + :type request_path: str + :ivar provisioning_state: The provisioning state of the probe resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'interval_in_seconds': {'key': 'properties.intervalInSeconds', 'type': 'int'}, + 'number_of_probes': {'key': 'properties.numberOfProbes', 'type': 'int'}, + 'request_path': {'key': 'properties.requestPath', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Probe, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.load_balancing_rules = None + self.protocol = kwargs.get('protocol', None) + self.port = kwargs.get('port', None) + self.interval_in_seconds = kwargs.get('interval_in_seconds', None) + self.number_of_probes = kwargs.get('number_of_probes', None) + self.request_path = kwargs.get('request_path', None) + self.provisioning_state = None + + +class PropagatedRouteTable(msrest.serialization.Model): + """The list of RouteTables to advertise the routes to. + + :param labels: The list of labels. + :type labels: list[str] + :param ids: The list of resource ids of all the RouteTables. + :type ids: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _attribute_map = { + 'labels': {'key': 'labels', 'type': '[str]'}, + 'ids': {'key': 'ids', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(PropagatedRouteTable, self).__init__(**kwargs) + self.labels = kwargs.get('labels', None) + self.ids = kwargs.get('ids', None) + + +class ProtocolConfiguration(msrest.serialization.Model): + """Configuration of the protocol. + + :param http_configuration: HTTP configuration of the connectivity check. + :type http_configuration: ~azure.mgmt.network.v2020_08_01.models.HTTPConfiguration + """ + + _attribute_map = { + 'http_configuration': {'key': 'HTTPConfiguration', 'type': 'HTTPConfiguration'}, + } + + def __init__( + self, + **kwargs + ): + super(ProtocolConfiguration, self).__init__(**kwargs) + self.http_configuration = kwargs.get('http_configuration', None) + + +class ProtocolCustomSettingsFormat(msrest.serialization.Model): + """DDoS custom policy properties. + + :param protocol: The protocol for which the DDoS protection policy is being customized. + Possible values include: "Tcp", "Udp", "Syn". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicyProtocol + :param trigger_rate_override: The customized DDoS protection trigger rate. + :type trigger_rate_override: str + :param source_rate_override: The customized DDoS protection source rate. + :type source_rate_override: str + :param trigger_sensitivity_override: The customized DDoS protection trigger rate sensitivity + degrees. High: Trigger rate set with most sensitivity w.r.t. normal traffic. Default: Trigger + rate set with moderate sensitivity w.r.t. normal traffic. Low: Trigger rate set with less + sensitivity w.r.t. normal traffic. Relaxed: Trigger rate set with least sensitivity w.r.t. + normal traffic. Possible values include: "Relaxed", "Low", "Default", "High". + :type trigger_sensitivity_override: str or + ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicyTriggerSensitivityOverride + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'trigger_rate_override': {'key': 'triggerRateOverride', 'type': 'str'}, + 'source_rate_override': {'key': 'sourceRateOverride', 'type': 'str'}, + 'trigger_sensitivity_override': {'key': 'triggerSensitivityOverride', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProtocolCustomSettingsFormat, self).__init__(**kwargs) + self.protocol = kwargs.get('protocol', None) + self.trigger_rate_override = kwargs.get('trigger_rate_override', None) + self.source_rate_override = kwargs.get('source_rate_override', None) + self.trigger_sensitivity_override = kwargs.get('trigger_sensitivity_override', None) + + +class PublicIPAddress(Resource): + """Public IP address resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the public ip address. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The public IP address SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param public_ip_allocation_method: The public IP address allocation method. Possible values + include: "Static", "Dynamic". + :type public_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param public_ip_address_version: The public IP address version. Possible values include: + "IPv4", "IPv6". + :type public_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :ivar ip_configuration: The IP configuration associated with the public IP address. + :vartype ip_configuration: ~azure.mgmt.network.v2020_08_01.models.IPConfiguration + :param dns_settings: The FQDN of the DNS record associated with the public IP address. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressDnsSettings + :param ddos_settings: The DDoS protection custom policy associated with the public IP address. + :type ddos_settings: ~azure.mgmt.network.v2020_08_01.models.DdosSettings + :param ip_tags: The list of tags associated with the public IP address. + :type ip_tags: list[~azure.mgmt.network.v2020_08_01.models.IpTag] + :param ip_address: The IP address associated with the public IP address resource. + :type ip_address: str + :param public_ip_prefix: The Public IP Prefix this Public IP Address should be allocated from. + :type public_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param idle_timeout_in_minutes: The idle timeout of the public IP address. + :type idle_timeout_in_minutes: int + :ivar resource_guid: The resource GUID property of the public IP address resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the public IP address resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'ip_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'PublicIPAddressSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'public_ip_allocation_method': {'key': 'properties.publicIPAllocationMethod', 'type': 'str'}, + 'public_ip_address_version': {'key': 'properties.publicIPAddressVersion', 'type': 'str'}, + 'ip_configuration': {'key': 'properties.ipConfiguration', 'type': 'IPConfiguration'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'PublicIPAddressDnsSettings'}, + 'ddos_settings': {'key': 'properties.ddosSettings', 'type': 'DdosSettings'}, + 'ip_tags': {'key': 'properties.ipTags', 'type': '[IpTag]'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'public_ip_prefix': {'key': 'properties.publicIPPrefix', 'type': 'SubResource'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPAddress, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.sku = kwargs.get('sku', None) + self.etag = None + self.zones = kwargs.get('zones', None) + self.public_ip_allocation_method = kwargs.get('public_ip_allocation_method', None) + self.public_ip_address_version = kwargs.get('public_ip_address_version', None) + self.ip_configuration = None + self.dns_settings = kwargs.get('dns_settings', None) + self.ddos_settings = kwargs.get('ddos_settings', None) + self.ip_tags = kwargs.get('ip_tags', None) + self.ip_address = kwargs.get('ip_address', None) + self.public_ip_prefix = kwargs.get('public_ip_prefix', None) + self.idle_timeout_in_minutes = kwargs.get('idle_timeout_in_minutes', None) + self.resource_guid = None + self.provisioning_state = None + + +class PublicIPAddressDnsSettings(msrest.serialization.Model): + """Contains FQDN of the DNS record associated with the public IP address. + + :param domain_name_label: The domain name label. The concatenation of the domain name label and + the regionalized DNS zone make up the fully qualified domain name associated with the public IP + address. If a domain name label is specified, an A DNS record is created for the public IP in + the Microsoft Azure DNS system. + :type domain_name_label: str + :param fqdn: The Fully Qualified Domain Name of the A DNS record associated with the public IP. + This is the concatenation of the domainNameLabel and the regionalized DNS zone. + :type fqdn: str + :param reverse_fqdn: The reverse FQDN. A user-visible, fully qualified domain name that + resolves to this public IP address. If the reverseFqdn is specified, then a PTR DNS record is + created pointing from the IP address in the in-addr.arpa domain to the reverse FQDN. + :type reverse_fqdn: str + """ + + _attribute_map = { + 'domain_name_label': {'key': 'domainNameLabel', 'type': 'str'}, + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'reverse_fqdn': {'key': 'reverseFqdn', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPAddressDnsSettings, self).__init__(**kwargs) + self.domain_name_label = kwargs.get('domain_name_label', None) + self.fqdn = kwargs.get('fqdn', None) + self.reverse_fqdn = kwargs.get('reverse_fqdn', None) + + +class PublicIPAddressListResult(msrest.serialization.Model): + """Response for ListPublicIpAddresses API service call. + + :param value: A list of public IP addresses that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PublicIPAddress] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicIPAddress]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPAddressListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class PublicIPAddressSku(msrest.serialization.Model): + """SKU of a public IP address. + + :param name: Name of a public IP address SKU. Possible values include: "Basic", "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSkuName + :param tier: Tier of a public IP address SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPAddressSku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + + +class PublicIPPrefix(Resource): + """Public IP prefix resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the public ip address. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The public IP prefix SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param public_ip_address_version: The public IP address version. Possible values include: + "IPv4", "IPv6". + :type public_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param ip_tags: The list of tags associated with the public IP prefix. + :type ip_tags: list[~azure.mgmt.network.v2020_08_01.models.IpTag] + :param prefix_length: The Length of the Public IP Prefix. + :type prefix_length: int + :ivar ip_prefix: The allocated Prefix. + :vartype ip_prefix: str + :ivar public_ip_addresses: The list of all referenced PublicIPAddresses. + :vartype public_ip_addresses: + list[~azure.mgmt.network.v2020_08_01.models.ReferencedPublicIpAddress] + :ivar load_balancer_frontend_ip_configuration: The reference to load balancer frontend IP + configuration associated with the public IP prefix. + :vartype load_balancer_frontend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.SubResource + :param custom_ip_prefix: The customIpPrefix that this prefix is associated with. + :type custom_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar resource_guid: The resource GUID property of the public IP prefix resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the public IP prefix resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'ip_prefix': {'readonly': True}, + 'public_ip_addresses': {'readonly': True}, + 'load_balancer_frontend_ip_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'PublicIPPrefixSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'public_ip_address_version': {'key': 'properties.publicIPAddressVersion', 'type': 'str'}, + 'ip_tags': {'key': 'properties.ipTags', 'type': '[IpTag]'}, + 'prefix_length': {'key': 'properties.prefixLength', 'type': 'int'}, + 'ip_prefix': {'key': 'properties.ipPrefix', 'type': 'str'}, + 'public_ip_addresses': {'key': 'properties.publicIPAddresses', 'type': '[ReferencedPublicIpAddress]'}, + 'load_balancer_frontend_ip_configuration': {'key': 'properties.loadBalancerFrontendIpConfiguration', 'type': 'SubResource'}, + 'custom_ip_prefix': {'key': 'properties.customIPPrefix', 'type': 'SubResource'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPPrefix, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.sku = kwargs.get('sku', None) + self.etag = None + self.zones = kwargs.get('zones', None) + self.public_ip_address_version = kwargs.get('public_ip_address_version', None) + self.ip_tags = kwargs.get('ip_tags', None) + self.prefix_length = kwargs.get('prefix_length', None) + self.ip_prefix = None + self.public_ip_addresses = None + self.load_balancer_frontend_ip_configuration = None + self.custom_ip_prefix = kwargs.get('custom_ip_prefix', None) + self.resource_guid = None + self.provisioning_state = None + + +class PublicIPPrefixListResult(msrest.serialization.Model): + """Response for ListPublicIpPrefixes API service call. + + :param value: A list of public IP prefixes that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicIPPrefix]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPPrefixListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class PublicIPPrefixSku(msrest.serialization.Model): + """SKU of a public IP prefix. + + :param name: Name of a public IP prefix SKU. Possible values include: "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSkuName + :param tier: Tier of a public IP prefix SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicIPPrefixSku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + + +class QosIpRange(msrest.serialization.Model): + """Qos Traffic Profiler IP Range properties. + + :param start_ip: Start IP Address. + :type start_ip: str + :param end_ip: End IP Address. + :type end_ip: str + """ + + _attribute_map = { + 'start_ip': {'key': 'startIP', 'type': 'str'}, + 'end_ip': {'key': 'endIP', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(QosIpRange, self).__init__(**kwargs) + self.start_ip = kwargs.get('start_ip', None) + self.end_ip = kwargs.get('end_ip', None) + + +class QosPortRange(msrest.serialization.Model): + """Qos Traffic Profiler Port range properties. + + :param start: Qos Port Range start. + :type start: int + :param end: Qos Port Range end. + :type end: int + """ + + _attribute_map = { + 'start': {'key': 'start', 'type': 'int'}, + 'end': {'key': 'end', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(QosPortRange, self).__init__(**kwargs) + self.start = kwargs.get('start', None) + self.end = kwargs.get('end', None) + + +class QueryTroubleshootingParameters(msrest.serialization.Model): + """Parameters that define the resource to query the troubleshooting result. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource ID to query the troubleshooting + result. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(QueryTroubleshootingParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + + +class RadiusServer(msrest.serialization.Model): + """Radius Server Settings. + + All required parameters must be populated in order to send to Azure. + + :param radius_server_address: Required. The address of this radius server. + :type radius_server_address: str + :param radius_server_score: The initial score assigned to this radius server. + :type radius_server_score: long + :param radius_server_secret: The secret used for this radius server. + :type radius_server_secret: str + """ + + _validation = { + 'radius_server_address': {'required': True}, + } + + _attribute_map = { + 'radius_server_address': {'key': 'radiusServerAddress', 'type': 'str'}, + 'radius_server_score': {'key': 'radiusServerScore', 'type': 'long'}, + 'radius_server_secret': {'key': 'radiusServerSecret', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RadiusServer, self).__init__(**kwargs) + self.radius_server_address = kwargs['radius_server_address'] + self.radius_server_score = kwargs.get('radius_server_score', None) + self.radius_server_secret = kwargs.get('radius_server_secret', None) + + +class RecordSet(msrest.serialization.Model): + """A collective group of information about the record set information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param record_type: Resource record type. + :type record_type: str + :param record_set_name: Recordset name. + :type record_set_name: str + :param fqdn: Fqdn that resolves to private endpoint ip address. + :type fqdn: str + :ivar provisioning_state: The provisioning state of the recordset. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ttl: Recordset time to live. + :type ttl: int + :param ip_addresses: The private ip address of the private endpoint. + :type ip_addresses: list[str] + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'record_type': {'key': 'recordType', 'type': 'str'}, + 'record_set_name': {'key': 'recordSetName', 'type': 'str'}, + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'ttl': {'key': 'ttl', 'type': 'int'}, + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(RecordSet, self).__init__(**kwargs) + self.record_type = kwargs.get('record_type', None) + self.record_set_name = kwargs.get('record_set_name', None) + self.fqdn = kwargs.get('fqdn', None) + self.provisioning_state = None + self.ttl = kwargs.get('ttl', None) + self.ip_addresses = kwargs.get('ip_addresses', None) + + +class ReferencedPublicIpAddress(msrest.serialization.Model): + """Reference to a public IP address. + + :param id: The PublicIPAddress Reference. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ReferencedPublicIpAddress, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class ResourceNavigationLink(SubResource): + """ResourceNavigationLink resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param linked_resource_type: Resource type of the linked resource. + :type linked_resource_type: str + :param link: Link to the external resource. + :type link: str + :ivar provisioning_state: The provisioning state of the resource navigation link resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'linked_resource_type': {'key': 'properties.linkedResourceType', 'type': 'str'}, + 'link': {'key': 'properties.link', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNavigationLink, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.linked_resource_type = kwargs.get('linked_resource_type', None) + self.link = kwargs.get('link', None) + self.provisioning_state = None + + +class ResourceNavigationLinksListResult(msrest.serialization.Model): + """Response for ResourceNavigationLinks_List operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The resource navigation links in a subnet. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLink] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceNavigationLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNavigationLinksListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class RetentionPolicyParameters(msrest.serialization.Model): + """Parameters that define the retention policy for flow log. + + :param days: Number of days to retain flow log records. + :type days: int + :param enabled: Flag to enable/disable retention. + :type enabled: bool + """ + + _attribute_map = { + 'days': {'key': 'days', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(RetentionPolicyParameters, self).__init__(**kwargs) + self.days = kwargs.get('days', 0) + self.enabled = kwargs.get('enabled', False) + + +class Route(SubResource): + """Route resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param type: The type of the resource. + :type type: str + :param address_prefix: The destination CIDR to which the route applies. + :type address_prefix: str + :param next_hop_type: The type of Azure hop the packet should be sent to. Possible values + include: "VirtualNetworkGateway", "VnetLocal", "Internet", "VirtualAppliance", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteNextHopType + :param next_hop_ip_address: The IP address packets should be forwarded to. Next hop values are + only allowed in routes where the next hop type is VirtualAppliance. + :type next_hop_ip_address: str + :ivar provisioning_state: The provisioning state of the route resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param has_bgp_override: A value indicating whether this route overrides overlapping BGP routes + regardless of LPM. + :type has_bgp_override: bool + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'next_hop_type': {'key': 'properties.nextHopType', 'type': 'str'}, + 'next_hop_ip_address': {'key': 'properties.nextHopIpAddress', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'has_bgp_override': {'key': 'properties.hasBgpOverride', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(Route, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = kwargs.get('type', None) + self.address_prefix = kwargs.get('address_prefix', None) + self.next_hop_type = kwargs.get('next_hop_type', None) + self.next_hop_ip_address = kwargs.get('next_hop_ip_address', None) + self.provisioning_state = None + self.has_bgp_override = kwargs.get('has_bgp_override', None) + + +class RouteFilter(Resource): + """Route Filter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param rules: Collection of RouteFilterRules contained within a route filter. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :ivar peerings: A collection of references to express route circuit peerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar ipv6_peerings: A collection of references to express route circuit ipv6 peerings. + :vartype ipv6_peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar provisioning_state: The provisioning state of the route filter resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'peerings': {'readonly': True}, + 'ipv6_peerings': {'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'}, + 'rules': {'key': 'properties.rules', 'type': '[RouteFilterRule]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'ipv6_peerings': {'key': 'properties.ipv6Peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteFilter, self).__init__(**kwargs) + self.etag = None + self.rules = kwargs.get('rules', None) + self.peerings = None + self.ipv6_peerings = None + self.provisioning_state = None + + +class RouteFilterListResult(msrest.serialization.Model): + """Response for the ListRouteFilters API service call. + + :param value: A list of route filters in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteFilter] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteFilter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteFilterListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class RouteFilterRule(SubResource): + """Route Filter Rule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :param location: Resource location. + :type location: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param access: The access type of the rule. Possible values include: "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param route_filter_rule_type: The rule type of the rule. Possible values include: "Community". + :type route_filter_rule_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleType + :param communities: The collection for bgp community values to filter on. e.g. + ['12076:5010','12076:5020']. + :type communities: list[str] + :ivar provisioning_state: The provisioning state of the route filter rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'route_filter_rule_type': {'key': 'properties.routeFilterRuleType', 'type': 'str'}, + 'communities': {'key': 'properties.communities', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteFilterRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.location = kwargs.get('location', None) + self.etag = None + self.access = kwargs.get('access', None) + self.route_filter_rule_type = kwargs.get('route_filter_rule_type', None) + self.communities = kwargs.get('communities', None) + self.provisioning_state = None + + +class RouteFilterRuleListResult(msrest.serialization.Model): + """Response for the ListRouteFilterRules API service call. + + :param value: A list of RouteFilterRules in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteFilterRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteFilterRuleListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class RouteListResult(msrest.serialization.Model): + """Response for the ListRoute API service call. + + :param value: A list of routes in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Route] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Route]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class RouteTable(Resource): + """Route table resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param routes: Collection of routes contained within a route table. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.Route] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param disable_bgp_route_propagation: Whether to disable the routes learned by BGP on that + route table. True means disable. + :type disable_bgp_route_propagation: bool + :ivar provisioning_state: The provisioning state of the route table resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_guid: The resource GUID property of the route table. + :vartype resource_guid: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_guid': {'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'}, + 'routes': {'key': 'properties.routes', 'type': '[Route]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'disable_bgp_route_propagation': {'key': 'properties.disableBgpRoutePropagation', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteTable, self).__init__(**kwargs) + self.etag = None + self.routes = kwargs.get('routes', None) + self.subnets = None + self.disable_bgp_route_propagation = kwargs.get('disable_bgp_route_propagation', None) + self.provisioning_state = None + self.resource_guid = None + + +class RouteTableListResult(msrest.serialization.Model): + """Response for the ListRouteTable API service call. + + :param value: A list of route tables in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RouteTableListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class RoutingConfiguration(msrest.serialization.Model): + """Routing Configuration indicating the associated and propagated route tables for this connection. + + :param associated_route_table: The resource id RouteTable associated with this + RoutingConfiguration. + :type associated_route_table: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param propagated_route_tables: The list of RouteTables to advertise the routes to. + :type propagated_route_tables: ~azure.mgmt.network.v2020_08_01.models.PropagatedRouteTable + :param vnet_routes: List of routes that control routing from VirtualHub into a virtual network + connection. + :type vnet_routes: ~azure.mgmt.network.v2020_08_01.models.VnetRoute + """ + + _attribute_map = { + 'associated_route_table': {'key': 'associatedRouteTable', 'type': 'SubResource'}, + 'propagated_route_tables': {'key': 'propagatedRouteTables', 'type': 'PropagatedRouteTable'}, + 'vnet_routes': {'key': 'vnetRoutes', 'type': 'VnetRoute'}, + } + + def __init__( + self, + **kwargs + ): + super(RoutingConfiguration, self).__init__(**kwargs) + self.associated_route_table = kwargs.get('associated_route_table', None) + self.propagated_route_tables = kwargs.get('propagated_route_tables', None) + self.vnet_routes = kwargs.get('vnet_routes', None) + + +class SecurityGroupNetworkInterface(msrest.serialization.Model): + """Network interface and all its associated security rules. + + :param id: ID of the network interface. + :type id: str + :param security_rule_associations: All security rules associated with the network interface. + :type security_rule_associations: + ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAssociations + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rule_associations': {'key': 'securityRuleAssociations', 'type': 'SecurityRuleAssociations'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityGroupNetworkInterface, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.security_rule_associations = kwargs.get('security_rule_associations', None) + + +class SecurityGroupViewParameters(msrest.serialization.Model): + """Parameters that define the VM to check security groups for. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. ID of the target VM. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityGroupViewParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + + +class SecurityGroupViewResult(msrest.serialization.Model): + """The information about security rules applied to the specified VM. + + :param network_interfaces: List of network interfaces on the specified VM. + :type network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.SecurityGroupNetworkInterface] + """ + + _attribute_map = { + 'network_interfaces': {'key': 'networkInterfaces', 'type': '[SecurityGroupNetworkInterface]'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityGroupViewResult, self).__init__(**kwargs) + self.network_interfaces = kwargs.get('network_interfaces', None) + + +class SecurityPartnerProvider(Resource): + """Security Partner Provider resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the Security Partner Provider resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param security_provider_name: The security provider name. Possible values include: "ZScaler", + "IBoss", "Checkpoint". + :type security_provider_name: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityProviderName + :ivar connection_status: The connection status with the Security Partner Provider. Possible + values include: "Unknown", "PartiallyConnected", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderConnectionStatus + :param virtual_hub: The virtualHub to which the Security Partner Provider belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'connection_status': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'security_provider_name': {'key': 'properties.securityProviderName', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityPartnerProvider, self).__init__(**kwargs) + self.etag = None + self.provisioning_state = None + self.security_provider_name = kwargs.get('security_provider_name', None) + self.connection_status = None + self.virtual_hub = kwargs.get('virtual_hub', None) + + +class SecurityPartnerProviderListResult(msrest.serialization.Model): + """Response for ListSecurityPartnerProviders API service call. + + :param value: List of Security Partner Providers in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SecurityPartnerProvider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityPartnerProviderListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class SecurityRule(SubResource): + """Network security rule. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param type: The type of the resource. + :type type: str + :param description: A description for this rule. Restricted to 140 chars. + :type description: str + :param protocol: Network protocol this rule applies to. Possible values include: "Tcp", "Udp", + "Icmp", "Esp", "*", "Ah". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleProtocol + :param source_port_range: The source port or range. Integer or range between 0 and 65535. + Asterisk '*' can also be used to match all ports. + :type source_port_range: str + :param destination_port_range: The destination port or range. Integer or range between 0 and + 65535. Asterisk '*' can also be used to match all ports. + :type destination_port_range: str + :param source_address_prefix: The CIDR or source IP range. Asterisk '*' can also be used to + match all source IPs. Default tags such as 'VirtualNetwork', 'AzureLoadBalancer' and 'Internet' + can also be used. If this is an ingress rule, specifies where network traffic originates from. + :type source_address_prefix: str + :param source_address_prefixes: The CIDR or source IP ranges. + :type source_address_prefixes: list[str] + :param source_application_security_groups: The application security group specified as source. + :type source_application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :param destination_address_prefix: The destination address prefix. CIDR or destination IP + range. Asterisk '*' can also be used to match all source IPs. Default tags such as + 'VirtualNetwork', 'AzureLoadBalancer' and 'Internet' can also be used. + :type destination_address_prefix: str + :param destination_address_prefixes: The destination address prefixes. CIDR or destination IP + ranges. + :type destination_address_prefixes: list[str] + :param destination_application_security_groups: The application security group specified as + destination. + :type destination_application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :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: The network traffic is allowed or denied. Possible values include: "Allow", + "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :param priority: The priority of the rule. The value can be between 100 and 4096. 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: The direction of the rule. The direction specifies if rule will be evaluated + on incoming or outgoing traffic. Possible values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleDirection + :ivar provisioning_state: The provisioning state of the security rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'source_port_range': {'key': 'properties.sourcePortRange', 'type': 'str'}, + 'destination_port_range': {'key': 'properties.destinationPortRange', 'type': 'str'}, + 'source_address_prefix': {'key': 'properties.sourceAddressPrefix', 'type': 'str'}, + 'source_address_prefixes': {'key': 'properties.sourceAddressPrefixes', 'type': '[str]'}, + 'source_application_security_groups': {'key': 'properties.sourceApplicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'destination_address_prefix': {'key': 'properties.destinationAddressPrefix', 'type': 'str'}, + 'destination_address_prefixes': {'key': 'properties.destinationAddressPrefixes', 'type': '[str]'}, + 'destination_application_security_groups': {'key': 'properties.destinationApplicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'source_port_ranges': {'key': 'properties.sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'properties.destinationPortRanges', 'type': '[str]'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'direction': {'key': 'properties.direction', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = kwargs.get('type', None) + self.description = kwargs.get('description', None) + self.protocol = kwargs.get('protocol', None) + self.source_port_range = kwargs.get('source_port_range', None) + self.destination_port_range = kwargs.get('destination_port_range', None) + self.source_address_prefix = kwargs.get('source_address_prefix', None) + self.source_address_prefixes = kwargs.get('source_address_prefixes', None) + self.source_application_security_groups = kwargs.get('source_application_security_groups', None) + self.destination_address_prefix = kwargs.get('destination_address_prefix', None) + self.destination_address_prefixes = kwargs.get('destination_address_prefixes', None) + self.destination_application_security_groups = kwargs.get('destination_application_security_groups', None) + self.source_port_ranges = kwargs.get('source_port_ranges', None) + self.destination_port_ranges = kwargs.get('destination_port_ranges', None) + self.access = kwargs.get('access', None) + self.priority = kwargs.get('priority', None) + self.direction = kwargs.get('direction', None) + self.provisioning_state = None + + +class SecurityRuleAssociations(msrest.serialization.Model): + """All security rules associated with the network interface. + + :param network_interface_association: Network interface and it's custom security rules. + :type network_interface_association: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceAssociation + :param subnet_association: Subnet and it's custom security rules. + :type subnet_association: ~azure.mgmt.network.v2020_08_01.models.SubnetAssociation + :param default_security_rules: Collection of default security rules of the network security + group. + :type default_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :param effective_security_rules: Collection of effective security rules. + :type effective_security_rules: + list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityRule] + """ + + _attribute_map = { + 'network_interface_association': {'key': 'networkInterfaceAssociation', 'type': 'NetworkInterfaceAssociation'}, + 'subnet_association': {'key': 'subnetAssociation', 'type': 'SubnetAssociation'}, + 'default_security_rules': {'key': 'defaultSecurityRules', 'type': '[SecurityRule]'}, + 'effective_security_rules': {'key': 'effectiveSecurityRules', 'type': '[EffectiveNetworkSecurityRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityRuleAssociations, self).__init__(**kwargs) + self.network_interface_association = kwargs.get('network_interface_association', None) + self.subnet_association = kwargs.get('subnet_association', None) + self.default_security_rules = kwargs.get('default_security_rules', None) + self.effective_security_rules = kwargs.get('effective_security_rules', None) + + +class SecurityRuleListResult(msrest.serialization.Model): + """Response for ListSecurityRule API service call. Retrieves all security rules that belongs to a network security group. + + :param value: The security rules in a network security group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SecurityRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SecurityRuleListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ServiceAssociationLink(SubResource): + """ServiceAssociationLink resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param linked_resource_type: Resource type of the linked resource. + :type linked_resource_type: str + :param link: Link to the external resource. + :type link: str + :ivar provisioning_state: The provisioning state of the service association link resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param allow_delete: If true, the resource can be deleted. + :type allow_delete: bool + :param locations: A list of locations. + :type locations: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'linked_resource_type': {'key': 'properties.linkedResourceType', 'type': 'str'}, + 'link': {'key': 'properties.link', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'allow_delete': {'key': 'properties.allowDelete', 'type': 'bool'}, + 'locations': {'key': 'properties.locations', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceAssociationLink, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.linked_resource_type = kwargs.get('linked_resource_type', None) + self.link = kwargs.get('link', None) + self.provisioning_state = None + self.allow_delete = kwargs.get('allow_delete', None) + self.locations = kwargs.get('locations', None) + + +class ServiceAssociationLinksListResult(msrest.serialization.Model): + """Response for ServiceAssociationLinks_List operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The service association links in a subnet. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLink] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceAssociationLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceAssociationLinksListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ServiceEndpointPolicy(Resource): + """Service End point policy resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param service_endpoint_policy_definitions: A collection of service endpoint policy definitions + of the service endpoint policy. + :type service_endpoint_policy_definitions: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :ivar resource_guid: The resource GUID property of the service endpoint policy resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the service endpoint policy resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'resource_guid': {'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'}, + 'service_endpoint_policy_definitions': {'key': 'properties.serviceEndpointPolicyDefinitions', 'type': '[ServiceEndpointPolicyDefinition]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceEndpointPolicy, self).__init__(**kwargs) + self.etag = None + self.service_endpoint_policy_definitions = kwargs.get('service_endpoint_policy_definitions', None) + self.subnets = None + self.resource_guid = None + self.provisioning_state = None + + +class ServiceEndpointPolicyDefinition(SubResource): + """Service Endpoint policy definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param description: A description for this rule. Restricted to 140 chars. + :type description: str + :param service: Service endpoint name. + :type service: str + :param service_resources: A list of service resources. + :type service_resources: list[str] + :ivar provisioning_state: The provisioning state of the service endpoint policy definition + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'service': {'key': 'properties.service', 'type': 'str'}, + 'service_resources': {'key': 'properties.serviceResources', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceEndpointPolicyDefinition, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.description = kwargs.get('description', None) + self.service = kwargs.get('service', None) + self.service_resources = kwargs.get('service_resources', None) + self.provisioning_state = None + + +class ServiceEndpointPolicyDefinitionListResult(msrest.serialization.Model): + """Response for ListServiceEndpointPolicyDefinition API service call. Retrieves all service endpoint policy definition that belongs to a service endpoint policy. + + :param value: The service endpoint policy definition in a service endpoint policy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceEndpointPolicyDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceEndpointPolicyDefinitionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ServiceEndpointPolicyListResult(msrest.serialization.Model): + """Response for ListServiceEndpointPolicies API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ServiceEndpointPolicy resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceEndpointPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceEndpointPolicyListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ServiceEndpointPropertiesFormat(msrest.serialization.Model): + """The service endpoint properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param service: The type of the endpoint service. + :type service: str + :param locations: A list of locations. + :type locations: list[str] + :ivar provisioning_state: The provisioning state of the service endpoint resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'service': {'key': 'service', 'type': 'str'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceEndpointPropertiesFormat, self).__init__(**kwargs) + self.service = kwargs.get('service', None) + self.locations = kwargs.get('locations', None) + self.provisioning_state = None + + +class ServiceTagInformation(msrest.serialization.Model): + """The service tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar properties: Properties of the service tag information. + :vartype properties: + ~azure.mgmt.network.v2020_08_01.models.ServiceTagInformationPropertiesFormat + :ivar name: The name of service tag. + :vartype name: str + :ivar id: The ID of service tag. + :vartype id: str + """ + + _validation = { + 'properties': {'readonly': True}, + 'name': {'readonly': True}, + 'id': {'readonly': True}, + } + + _attribute_map = { + 'properties': {'key': 'properties', 'type': 'ServiceTagInformationPropertiesFormat'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagInformation, self).__init__(**kwargs) + self.properties = None + self.name = None + self.id = None + + +class ServiceTagInformationPropertiesFormat(msrest.serialization.Model): + """Properties of the service tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar change_number: The iteration number of service tag. + :vartype change_number: str + :ivar region: The region of service tag. + :vartype region: str + :ivar system_service: The name of system service. + :vartype system_service: str + :ivar address_prefixes: The list of IP address prefixes. + :vartype address_prefixes: list[str] + """ + + _validation = { + 'change_number': {'readonly': True}, + 'region': {'readonly': True}, + 'system_service': {'readonly': True}, + 'address_prefixes': {'readonly': True}, + } + + _attribute_map = { + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + 'region': {'key': 'region', 'type': 'str'}, + 'system_service': {'key': 'systemService', 'type': 'str'}, + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagInformationPropertiesFormat, self).__init__(**kwargs) + self.change_number = None + self.region = None + self.system_service = None + self.address_prefixes = None + + +class ServiceTagsListResult(msrest.serialization.Model): + """Response for the ListServiceTags API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: The name of the cloud. + :vartype name: str + :ivar id: The ID of the cloud. + :vartype id: str + :ivar type: The azure resource type. + :vartype type: str + :ivar change_number: The iteration number. + :vartype change_number: str + :ivar cloud: The name of the cloud. + :vartype cloud: str + :ivar values: The list of service tag information resources. + :vartype values: list[~azure.mgmt.network.v2020_08_01.models.ServiceTagInformation] + :ivar next_link: The URL to get next page of service tag information resources. + :vartype next_link: str + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'type': {'readonly': True}, + 'change_number': {'readonly': True}, + 'cloud': {'readonly': True}, + 'values': {'readonly': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + 'cloud': {'key': 'cloud', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[ServiceTagInformation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagsListResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.type = None + self.change_number = None + self.cloud = None + self.values = None + self.next_link = None + + +class SessionIds(msrest.serialization.Model): + """List of session IDs. + + :param session_ids: List of session IDs. + :type session_ids: list[str] + """ + + _attribute_map = { + 'session_ids': {'key': 'sessionIds', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(SessionIds, self).__init__(**kwargs) + self.session_ids = kwargs.get('session_ids', None) + + +class StaticRoute(msrest.serialization.Model): + """List of all Static Routes. + + :param name: The name of the StaticRoute that is unique within a VnetRoute. + :type name: str + :param address_prefixes: List of all address prefixes. + :type address_prefixes: list[str] + :param next_hop_ip_address: The ip address of the next hop. + :type next_hop_ip_address: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticRoute, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.address_prefixes = kwargs.get('address_prefixes', None) + self.next_hop_ip_address = kwargs.get('next_hop_ip_address', None) + + +class Subnet(SubResource): + """Subnet in a virtual network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param address_prefix: The address prefix for the subnet. + :type address_prefix: str + :param address_prefixes: List of address prefixes for the subnet. + :type address_prefixes: list[str] + :param network_security_group: The reference to the NetworkSecurityGroup resource. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :param route_table: The reference to the RouteTable resource. + :type route_table: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :param nat_gateway: Nat gateway associated with this subnet. + :type nat_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param service_endpoints: An array of service endpoints. + :type service_endpoints: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPropertiesFormat] + :param service_endpoint_policies: An array of service endpoint policies. + :type service_endpoint_policies: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :ivar private_endpoints: An array of references to private endpoints. + :vartype private_endpoints: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :ivar ip_configurations: An array of references to the network interface IP configurations + using subnet. + :vartype ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.IPConfiguration] + :ivar ip_configuration_profiles: Array of IP configuration profiles which reference this + subnet. + :vartype ip_configuration_profiles: + list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationProfile] + :param ip_allocations: Array of IpAllocation which reference this subnet. + :type ip_allocations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_navigation_links: An array of references to the external resources using subnet. + :vartype resource_navigation_links: + list[~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLink] + :ivar service_association_links: An array of references to services injecting into this subnet. + :vartype service_association_links: + list[~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLink] + :param delegations: An array of references to the delegations on the subnet. + :type delegations: list[~azure.mgmt.network.v2020_08_01.models.Delegation] + :ivar purpose: A read-only string identifying the intention of use for this subnet based on + delegations and other user-defined properties. + :vartype purpose: str + :ivar provisioning_state: The provisioning state of the subnet resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_endpoint_network_policies: Enable or Disable apply network policies on private + end point in the subnet. + :type private_endpoint_network_policies: str + :param private_link_service_network_policies: Enable or Disable apply network policies on + private link service in the subnet. + :type private_link_service_network_policies: str + """ + + _validation = { + 'etag': {'readonly': True}, + 'private_endpoints': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'ip_configuration_profiles': {'readonly': True}, + 'resource_navigation_links': {'readonly': True}, + 'service_association_links': {'readonly': True}, + 'purpose': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'address_prefixes': {'key': 'properties.addressPrefixes', 'type': '[str]'}, + 'network_security_group': {'key': 'properties.networkSecurityGroup', 'type': 'NetworkSecurityGroup'}, + 'route_table': {'key': 'properties.routeTable', 'type': 'RouteTable'}, + 'nat_gateway': {'key': 'properties.natGateway', 'type': 'SubResource'}, + 'service_endpoints': {'key': 'properties.serviceEndpoints', 'type': '[ServiceEndpointPropertiesFormat]'}, + 'service_endpoint_policies': {'key': 'properties.serviceEndpointPolicies', 'type': '[ServiceEndpointPolicy]'}, + 'private_endpoints': {'key': 'properties.privateEndpoints', 'type': '[PrivateEndpoint]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[IPConfiguration]'}, + 'ip_configuration_profiles': {'key': 'properties.ipConfigurationProfiles', 'type': '[IPConfigurationProfile]'}, + 'ip_allocations': {'key': 'properties.ipAllocations', 'type': '[SubResource]'}, + 'resource_navigation_links': {'key': 'properties.resourceNavigationLinks', 'type': '[ResourceNavigationLink]'}, + 'service_association_links': {'key': 'properties.serviceAssociationLinks', 'type': '[ServiceAssociationLink]'}, + 'delegations': {'key': 'properties.delegations', 'type': '[Delegation]'}, + 'purpose': {'key': 'properties.purpose', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint_network_policies': {'key': 'properties.privateEndpointNetworkPolicies', 'type': 'str'}, + 'private_link_service_network_policies': {'key': 'properties.privateLinkServiceNetworkPolicies', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Subnet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.address_prefix = kwargs.get('address_prefix', None) + self.address_prefixes = kwargs.get('address_prefixes', None) + self.network_security_group = kwargs.get('network_security_group', None) + self.route_table = kwargs.get('route_table', None) + self.nat_gateway = kwargs.get('nat_gateway', None) + self.service_endpoints = kwargs.get('service_endpoints', None) + self.service_endpoint_policies = kwargs.get('service_endpoint_policies', None) + self.private_endpoints = None + self.ip_configurations = None + self.ip_configuration_profiles = None + self.ip_allocations = kwargs.get('ip_allocations', None) + self.resource_navigation_links = None + self.service_association_links = None + self.delegations = kwargs.get('delegations', None) + self.purpose = None + self.provisioning_state = None + self.private_endpoint_network_policies = kwargs.get('private_endpoint_network_policies', None) + self.private_link_service_network_policies = kwargs.get('private_link_service_network_policies', None) + + +class SubnetAssociation(msrest.serialization.Model): + """Subnet and it's custom security rules. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Subnet ID. + :vartype id: str + :param security_rules: Collection of custom security rules. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rules': {'key': 'securityRules', 'type': '[SecurityRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(SubnetAssociation, self).__init__(**kwargs) + self.id = None + self.security_rules = kwargs.get('security_rules', None) + + +class SubnetListResult(msrest.serialization.Model): + """Response for ListSubnets API service callRetrieves all subnet that belongs to a virtual network. + + :param value: The subnets in a virtual network. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Subnet]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SubnetListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class TagsObject(msrest.serialization.Model): + """Tags object for patch operations. + + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(TagsObject, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class Topology(msrest.serialization.Model): + """Topology of the specified resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: GUID representing the operation id. + :vartype id: str + :ivar created_date_time: The datetime when the topology was initially created for the resource + group. + :vartype created_date_time: ~datetime.datetime + :ivar last_modified: The datetime when the topology was last modified. + :vartype last_modified: ~datetime.datetime + :param resources: A list of topology resources. + :type resources: list[~azure.mgmt.network.v2020_08_01.models.TopologyResource] + """ + + _validation = { + 'id': {'readonly': True}, + 'created_date_time': {'readonly': True}, + 'last_modified': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'created_date_time': {'key': 'createdDateTime', 'type': 'iso-8601'}, + 'last_modified': {'key': 'lastModified', 'type': 'iso-8601'}, + 'resources': {'key': 'resources', 'type': '[TopologyResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(Topology, self).__init__(**kwargs) + self.id = None + self.created_date_time = None + self.last_modified = None + self.resources = kwargs.get('resources', None) + + +class TopologyAssociation(msrest.serialization.Model): + """Resources that have an association with the parent resource. + + :param name: The name of the resource that is associated with the parent resource. + :type name: str + :param resource_id: The ID of the resource that is associated with the parent resource. + :type resource_id: str + :param association_type: The association type of the child resource to the parent resource. + Possible values include: "Associated", "Contains". + :type association_type: str or ~azure.mgmt.network.v2020_08_01.models.AssociationType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'association_type': {'key': 'associationType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TopologyAssociation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.resource_id = kwargs.get('resource_id', None) + self.association_type = kwargs.get('association_type', None) + + +class TopologyParameters(msrest.serialization.Model): + """Parameters that define the representation of topology. + + :param target_resource_group_name: The name of the target resource group to perform topology + on. + :type target_resource_group_name: str + :param target_virtual_network: The reference to the Virtual Network resource. + :type target_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param target_subnet: The reference to the Subnet resource. + :type target_subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'target_resource_group_name': {'key': 'targetResourceGroupName', 'type': 'str'}, + 'target_virtual_network': {'key': 'targetVirtualNetwork', 'type': 'SubResource'}, + 'target_subnet': {'key': 'targetSubnet', 'type': 'SubResource'}, + } + + def __init__( + self, + **kwargs + ): + super(TopologyParameters, self).__init__(**kwargs) + self.target_resource_group_name = kwargs.get('target_resource_group_name', None) + self.target_virtual_network = kwargs.get('target_virtual_network', None) + self.target_subnet = kwargs.get('target_subnet', None) + + +class TopologyResource(msrest.serialization.Model): + """The network resource topology information for the given resource group. + + :param name: Name of the resource. + :type name: str + :param id: ID of the resource. + :type id: str + :param location: Resource location. + :type location: str + :param associations: Holds the associations the resource has with other resources in the + resource group. + :type associations: list[~azure.mgmt.network.v2020_08_01.models.TopologyAssociation] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'associations': {'key': 'associations', 'type': '[TopologyAssociation]'}, + } + + def __init__( + self, + **kwargs + ): + super(TopologyResource, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.location = kwargs.get('location', None) + self.associations = kwargs.get('associations', None) + + +class TrafficAnalyticsConfigurationProperties(msrest.serialization.Model): + """Parameters that define the configuration of traffic analytics. + + :param enabled: Flag to enable/disable traffic analytics. + :type enabled: bool + :param workspace_id: The resource guid of the attached workspace. + :type workspace_id: str + :param workspace_region: The location of the attached workspace. + :type workspace_region: str + :param workspace_resource_id: Resource Id of the attached workspace. + :type workspace_resource_id: str + :param traffic_analytics_interval: The interval in minutes which would decide how frequently TA + service should do flow analytics. + :type traffic_analytics_interval: int + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'workspace_id': {'key': 'workspaceId', 'type': 'str'}, + 'workspace_region': {'key': 'workspaceRegion', 'type': 'str'}, + 'workspace_resource_id': {'key': 'workspaceResourceId', 'type': 'str'}, + 'traffic_analytics_interval': {'key': 'trafficAnalyticsInterval', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(TrafficAnalyticsConfigurationProperties, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.workspace_id = kwargs.get('workspace_id', None) + self.workspace_region = kwargs.get('workspace_region', None) + self.workspace_resource_id = kwargs.get('workspace_resource_id', None) + self.traffic_analytics_interval = kwargs.get('traffic_analytics_interval', None) + + +class TrafficAnalyticsProperties(msrest.serialization.Model): + """Parameters that define the configuration of traffic analytics. + + :param network_watcher_flow_analytics_configuration: Parameters that define the configuration + of traffic analytics. + :type network_watcher_flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsConfigurationProperties + """ + + _attribute_map = { + 'network_watcher_flow_analytics_configuration': {'key': 'networkWatcherFlowAnalyticsConfiguration', 'type': 'TrafficAnalyticsConfigurationProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(TrafficAnalyticsProperties, self).__init__(**kwargs) + self.network_watcher_flow_analytics_configuration = kwargs.get('network_watcher_flow_analytics_configuration', None) + + +class TrafficSelectorPolicy(msrest.serialization.Model): + """An traffic selector policy for a virtual network gateway connection. + + All required parameters must be populated in order to send to Azure. + + :param local_address_ranges: Required. A collection of local address spaces in CIDR format. + :type local_address_ranges: list[str] + :param remote_address_ranges: Required. A collection of remote address spaces in CIDR format. + :type remote_address_ranges: list[str] + """ + + _validation = { + 'local_address_ranges': {'required': True}, + 'remote_address_ranges': {'required': True}, + } + + _attribute_map = { + 'local_address_ranges': {'key': 'localAddressRanges', 'type': '[str]'}, + 'remote_address_ranges': {'key': 'remoteAddressRanges', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(TrafficSelectorPolicy, self).__init__(**kwargs) + self.local_address_ranges = kwargs['local_address_ranges'] + self.remote_address_ranges = kwargs['remote_address_ranges'] + + +class TroubleshootingDetails(msrest.serialization.Model): + """Information gained from troubleshooting of specified resource. + + :param id: The id of the get troubleshoot operation. + :type id: str + :param reason_type: Reason type of failure. + :type reason_type: str + :param summary: A summary of troubleshooting. + :type summary: str + :param detail: Details on troubleshooting results. + :type detail: str + :param recommended_actions: List of recommended actions. + :type recommended_actions: + list[~azure.mgmt.network.v2020_08_01.models.TroubleshootingRecommendedActions] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'reason_type': {'key': 'reasonType', 'type': 'str'}, + 'summary': {'key': 'summary', 'type': 'str'}, + 'detail': {'key': 'detail', 'type': 'str'}, + 'recommended_actions': {'key': 'recommendedActions', 'type': '[TroubleshootingRecommendedActions]'}, + } + + def __init__( + self, + **kwargs + ): + super(TroubleshootingDetails, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.reason_type = kwargs.get('reason_type', None) + self.summary = kwargs.get('summary', None) + self.detail = kwargs.get('detail', None) + self.recommended_actions = kwargs.get('recommended_actions', None) + + +class TroubleshootingParameters(msrest.serialization.Model): + """Parameters that define the resource to troubleshoot. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource to troubleshoot. + :type target_resource_id: str + :param storage_id: Required. The ID for the storage account to save the troubleshoot result. + :type storage_id: str + :param storage_path: Required. The path to the blob to save the troubleshoot result in. + :type storage_path: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'storage_id': {'required': True}, + 'storage_path': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'storage_path': {'key': 'properties.storagePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TroubleshootingParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + self.storage_id = kwargs['storage_id'] + self.storage_path = kwargs['storage_path'] + + +class TroubleshootingRecommendedActions(msrest.serialization.Model): + """Recommended actions based on discovered issues. + + :param action_id: ID of the recommended action. + :type action_id: str + :param action_text: Description of recommended actions. + :type action_text: str + :param action_uri: The uri linking to a documentation for the recommended troubleshooting + actions. + :type action_uri: str + :param action_uri_text: The information from the URI for the recommended troubleshooting + actions. + :type action_uri_text: str + """ + + _attribute_map = { + 'action_id': {'key': 'actionId', 'type': 'str'}, + 'action_text': {'key': 'actionText', 'type': 'str'}, + 'action_uri': {'key': 'actionUri', 'type': 'str'}, + 'action_uri_text': {'key': 'actionUriText', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TroubleshootingRecommendedActions, self).__init__(**kwargs) + self.action_id = kwargs.get('action_id', None) + self.action_text = kwargs.get('action_text', None) + self.action_uri = kwargs.get('action_uri', None) + self.action_uri_text = kwargs.get('action_uri_text', None) + + +class TroubleshootingResult(msrest.serialization.Model): + """Troubleshooting information gained from specified resource. + + :param start_time: The start time of the troubleshooting. + :type start_time: ~datetime.datetime + :param end_time: The end time of the troubleshooting. + :type end_time: ~datetime.datetime + :param code: The result code of the troubleshooting. + :type code: str + :param results: Information from troubleshooting. + :type results: list[~azure.mgmt.network.v2020_08_01.models.TroubleshootingDetails] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'code': {'key': 'code', 'type': 'str'}, + 'results': {'key': 'results', 'type': '[TroubleshootingDetails]'}, + } + + def __init__( + self, + **kwargs + ): + super(TroubleshootingResult, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.code = kwargs.get('code', None) + self.results = kwargs.get('results', None) + + +class TunnelConnectionHealth(msrest.serialization.Model): + """VirtualNetworkGatewayConnection properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar tunnel: Tunnel name. + :vartype tunnel: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar ingress_bytes_transferred: The Ingress Bytes Transferred in this connection. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: The Egress Bytes Transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar last_connection_established_utc_time: The time at which connection was established in Utc + format. + :vartype last_connection_established_utc_time: str + """ + + _validation = { + 'tunnel': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'last_connection_established_utc_time': {'readonly': True}, + } + + _attribute_map = { + 'tunnel': {'key': 'tunnel', 'type': 'str'}, + 'connection_status': {'key': 'connectionStatus', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'egressBytesTransferred', 'type': 'long'}, + 'last_connection_established_utc_time': {'key': 'lastConnectionEstablishedUtcTime', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TunnelConnectionHealth, self).__init__(**kwargs) + self.tunnel = None + self.connection_status = None + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.last_connection_established_utc_time = None + + +class UnprepareNetworkPoliciesRequest(msrest.serialization.Model): + """Details of UnprepareNetworkPolicies for Subnet. + + :param service_name: The name of the service for which subnet is being unprepared for. + :type service_name: str + """ + + _attribute_map = { + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UnprepareNetworkPoliciesRequest, self).__init__(**kwargs) + self.service_name = kwargs.get('service_name', None) + + +class Usage(msrest.serialization.Model): + """The network resource usage. + + Variables are only 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 identifier. + :vartype id: str + :param unit: Required. An enum describing the unit of measurement. Possible values include: + "Count". + :type unit: str or ~azure.mgmt.network.v2020_08_01.models.UsageUnit + :param current_value: Required. The current value of the usage. + :type current_value: long + :param limit: Required. The limit of usage. + :type limit: long + :param name: Required. The name of the type of usage. + :type name: ~azure.mgmt.network.v2020_08_01.models.UsageName + """ + + _validation = { + 'id': {'readonly': True}, + 'unit': {'required': True}, + 'current_value': {'required': True}, + 'limit': {'required': True}, + 'name': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'UsageName'}, + } + + def __init__( + self, + **kwargs + ): + super(Usage, self).__init__(**kwargs) + self.id = None + self.unit = kwargs['unit'] + self.current_value = kwargs['current_value'] + self.limit = kwargs['limit'] + self.name = kwargs['name'] + + +class UsageName(msrest.serialization.Model): + """The usage names. + + :param value: A string describing the resource name. + :type value: str + :param localized_value: A localized string describing the resource name. + :type localized_value: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UsageName, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.localized_value = kwargs.get('localized_value', None) + + +class UsagesListResult(msrest.serialization.Model): + """The list usages operation response. + + :param value: The list network resource usages. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Usage] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UsagesListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VerificationIPFlowParameters(msrest.serialization.Model): + """Parameters that define the IP flow to be verified. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the target resource to perform next-hop on. + :type target_resource_id: str + :param direction: Required. The direction of the packet represented as a 5-tuple. Possible + values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.Direction + :param protocol: Required. Protocol to be verified on. Possible values include: "TCP", "UDP". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.IpFlowProtocol + :param local_port: Required. The local port. Acceptable values are a single integer in the + range (0-65535). Support for * for the source port, which depends on the direction. + :type local_port: str + :param remote_port: Required. The remote port. Acceptable values are a single integer in the + range (0-65535). Support for * for the source port, which depends on the direction. + :type remote_port: str + :param local_ip_address: Required. The local IP address. Acceptable values are valid IPv4 + addresses. + :type local_ip_address: str + :param remote_ip_address: Required. The remote IP address. Acceptable values are valid IPv4 + addresses. + :type remote_ip_address: str + :param target_nic_resource_id: The NIC ID. (If VM has multiple NICs and IP forwarding is + enabled on any of them, then this parameter must be specified. Otherwise optional). + :type target_nic_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'direction': {'required': True}, + 'protocol': {'required': True}, + 'local_port': {'required': True}, + 'remote_port': {'required': True}, + 'local_ip_address': {'required': True}, + 'remote_ip_address': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'direction': {'key': 'direction', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'local_port': {'key': 'localPort', 'type': 'str'}, + 'remote_port': {'key': 'remotePort', 'type': 'str'}, + 'local_ip_address': {'key': 'localIPAddress', 'type': 'str'}, + 'remote_ip_address': {'key': 'remoteIPAddress', 'type': 'str'}, + 'target_nic_resource_id': {'key': 'targetNicResourceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VerificationIPFlowParameters, self).__init__(**kwargs) + self.target_resource_id = kwargs['target_resource_id'] + self.direction = kwargs['direction'] + self.protocol = kwargs['protocol'] + self.local_port = kwargs['local_port'] + self.remote_port = kwargs['remote_port'] + self.local_ip_address = kwargs['local_ip_address'] + self.remote_ip_address = kwargs['remote_ip_address'] + self.target_nic_resource_id = kwargs.get('target_nic_resource_id', None) + + +class VerificationIPFlowResult(msrest.serialization.Model): + """Results of IP flow verification on the target resource. + + :param access: Indicates whether the traffic is allowed or denied. Possible values include: + "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param rule_name: Name of the rule. If input is not matched against any security rule, it is + not displayed. + :type rule_name: str + """ + + _attribute_map = { + 'access': {'key': 'access', 'type': 'str'}, + 'rule_name': {'key': 'ruleName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VerificationIPFlowResult, self).__init__(**kwargs) + self.access = kwargs.get('access', None) + self.rule_name = kwargs.get('rule_name', None) + + +class VirtualApplianceNicProperties(msrest.serialization.Model): + """Network Virtual Appliance NIC properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: NIC name. + :vartype name: str + :ivar public_ip_address: Public IP address. + :vartype public_ip_address: str + :ivar private_ip_address: Private IP address. + :vartype private_ip_address: str + """ + + _validation = { + 'name': {'readonly': True}, + 'public_ip_address': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplianceNicProperties, self).__init__(**kwargs) + self.name = None + self.public_ip_address = None + self.private_ip_address = None + + +class VirtualApplianceSite(SubResource): + """Virtual Appliance Site resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the virtual appliance site. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Site type. + :vartype type: str + :param address_prefix: Address Prefix. + :type address_prefix: str + :param o365_policy: Office 365 Policy. + :type o365_policy: ~azure.mgmt.network.v2020_08_01.models.Office365PolicyProperties + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'o365_policy': {'key': 'properties.o365Policy', 'type': 'Office365PolicyProperties'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplianceSite, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.address_prefix = kwargs.get('address_prefix', None) + self.o365_policy = kwargs.get('o365_policy', None) + self.provisioning_state = None + + +class VirtualApplianceSkuProperties(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param vendor: Virtual Appliance Vendor. + :type vendor: str + :param bundled_scale_unit: Virtual Appliance Scale Unit. + :type bundled_scale_unit: str + :param market_place_version: Virtual Appliance Version. + :type market_place_version: str + """ + + _attribute_map = { + 'vendor': {'key': 'vendor', 'type': 'str'}, + 'bundled_scale_unit': {'key': 'bundledScaleUnit', 'type': 'str'}, + 'market_place_version': {'key': 'marketPlaceVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplianceSkuProperties, self).__init__(**kwargs) + self.vendor = kwargs.get('vendor', None) + self.bundled_scale_unit = kwargs.get('bundled_scale_unit', None) + self.market_place_version = kwargs.get('market_place_version', None) + + +class VirtualHub(Resource): + """VirtualHub Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_wan: The VirtualWAN to which the VirtualHub belongs. + :type virtual_wan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param vpn_gateway: The VpnGateway associated with this VirtualHub. + :type vpn_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param p2_s_vpn_gateway: The P2SVpnGateway associated with this VirtualHub. + :type p2_s_vpn_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param express_route_gateway: The expressRouteGateway associated with this VirtualHub. + :type express_route_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param azure_firewall: The azureFirewall associated with this VirtualHub. + :type azure_firewall: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param security_partner_provider: The securityPartnerProvider associated with this VirtualHub. + :type security_partner_provider: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: Address-prefix for this VirtualHub. + :type address_prefix: str + :param route_table: The routeTable associated with this virtual hub. + :type route_table: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTable + :ivar provisioning_state: The provisioning state of the virtual hub resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param security_provider_name: The Security Provider name. + :type security_provider_name: str + :param virtual_hub_route_table_v2_s: List of all virtual hub route table v2s associated with + this VirtualHub. + :type virtual_hub_route_table_v2_s: + list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :param sku: The sku of this VirtualHub. + :type sku: str + :ivar routing_state: The routing state. Possible values include: "None", "Provisioned", + "Provisioning", "Failed". + :vartype routing_state: str or ~azure.mgmt.network.v2020_08_01.models.RoutingState + :ivar bgp_connections: List of references to Bgp Connections. + :vartype bgp_connections: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar ip_configurations: List of references to IpConfigurations. + :vartype ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param virtual_router_asn: VirtualRouter ASN. + :type virtual_router_asn: long + :param virtual_router_ips: VirtualRouter IPs. + :type virtual_router_ips: list[str] + :param allow_branch_to_branch_traffic: Flag to control transit for VirtualRouter hub. + :type allow_branch_to_branch_traffic: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'routing_state': {'readonly': True}, + 'bgp_connections': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'virtual_router_asn': {'maximum': 4294967295, 'minimum': 0}, + } + + _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'}, + 'virtual_wan': {'key': 'properties.virtualWan', 'type': 'SubResource'}, + 'vpn_gateway': {'key': 'properties.vpnGateway', 'type': 'SubResource'}, + 'p2_s_vpn_gateway': {'key': 'properties.p2SVpnGateway', 'type': 'SubResource'}, + 'express_route_gateway': {'key': 'properties.expressRouteGateway', 'type': 'SubResource'}, + 'azure_firewall': {'key': 'properties.azureFirewall', 'type': 'SubResource'}, + 'security_partner_provider': {'key': 'properties.securityPartnerProvider', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'route_table': {'key': 'properties.routeTable', 'type': 'VirtualHubRouteTable'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'security_provider_name': {'key': 'properties.securityProviderName', 'type': 'str'}, + 'virtual_hub_route_table_v2_s': {'key': 'properties.virtualHubRouteTableV2s', 'type': '[VirtualHubRouteTableV2]'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'routing_state': {'key': 'properties.routingState', 'type': 'str'}, + 'bgp_connections': {'key': 'properties.bgpConnections', 'type': '[SubResource]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[SubResource]'}, + 'virtual_router_asn': {'key': 'properties.virtualRouterAsn', 'type': 'long'}, + 'virtual_router_ips': {'key': 'properties.virtualRouterIps', 'type': '[str]'}, + 'allow_branch_to_branch_traffic': {'key': 'properties.allowBranchToBranchTraffic', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHub, self).__init__(**kwargs) + self.etag = None + self.virtual_wan = kwargs.get('virtual_wan', None) + self.vpn_gateway = kwargs.get('vpn_gateway', None) + self.p2_s_vpn_gateway = kwargs.get('p2_s_vpn_gateway', None) + self.express_route_gateway = kwargs.get('express_route_gateway', None) + self.azure_firewall = kwargs.get('azure_firewall', None) + self.security_partner_provider = kwargs.get('security_partner_provider', None) + self.address_prefix = kwargs.get('address_prefix', None) + self.route_table = kwargs.get('route_table', None) + self.provisioning_state = None + self.security_provider_name = kwargs.get('security_provider_name', None) + self.virtual_hub_route_table_v2_s = kwargs.get('virtual_hub_route_table_v2_s', None) + self.sku = kwargs.get('sku', None) + self.routing_state = None + self.bgp_connections = None + self.ip_configurations = None + self.virtual_router_asn = kwargs.get('virtual_router_asn', None) + self.virtual_router_ips = kwargs.get('virtual_router_ips', None) + self.allow_branch_to_branch_traffic = kwargs.get('allow_branch_to_branch_traffic', None) + + +class VirtualHubEffectiveRoute(msrest.serialization.Model): + """The effective route configured on the virtual hub or specified resource. + + :param address_prefixes: The list of address prefixes. + :type address_prefixes: list[str] + :param next_hops: The list of next hops. + :type next_hops: list[str] + :param next_hop_type: The type of the next hop. + :type next_hop_type: str + :param as_path: The ASPath of this route. + :type as_path: str + :param route_origin: The origin of this route. + :type route_origin: str + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hops': {'key': 'nextHops', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'route_origin': {'key': 'routeOrigin', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubEffectiveRoute, self).__init__(**kwargs) + self.address_prefixes = kwargs.get('address_prefixes', None) + self.next_hops = kwargs.get('next_hops', None) + self.next_hop_type = kwargs.get('next_hop_type', None) + self.as_path = kwargs.get('as_path', None) + self.route_origin = kwargs.get('route_origin', None) + + +class VirtualHubEffectiveRouteList(msrest.serialization.Model): + """EffectiveRoutes List. + + :param value: The list of effective routes configured on the virtual hub or the specified + resource. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubEffectiveRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualHubEffectiveRoute]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubEffectiveRouteList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class VirtualHubId(msrest.serialization.Model): + """Virtual Hub identifier. + + :param id: The resource URI for the Virtual Hub where the ExpressRoute gateway is or will be + deployed. The Virtual Hub resource and the ExpressRoute gateway resource reside in the same + subscription. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubId, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class VirtualHubRoute(msrest.serialization.Model): + """VirtualHub route. + + :param address_prefixes: List of all addressPrefixes. + :type address_prefixes: list[str] + :param next_hop_ip_address: NextHop ip address. + :type next_hop_ip_address: str + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubRoute, self).__init__(**kwargs) + self.address_prefixes = kwargs.get('address_prefixes', None) + self.next_hop_ip_address = kwargs.get('next_hop_ip_address', None) + + +class VirtualHubRouteTable(msrest.serialization.Model): + """VirtualHub route table. + + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRoute] + """ + + _attribute_map = { + 'routes': {'key': 'routes', 'type': '[VirtualHubRoute]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubRouteTable, self).__init__(**kwargs) + self.routes = kwargs.get('routes', None) + + +class VirtualHubRouteTableV2(SubResource): + """VirtualHubRouteTableV2 Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteV2] + :param attached_connections: List of all connections attached to this route table v2. + :type attached_connections: list[str] + :ivar provisioning_state: The provisioning state of the virtual hub route table v2 resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VirtualHubRouteV2]'}, + 'attached_connections': {'key': 'properties.attachedConnections', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubRouteTableV2, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.routes = kwargs.get('routes', None) + self.attached_connections = kwargs.get('attached_connections', None) + self.provisioning_state = None + + +class VirtualHubRouteV2(msrest.serialization.Model): + """VirtualHubRouteTableV2 route. + + :param destination_type: The type of destinations. + :type destination_type: str + :param destinations: List of all destinations. + :type destinations: list[str] + :param next_hop_type: The type of next hops. + :type next_hop_type: str + :param next_hops: NextHops ip address. + :type next_hops: list[str] + """ + + _attribute_map = { + 'destination_type': {'key': 'destinationType', 'type': 'str'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hops': {'key': 'nextHops', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualHubRouteV2, self).__init__(**kwargs) + self.destination_type = kwargs.get('destination_type', None) + self.destinations = kwargs.get('destinations', None) + self.next_hop_type = kwargs.get('next_hop_type', None) + self.next_hops = kwargs.get('next_hops', None) + + +class VirtualNetwork(Resource): + """Virtual Network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the virtual network. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param address_space: The AddressSpace that contains an array of IP address ranges that can be + used by subnets. + :type address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param dhcp_options: The dhcpOptions that contains an array of DNS servers available to VMs + deployed in the virtual network. + :type dhcp_options: ~azure.mgmt.network.v2020_08_01.models.DhcpOptions + :param subnets: A list of subnets in a Virtual Network. + :type subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param virtual_network_peerings: A list of peerings in a Virtual Network. + :type virtual_network_peerings: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :ivar resource_guid: The resourceGuid property of the Virtual Network resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param enable_ddos_protection: Indicates if DDoS protection is enabled for all the protected + resources in the virtual network. It requires a DDoS protection plan associated with the + resource. + :type enable_ddos_protection: bool + :param enable_vm_protection: Indicates if VM protection is enabled for all the subnets in the + virtual network. + :type enable_vm_protection: bool + :param ddos_protection_plan: The DDoS protection plan associated with the virtual network. + :type ddos_protection_plan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param bgp_communities: Bgp Communities sent over ExpressRoute with each route corresponding to + a prefix in this VNET. + :type bgp_communities: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkBgpCommunities + :param ip_allocations: Array of IpAllocation which reference this VNET. + :type ip_allocations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'address_space': {'key': 'properties.addressSpace', 'type': 'AddressSpace'}, + 'dhcp_options': {'key': 'properties.dhcpOptions', 'type': 'DhcpOptions'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'virtual_network_peerings': {'key': 'properties.virtualNetworkPeerings', 'type': '[VirtualNetworkPeering]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'enable_ddos_protection': {'key': 'properties.enableDdosProtection', 'type': 'bool'}, + 'enable_vm_protection': {'key': 'properties.enableVmProtection', 'type': 'bool'}, + 'ddos_protection_plan': {'key': 'properties.ddosProtectionPlan', 'type': 'SubResource'}, + 'bgp_communities': {'key': 'properties.bgpCommunities', 'type': 'VirtualNetworkBgpCommunities'}, + 'ip_allocations': {'key': 'properties.ipAllocations', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetwork, self).__init__(**kwargs) + self.extended_location = kwargs.get('extended_location', None) + self.etag = None + self.address_space = kwargs.get('address_space', None) + self.dhcp_options = kwargs.get('dhcp_options', None) + self.subnets = kwargs.get('subnets', None) + self.virtual_network_peerings = kwargs.get('virtual_network_peerings', None) + self.resource_guid = None + self.provisioning_state = None + self.enable_ddos_protection = kwargs.get('enable_ddos_protection', False) + self.enable_vm_protection = kwargs.get('enable_vm_protection', False) + self.ddos_protection_plan = kwargs.get('ddos_protection_plan', None) + self.bgp_communities = kwargs.get('bgp_communities', None) + self.ip_allocations = kwargs.get('ip_allocations', None) + + +class VirtualNetworkBgpCommunities(msrest.serialization.Model): + """Bgp Communities sent over ExpressRoute with each route corresponding to a prefix in this VNET. + + Variables are only 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 virtual_network_community: Required. The BGP community associated with the virtual + network. + :type virtual_network_community: str + :ivar regional_community: The BGP community associated with the region of the virtual network. + :vartype regional_community: str + """ + + _validation = { + 'virtual_network_community': {'required': True}, + 'regional_community': {'readonly': True}, + } + + _attribute_map = { + 'virtual_network_community': {'key': 'virtualNetworkCommunity', 'type': 'str'}, + 'regional_community': {'key': 'regionalCommunity', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkBgpCommunities, self).__init__(**kwargs) + self.virtual_network_community = kwargs['virtual_network_community'] + self.regional_community = None + + +class VirtualNetworkConnectionGatewayReference(msrest.serialization.Model): + """A reference to VirtualNetworkGateway or LocalNetworkGateway resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. The ID of VirtualNetworkGateway or LocalNetworkGateway resource. + :type id: str + """ + + _validation = { + 'id': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkConnectionGatewayReference, self).__init__(**kwargs) + self.id = kwargs['id'] + + +class VirtualNetworkGateway(Resource): + """A common class for general resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: IP configurations for virtual network gateway. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayIPConfiguration] + :param gateway_type: The type of this virtual network gateway. Possible values include: "Vpn", + "ExpressRoute", "LocalGateway". + :type gateway_type: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayType + :param vpn_type: The type of this virtual network gateway. Possible values include: + "PolicyBased", "RouteBased". + :type vpn_type: str or ~azure.mgmt.network.v2020_08_01.models.VpnType + :param vpn_gateway_generation: The generation for this VirtualNetworkGateway. Must be None if + gatewayType is not VPN. Possible values include: "None", "Generation1", "Generation2". + :type vpn_gateway_generation: str or + ~azure.mgmt.network.v2020_08_01.models.VpnGatewayGeneration + :param enable_bgp: Whether BGP is enabled for this virtual network gateway or not. + :type enable_bgp: bool + :param enable_private_ip_address: Whether private IP needs to be enabled on this gateway for + connections or not. + :type enable_private_ip_address: bool + :param active: ActiveActive flag. + :type active: bool + :param gateway_default_site: The reference to the LocalNetworkGateway resource which represents + local network site having default routes. Assign Null value in case of removing existing + default site setting. + :type gateway_default_site: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param sku: The reference to the VirtualNetworkGatewaySku resource which represents the SKU + selected for Virtual network gateway. + :type sku: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySku + :param vpn_client_configuration: The reference to the VpnClientConfiguration resource which + represents the P2S VpnClient configurations. + :type vpn_client_configuration: ~azure.mgmt.network.v2020_08_01.models.VpnClientConfiguration + :param bgp_settings: Virtual network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :param custom_routes: The reference to the address space resource which represents the custom + routes address space specified by the customer for virtual network gateway and VpnClient. + :type custom_routes: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :ivar resource_guid: The resource GUID property of the virtual network gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param enable_dns_forwarding: Whether dns forwarding is enabled or not. + :type enable_dns_forwarding: bool + :ivar inbound_dns_forwarding_endpoint: The IP address allocated by the gateway to which dns + requests can be sent. + :vartype inbound_dns_forwarding_endpoint: str + :param virtual_network_extended_location_resource_id: MAS FIJI customer vnet resource id. + VirtualNetworkGateway of type local gateway is associated with the customer vnet. + :type virtual_network_extended_location_resource_id: str + :param extended_location: The extended location of type local virtual network gateway. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'inbound_dns_forwarding_endpoint': {'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'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[VirtualNetworkGatewayIPConfiguration]'}, + 'gateway_type': {'key': 'properties.gatewayType', 'type': 'str'}, + 'vpn_type': {'key': 'properties.vpnType', 'type': 'str'}, + 'vpn_gateway_generation': {'key': 'properties.vpnGatewayGeneration', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'enable_private_ip_address': {'key': 'properties.enablePrivateIpAddress', 'type': 'bool'}, + 'active': {'key': 'properties.activeActive', 'type': 'bool'}, + 'gateway_default_site': {'key': 'properties.gatewayDefaultSite', 'type': 'SubResource'}, + 'sku': {'key': 'properties.sku', 'type': 'VirtualNetworkGatewaySku'}, + 'vpn_client_configuration': {'key': 'properties.vpnClientConfiguration', 'type': 'VpnClientConfiguration'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'custom_routes': {'key': 'properties.customRoutes', 'type': 'AddressSpace'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'enable_dns_forwarding': {'key': 'properties.enableDnsForwarding', 'type': 'bool'}, + 'inbound_dns_forwarding_endpoint': {'key': 'properties.inboundDnsForwardingEndpoint', 'type': 'str'}, + 'virtual_network_extended_location_resource_id': {'key': 'properties.virtualNetworkExtendedLocationResourceId', 'type': 'str'}, + 'extended_location': {'key': 'properties.extendedLocation', 'type': 'ExtendedLocation'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGateway, self).__init__(**kwargs) + self.etag = None + self.ip_configurations = kwargs.get('ip_configurations', None) + self.gateway_type = kwargs.get('gateway_type', None) + self.vpn_type = kwargs.get('vpn_type', None) + self.vpn_gateway_generation = kwargs.get('vpn_gateway_generation', None) + self.enable_bgp = kwargs.get('enable_bgp', None) + self.enable_private_ip_address = kwargs.get('enable_private_ip_address', None) + self.active = kwargs.get('active', None) + self.gateway_default_site = kwargs.get('gateway_default_site', None) + self.sku = kwargs.get('sku', None) + self.vpn_client_configuration = kwargs.get('vpn_client_configuration', None) + self.bgp_settings = kwargs.get('bgp_settings', None) + self.custom_routes = kwargs.get('custom_routes', None) + self.resource_guid = None + self.provisioning_state = None + self.enable_dns_forwarding = kwargs.get('enable_dns_forwarding', None) + self.inbound_dns_forwarding_endpoint = None + self.virtual_network_extended_location_resource_id = kwargs.get('virtual_network_extended_location_resource_id', None) + self.extended_location = kwargs.get('extended_location', None) + + +class VirtualNetworkGatewayConnection(Resource): + """A common class for general resource 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 id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param authorization_key: The authorizationKey. + :type authorization_key: str + :param virtual_network_gateway1: Required. The reference to virtual network gateway resource. + :type virtual_network_gateway1: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :param virtual_network_gateway2: The reference to virtual network gateway resource. + :type virtual_network_gateway2: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :param local_network_gateway2: The reference to local network gateway resource. + :type local_network_gateway2: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :param connection_type: Required. Gateway connection type. Possible values include: "IPsec", + "Vnet2Vnet", "ExpressRoute", "VPNClient". + :type connection_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionType + :param connection_protocol: Connection protocol used for this connection. Possible values + include: "IKEv2", "IKEv1". + :type connection_protocol: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :param routing_weight: The routing weight. + :type routing_weight: int + :param dpd_timeout_seconds: The dead peer detection timeout of this connection in seconds. + :type dpd_timeout_seconds: int + :param connection_mode: The connection mode for this connection. Possible values include: + "Default", "ResponderOnly", "InitiatorOnly". + :type connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionMode + :param shared_key: The IPSec shared key. + :type shared_key: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar tunnel_connection_status: Collection of all tunnels' connection health status. + :vartype tunnel_connection_status: + list[~azure.mgmt.network.v2020_08_01.models.TunnelConnectionHealth] + :ivar egress_bytes_transferred: The egress bytes transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes transferred in this connection. + :vartype ingress_bytes_transferred: long + :param peer: The reference to peerings resource. + :type peer: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_local_azure_ip_address: Use private local Azure IP for the connection. + :type use_local_azure_ip_address: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param traffic_selector_policies: The Traffic Selector Policies to be considered by this + connection. + :type traffic_selector_policies: + list[~azure.mgmt.network.v2020_08_01.models.TrafficSelectorPolicy] + :ivar resource_guid: The resource GUID property of the virtual network gateway connection + resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_gateway_bypass: Bypass ExpressRoute Gateway for data forwarding. + :type express_route_gateway_bypass: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_network_gateway1': {'required': True}, + 'connection_type': {'required': True}, + 'connection_status': {'readonly': True}, + 'tunnel_connection_status': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'resource_guid': {'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'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'virtual_network_gateway1': {'key': 'properties.virtualNetworkGateway1', 'type': 'VirtualNetworkGateway'}, + 'virtual_network_gateway2': {'key': 'properties.virtualNetworkGateway2', 'type': 'VirtualNetworkGateway'}, + 'local_network_gateway2': {'key': 'properties.localNetworkGateway2', 'type': 'LocalNetworkGateway'}, + 'connection_type': {'key': 'properties.connectionType', 'type': 'str'}, + 'connection_protocol': {'key': 'properties.connectionProtocol', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'dpd_timeout_seconds': {'key': 'properties.dpdTimeoutSeconds', 'type': 'int'}, + 'connection_mode': {'key': 'properties.connectionMode', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'tunnel_connection_status': {'key': 'properties.tunnelConnectionStatus', 'type': '[TunnelConnectionHealth]'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'peer': {'key': 'properties.peer', 'type': 'SubResource'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'traffic_selector_policies': {'key': 'properties.trafficSelectorPolicies', 'type': '[TrafficSelectorPolicy]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayConnection, self).__init__(**kwargs) + self.etag = None + self.authorization_key = kwargs.get('authorization_key', None) + self.virtual_network_gateway1 = kwargs['virtual_network_gateway1'] + self.virtual_network_gateway2 = kwargs.get('virtual_network_gateway2', None) + self.local_network_gateway2 = kwargs.get('local_network_gateway2', None) + self.connection_type = kwargs['connection_type'] + self.connection_protocol = kwargs.get('connection_protocol', None) + self.routing_weight = kwargs.get('routing_weight', None) + self.dpd_timeout_seconds = kwargs.get('dpd_timeout_seconds', None) + self.connection_mode = kwargs.get('connection_mode', None) + self.shared_key = kwargs.get('shared_key', None) + self.connection_status = None + self.tunnel_connection_status = None + self.egress_bytes_transferred = None + self.ingress_bytes_transferred = None + self.peer = kwargs.get('peer', None) + self.enable_bgp = kwargs.get('enable_bgp', None) + self.use_local_azure_ip_address = kwargs.get('use_local_azure_ip_address', None) + self.use_policy_based_traffic_selectors = kwargs.get('use_policy_based_traffic_selectors', None) + self.ipsec_policies = kwargs.get('ipsec_policies', None) + self.traffic_selector_policies = kwargs.get('traffic_selector_policies', None) + self.resource_guid = None + self.provisioning_state = None + self.express_route_gateway_bypass = kwargs.get('express_route_gateway_bypass', None) + + +class VirtualNetworkGatewayConnectionListEntity(Resource): + """A common class for general resource 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 id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param authorization_key: The authorizationKey. + :type authorization_key: str + :param virtual_network_gateway1: Required. The reference to virtual network gateway resource. + :type virtual_network_gateway1: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param virtual_network_gateway2: The reference to virtual network gateway resource. + :type virtual_network_gateway2: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param local_network_gateway2: The reference to local network gateway resource. + :type local_network_gateway2: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param connection_type: Required. Gateway connection type. Possible values include: "IPsec", + "Vnet2Vnet", "ExpressRoute", "VPNClient". + :type connection_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionType + :param connection_protocol: Connection protocol used for this connection. Possible values + include: "IKEv2", "IKEv1". + :type connection_protocol: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :param routing_weight: The routing weight. + :type routing_weight: int + :param connection_mode: The connection mode for this connection. Possible values include: + "Default", "ResponderOnly", "InitiatorOnly". + :type connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionMode + :param shared_key: The IPSec shared key. + :type shared_key: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar tunnel_connection_status: Collection of all tunnels' connection health status. + :vartype tunnel_connection_status: + list[~azure.mgmt.network.v2020_08_01.models.TunnelConnectionHealth] + :ivar egress_bytes_transferred: The egress bytes transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes transferred in this connection. + :vartype ingress_bytes_transferred: long + :param peer: The reference to peerings resource. + :type peer: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param traffic_selector_policies: The Traffic Selector Policies to be considered by this + connection. + :type traffic_selector_policies: + list[~azure.mgmt.network.v2020_08_01.models.TrafficSelectorPolicy] + :ivar resource_guid: The resource GUID property of the virtual network gateway connection + resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_gateway_bypass: Bypass ExpressRoute Gateway for data forwarding. + :type express_route_gateway_bypass: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_network_gateway1': {'required': True}, + 'connection_type': {'required': True}, + 'connection_status': {'readonly': True}, + 'tunnel_connection_status': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'resource_guid': {'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'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'virtual_network_gateway1': {'key': 'properties.virtualNetworkGateway1', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'virtual_network_gateway2': {'key': 'properties.virtualNetworkGateway2', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'local_network_gateway2': {'key': 'properties.localNetworkGateway2', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'connection_type': {'key': 'properties.connectionType', 'type': 'str'}, + 'connection_protocol': {'key': 'properties.connectionProtocol', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'connection_mode': {'key': 'properties.connectionMode', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'tunnel_connection_status': {'key': 'properties.tunnelConnectionStatus', 'type': '[TunnelConnectionHealth]'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'peer': {'key': 'properties.peer', 'type': 'SubResource'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'traffic_selector_policies': {'key': 'properties.trafficSelectorPolicies', 'type': '[TrafficSelectorPolicy]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayConnectionListEntity, self).__init__(**kwargs) + self.etag = None + self.authorization_key = kwargs.get('authorization_key', None) + self.virtual_network_gateway1 = kwargs['virtual_network_gateway1'] + self.virtual_network_gateway2 = kwargs.get('virtual_network_gateway2', None) + self.local_network_gateway2 = kwargs.get('local_network_gateway2', None) + self.connection_type = kwargs['connection_type'] + self.connection_protocol = kwargs.get('connection_protocol', None) + self.routing_weight = kwargs.get('routing_weight', None) + self.connection_mode = kwargs.get('connection_mode', None) + self.shared_key = kwargs.get('shared_key', None) + self.connection_status = None + self.tunnel_connection_status = None + self.egress_bytes_transferred = None + self.ingress_bytes_transferred = None + self.peer = kwargs.get('peer', None) + self.enable_bgp = kwargs.get('enable_bgp', None) + self.use_policy_based_traffic_selectors = kwargs.get('use_policy_based_traffic_selectors', None) + self.ipsec_policies = kwargs.get('ipsec_policies', None) + self.traffic_selector_policies = kwargs.get('traffic_selector_policies', None) + self.resource_guid = None + self.provisioning_state = None + self.express_route_gateway_bypass = kwargs.get('express_route_gateway_bypass', None) + + +class VirtualNetworkGatewayConnectionListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworkGatewayConnections API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGatewayConnection resources that exists in a resource + group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGatewayConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayConnectionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class VirtualNetworkGatewayIPConfiguration(SubResource): + """IP configuration for virtual network gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar private_ip_address: Private IP Address for this gateway. + :vartype private_ip_address: str + :ivar provisioning_state: The provisioning state of the virtual network gateway IP + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayIPConfiguration, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.private_ip_allocation_method = kwargs.get('private_ip_allocation_method', None) + self.subnet = kwargs.get('subnet', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.private_ip_address = None + self.provisioning_state = None + + +class VirtualNetworkGatewayListConnectionsResult(msrest.serialization.Model): + """Response for the VirtualNetworkGatewayListConnections API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGatewayConnection resources that exists in a resource + group. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionListEntity] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGatewayConnectionListEntity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayListConnectionsResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class VirtualNetworkGatewayListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworkGateways API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGateway resources that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewayListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class VirtualNetworkGatewaySku(msrest.serialization.Model): + """VirtualNetworkGatewaySku details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Gateway SKU name. Possible values include: "Basic", "HighPerformance", "Standard", + "UltraPerformance", "VpnGw1", "VpnGw2", "VpnGw3", "VpnGw4", "VpnGw5", "VpnGw1AZ", "VpnGw2AZ", + "VpnGw3AZ", "VpnGw4AZ", "VpnGw5AZ", "ErGw1AZ", "ErGw2AZ", "ErGw3AZ". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySkuName + :param tier: Gateway SKU tier. Possible values include: "Basic", "HighPerformance", "Standard", + "UltraPerformance", "VpnGw1", "VpnGw2", "VpnGw3", "VpnGw4", "VpnGw5", "VpnGw1AZ", "VpnGw2AZ", + "VpnGw3AZ", "VpnGw4AZ", "VpnGw5AZ", "ErGw1AZ", "ErGw2AZ", "ErGw3AZ". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySkuTier + :ivar capacity: The capacity. + :vartype capacity: int + """ + + _validation = { + 'capacity': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkGatewaySku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.capacity = None + + +class VirtualNetworkListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworks API service call. + + :param value: A list of VirtualNetwork resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetwork] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetwork]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VirtualNetworkListUsageResult(msrest.serialization.Model): + """Response for the virtual networks GetUsage API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar value: VirtualNetwork usage stats. + :vartype value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkUsage] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _validation = { + 'value': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkUsage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkListUsageResult, self).__init__(**kwargs) + self.value = None + self.next_link = kwargs.get('next_link', None) + + +class VirtualNetworkPeering(SubResource): + """Peerings in a virtual network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param allow_virtual_network_access: Whether the VMs in the local virtual network space would + be able to access the VMs in remote virtual network space. + :type allow_virtual_network_access: bool + :param allow_forwarded_traffic: Whether the forwarded traffic from the VMs in the local virtual + network will be allowed/disallowed in remote virtual network. + :type allow_forwarded_traffic: bool + :param allow_gateway_transit: If gateway links can be used in remote virtual networking to link + to this virtual network. + :type allow_gateway_transit: bool + :param use_remote_gateways: If remote gateways can be used on this virtual network. If the flag + is set to true, and allowGatewayTransit on remote peering is also true, virtual network will + use gateways of remote virtual network for transit. Only one peering can have this flag set to + true. This flag cannot be set if virtual network already has a gateway. + :type use_remote_gateways: bool + :param remote_virtual_network: The reference to the remote virtual network. The remote virtual + network can be in the same or different region (preview). See here to register for the preview + and learn more (https://docs.microsoft.com/en-us/azure/virtual-network/virtual-network-create- + peering). + :type remote_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param remote_address_space: The reference to the remote virtual network address space. + :type remote_address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param remote_bgp_communities: The reference to the remote virtual network's Bgp Communities. + :type remote_bgp_communities: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkBgpCommunities + :param peering_state: The status of the virtual network peering. Possible values include: + "Initiated", "Connected", "Disconnected". + :type peering_state: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeeringState + :ivar provisioning_state: The provisioning state of the virtual network peering resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'allow_virtual_network_access': {'key': 'properties.allowVirtualNetworkAccess', 'type': 'bool'}, + 'allow_forwarded_traffic': {'key': 'properties.allowForwardedTraffic', 'type': 'bool'}, + 'allow_gateway_transit': {'key': 'properties.allowGatewayTransit', 'type': 'bool'}, + 'use_remote_gateways': {'key': 'properties.useRemoteGateways', 'type': 'bool'}, + 'remote_virtual_network': {'key': 'properties.remoteVirtualNetwork', 'type': 'SubResource'}, + 'remote_address_space': {'key': 'properties.remoteAddressSpace', 'type': 'AddressSpace'}, + 'remote_bgp_communities': {'key': 'properties.remoteBgpCommunities', 'type': 'VirtualNetworkBgpCommunities'}, + 'peering_state': {'key': 'properties.peeringState', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkPeering, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.allow_virtual_network_access = kwargs.get('allow_virtual_network_access', None) + self.allow_forwarded_traffic = kwargs.get('allow_forwarded_traffic', None) + self.allow_gateway_transit = kwargs.get('allow_gateway_transit', None) + self.use_remote_gateways = kwargs.get('use_remote_gateways', None) + self.remote_virtual_network = kwargs.get('remote_virtual_network', None) + self.remote_address_space = kwargs.get('remote_address_space', None) + self.remote_bgp_communities = kwargs.get('remote_bgp_communities', None) + self.peering_state = kwargs.get('peering_state', None) + self.provisioning_state = None + + +class VirtualNetworkPeeringListResult(msrest.serialization.Model): + """Response for ListSubnets API service call. Retrieves all subnets that belong to a virtual network. + + :param value: The peerings in a virtual network. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkPeeringListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VirtualNetworkTap(Resource): + """Virtual Network Tap resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar network_interface_tap_configurations: Specifies the list of resource IDs for the network + interface IP configuration that needs to be tapped. + :vartype network_interface_tap_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :ivar resource_guid: The resource GUID property of the virtual network tap resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network tap resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param destination_network_interface_ip_configuration: The reference to the private IP Address + of the collector nic that will receive the tap. + :type destination_network_interface_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param destination_load_balancer_front_end_ip_configuration: The reference to the private IP + address on the internal Load Balancer that will receive the tap. + :type destination_load_balancer_front_end_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration + :param destination_port: The VXLAN destination port that will receive the tapped traffic. + :type destination_port: int + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interface_tap_configurations': {'readonly': True}, + 'resource_guid': {'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'}, + 'network_interface_tap_configurations': {'key': 'properties.networkInterfaceTapConfigurations', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'destination_network_interface_ip_configuration': {'key': 'properties.destinationNetworkInterfaceIPConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'destination_load_balancer_front_end_ip_configuration': {'key': 'properties.destinationLoadBalancerFrontEndIPConfiguration', 'type': 'FrontendIPConfiguration'}, + 'destination_port': {'key': 'properties.destinationPort', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkTap, self).__init__(**kwargs) + self.etag = None + self.network_interface_tap_configurations = None + self.resource_guid = None + self.provisioning_state = None + self.destination_network_interface_ip_configuration = kwargs.get('destination_network_interface_ip_configuration', None) + self.destination_load_balancer_front_end_ip_configuration = kwargs.get('destination_load_balancer_front_end_ip_configuration', None) + self.destination_port = kwargs.get('destination_port', None) + + +class VirtualNetworkTapListResult(msrest.serialization.Model): + """Response for ListVirtualNetworkTap API service call. + + :param value: A list of VirtualNetworkTaps in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkTap]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkTapListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VirtualNetworkUsage(msrest.serialization.Model): + """Usage details for subnet. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar current_value: Indicates number of IPs used from the Subnet. + :vartype current_value: float + :ivar id: Subnet identifier. + :vartype id: str + :ivar limit: Indicates the size of the subnet. + :vartype limit: float + :ivar name: The name containing common and localized value for usage. + :vartype name: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkUsageName + :ivar unit: Usage units. Returns 'Count'. + :vartype unit: str + """ + + _validation = { + 'current_value': {'readonly': True}, + 'id': {'readonly': True}, + 'limit': {'readonly': True}, + 'name': {'readonly': True}, + 'unit': {'readonly': True}, + } + + _attribute_map = { + 'current_value': {'key': 'currentValue', 'type': 'float'}, + 'id': {'key': 'id', 'type': 'str'}, + 'limit': {'key': 'limit', 'type': 'float'}, + 'name': {'key': 'name', 'type': 'VirtualNetworkUsageName'}, + 'unit': {'key': 'unit', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkUsage, self).__init__(**kwargs) + self.current_value = None + self.id = None + self.limit = None + self.name = None + self.unit = None + + +class VirtualNetworkUsageName(msrest.serialization.Model): + """Usage strings container. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar localized_value: Localized subnet size and usage string. + :vartype localized_value: str + :ivar value: Subnet size and usage string. + :vartype value: str + """ + + _validation = { + 'localized_value': {'readonly': True}, + 'value': {'readonly': True}, + } + + _attribute_map = { + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkUsageName, self).__init__(**kwargs) + self.localized_value = None + self.value = None + + +class VirtualRouter(Resource): + """VirtualRouter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_router_asn: VirtualRouter ASN. + :type virtual_router_asn: long + :param virtual_router_ips: VirtualRouter IPs. + :type virtual_router_ips: list[str] + :param hosted_subnet: The Subnet on which VirtualRouter is hosted. + :type hosted_subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param hosted_gateway: The Gateway on which VirtualRouter is hosted. + :type hosted_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar peerings: List of references to VirtualRouterPeerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_router_asn': {'maximum': 4294967295, 'minimum': 0}, + 'peerings': {'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'}, + 'virtual_router_asn': {'key': 'properties.virtualRouterAsn', 'type': 'long'}, + 'virtual_router_ips': {'key': 'properties.virtualRouterIps', 'type': '[str]'}, + 'hosted_subnet': {'key': 'properties.hostedSubnet', 'type': 'SubResource'}, + 'hosted_gateway': {'key': 'properties.hostedGateway', 'type': 'SubResource'}, + 'peerings': {'key': 'properties.peerings', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualRouter, self).__init__(**kwargs) + self.etag = None + self.virtual_router_asn = kwargs.get('virtual_router_asn', None) + self.virtual_router_ips = kwargs.get('virtual_router_ips', None) + self.hosted_subnet = kwargs.get('hosted_subnet', None) + self.hosted_gateway = kwargs.get('hosted_gateway', None) + self.peerings = None + self.provisioning_state = None + + +class VirtualRouterListResult(msrest.serialization.Model): + """Response for ListVirtualRouters API service call. + + :param value: List of Virtual Routers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualRouter] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualRouter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualRouterListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VirtualRouterPeering(SubResource): + """Virtual Router Peering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the virtual router peering that is unique within a virtual router. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Peering type. + :vartype type: str + :param peer_asn: Peer ASN. + :type peer_asn: long + :param peer_ip: Peer IP. + :type peer_ip: str + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peer_asn': {'key': 'properties.peerAsn', 'type': 'long'}, + 'peer_ip': {'key': 'properties.peerIp', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualRouterPeering, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.peer_asn = kwargs.get('peer_asn', None) + self.peer_ip = kwargs.get('peer_ip', None) + self.provisioning_state = None + + +class VirtualRouterPeeringListResult(msrest.serialization.Model): + """Response for ListVirtualRouterPeerings API service call. + + :param value: List of VirtualRouterPeerings in a VirtualRouter. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualRouterPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualRouterPeeringListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class VirtualWAN(Resource): + """VirtualWAN Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param disable_vpn_encryption: Vpn encryption to be disabled or not. + :type disable_vpn_encryption: bool + :ivar virtual_hubs: List of VirtualHubs in the VirtualWAN. + :vartype virtual_hubs: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar vpn_sites: List of VpnSites in the VirtualWAN. + :vartype vpn_sites: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param allow_branch_to_branch_traffic: True if branch to branch traffic is allowed. + :type allow_branch_to_branch_traffic: bool + :param allow_vnet_to_vnet_traffic: True if Vnet to Vnet traffic is allowed. + :type allow_vnet_to_vnet_traffic: bool + :ivar office365_local_breakout_category: The office local breakout category. Possible values + include: "Optimize", "OptimizeAndAllow", "All", "None". + :vartype office365_local_breakout_category: str or + ~azure.mgmt.network.v2020_08_01.models.OfficeTrafficCategory + :ivar provisioning_state: The provisioning state of the virtual WAN resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param type_properties_type: The type of the VirtualWAN. + :type type_properties_type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_hubs': {'readonly': True}, + 'vpn_sites': {'readonly': True}, + 'office365_local_breakout_category': {'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'}, + 'disable_vpn_encryption': {'key': 'properties.disableVpnEncryption', 'type': 'bool'}, + 'virtual_hubs': {'key': 'properties.virtualHubs', 'type': '[SubResource]'}, + 'vpn_sites': {'key': 'properties.vpnSites', 'type': '[SubResource]'}, + 'allow_branch_to_branch_traffic': {'key': 'properties.allowBranchToBranchTraffic', 'type': 'bool'}, + 'allow_vnet_to_vnet_traffic': {'key': 'properties.allowVnetToVnetTraffic', 'type': 'bool'}, + 'office365_local_breakout_category': {'key': 'properties.office365LocalBreakoutCategory', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualWAN, self).__init__(**kwargs) + self.etag = None + self.disable_vpn_encryption = kwargs.get('disable_vpn_encryption', None) + self.virtual_hubs = None + self.vpn_sites = None + self.allow_branch_to_branch_traffic = kwargs.get('allow_branch_to_branch_traffic', None) + self.allow_vnet_to_vnet_traffic = kwargs.get('allow_vnet_to_vnet_traffic', None) + self.office365_local_breakout_category = None + self.provisioning_state = None + self.type_properties_type = kwargs.get('type_properties_type', None) + + +class VirtualWanSecurityProvider(msrest.serialization.Model): + """Collection of SecurityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the security provider. + :type name: str + :param url: Url of the security provider. + :type url: str + :ivar type: Name of the security provider. Possible values include: "External", "Native". + :vartype type: str or ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviderType + """ + + _validation = { + 'type': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualWanSecurityProvider, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.url = kwargs.get('url', None) + self.type = None + + +class VirtualWanSecurityProviders(msrest.serialization.Model): + """Collection of SecurityProviders. + + :param supported_providers: List of VirtualWAN security providers. + :type supported_providers: + list[~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProvider] + """ + + _attribute_map = { + 'supported_providers': {'key': 'supportedProviders', 'type': '[VirtualWanSecurityProvider]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualWanSecurityProviders, self).__init__(**kwargs) + self.supported_providers = kwargs.get('supported_providers', None) + + +class VirtualWanVpnProfileParameters(msrest.serialization.Model): + """Virtual Wan Vpn profile parameters Vpn profile generation. + + :param vpn_server_configuration_resource_id: VpnServerConfiguration partial resource uri with + which VirtualWan is associated to. + :type vpn_server_configuration_resource_id: str + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + """ + + _attribute_map = { + 'vpn_server_configuration_resource_id': {'key': 'vpnServerConfigurationResourceId', 'type': 'str'}, + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualWanVpnProfileParameters, self).__init__(**kwargs) + self.vpn_server_configuration_resource_id = kwargs.get('vpn_server_configuration_resource_id', None) + self.authentication_method = kwargs.get('authentication_method', None) + + +class VM(Resource): + """Describes a Virtual Machine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 = { + '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(VM, self).__init__(**kwargs) + + +class VnetRoute(msrest.serialization.Model): + """List of routes that control routing from VirtualHub into a virtual network connection. + + :param static_routes: List of all Static Routes. + :type static_routes: list[~azure.mgmt.network.v2020_08_01.models.StaticRoute] + """ + + _attribute_map = { + 'static_routes': {'key': 'staticRoutes', 'type': '[StaticRoute]'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetRoute, self).__init__(**kwargs) + self.static_routes = kwargs.get('static_routes', None) + + +class VpnClientConfiguration(msrest.serialization.Model): + """VpnClientConfiguration for P2S client. + + :param vpn_client_address_pool: The reference to the address space resource which represents + Address space for P2S VpnClient. + :type vpn_client_address_pool: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param vpn_client_root_certificates: VpnClientRootCertificate for virtual network gateway. + :type vpn_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnClientRootCertificate] + :param vpn_client_revoked_certificates: VpnClientRevokedCertificate for Virtual network + gateway. + :type vpn_client_revoked_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnClientRevokedCertificate] + :param vpn_client_protocols: VpnClientProtocols for Virtual network gateway. + :type vpn_client_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnClientProtocol] + :param vpn_client_ipsec_policies: VpnClientIpsecPolicies for virtual network gateway P2S + client. + :type vpn_client_ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param radius_server_address: The radius server address property of the VirtualNetworkGateway + resource for vpn client connection. + :type radius_server_address: str + :param radius_server_secret: The radius secret property of the VirtualNetworkGateway resource + for vpn client connection. + :type radius_server_secret: str + :param radius_servers: The radiusServers property for multiple radius server configuration. + :type radius_servers: list[~azure.mgmt.network.v2020_08_01.models.RadiusServer] + :param aad_tenant: The AADTenant property of the VirtualNetworkGateway resource for vpn client + connection used for AAD authentication. + :type aad_tenant: str + :param aad_audience: The AADAudience property of the VirtualNetworkGateway resource for vpn + client connection used for AAD authentication. + :type aad_audience: str + :param aad_issuer: The AADIssuer property of the VirtualNetworkGateway resource for vpn client + connection used for AAD authentication. + :type aad_issuer: str + """ + + _attribute_map = { + 'vpn_client_address_pool': {'key': 'vpnClientAddressPool', 'type': 'AddressSpace'}, + 'vpn_client_root_certificates': {'key': 'vpnClientRootCertificates', 'type': '[VpnClientRootCertificate]'}, + 'vpn_client_revoked_certificates': {'key': 'vpnClientRevokedCertificates', 'type': '[VpnClientRevokedCertificate]'}, + 'vpn_client_protocols': {'key': 'vpnClientProtocols', 'type': '[str]'}, + 'vpn_client_ipsec_policies': {'key': 'vpnClientIpsecPolicies', 'type': '[IpsecPolicy]'}, + 'radius_server_address': {'key': 'radiusServerAddress', 'type': 'str'}, + 'radius_server_secret': {'key': 'radiusServerSecret', 'type': 'str'}, + 'radius_servers': {'key': 'radiusServers', 'type': '[RadiusServer]'}, + 'aad_tenant': {'key': 'aadTenant', 'type': 'str'}, + 'aad_audience': {'key': 'aadAudience', 'type': 'str'}, + 'aad_issuer': {'key': 'aadIssuer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientConfiguration, self).__init__(**kwargs) + self.vpn_client_address_pool = kwargs.get('vpn_client_address_pool', None) + self.vpn_client_root_certificates = kwargs.get('vpn_client_root_certificates', None) + self.vpn_client_revoked_certificates = kwargs.get('vpn_client_revoked_certificates', None) + self.vpn_client_protocols = kwargs.get('vpn_client_protocols', None) + self.vpn_client_ipsec_policies = kwargs.get('vpn_client_ipsec_policies', None) + self.radius_server_address = kwargs.get('radius_server_address', None) + self.radius_server_secret = kwargs.get('radius_server_secret', None) + self.radius_servers = kwargs.get('radius_servers', None) + self.aad_tenant = kwargs.get('aad_tenant', None) + self.aad_audience = kwargs.get('aad_audience', None) + self.aad_issuer = kwargs.get('aad_issuer', None) + + +class VpnClientConnectionHealth(msrest.serialization.Model): + """VpnClientConnectionHealth properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar total_ingress_bytes_transferred: Total of the Ingress Bytes Transferred in this P2S Vpn + connection. + :vartype total_ingress_bytes_transferred: long + :ivar total_egress_bytes_transferred: Total of the Egress Bytes Transferred in this connection. + :vartype total_egress_bytes_transferred: long + :param vpn_client_connections_count: The total of p2s vpn clients connected at this time to + this P2SVpnGateway. + :type vpn_client_connections_count: int + :param allocated_ip_addresses: List of allocated ip addresses to the connected p2s vpn clients. + :type allocated_ip_addresses: list[str] + """ + + _validation = { + 'total_ingress_bytes_transferred': {'readonly': True}, + 'total_egress_bytes_transferred': {'readonly': True}, + } + + _attribute_map = { + 'total_ingress_bytes_transferred': {'key': 'totalIngressBytesTransferred', 'type': 'long'}, + 'total_egress_bytes_transferred': {'key': 'totalEgressBytesTransferred', 'type': 'long'}, + 'vpn_client_connections_count': {'key': 'vpnClientConnectionsCount', 'type': 'int'}, + 'allocated_ip_addresses': {'key': 'allocatedIpAddresses', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientConnectionHealth, self).__init__(**kwargs) + self.total_ingress_bytes_transferred = None + self.total_egress_bytes_transferred = None + self.vpn_client_connections_count = kwargs.get('vpn_client_connections_count', None) + self.allocated_ip_addresses = kwargs.get('allocated_ip_addresses', None) + + +class VpnClientConnectionHealthDetail(msrest.serialization.Model): + """VPN client connection health detail. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar vpn_connection_id: The vpn client Id. + :vartype vpn_connection_id: str + :ivar vpn_connection_duration: The duration time of a connected vpn client. + :vartype vpn_connection_duration: long + :ivar vpn_connection_time: The start time of a connected vpn client. + :vartype vpn_connection_time: str + :ivar public_ip_address: The public Ip of a connected vpn client. + :vartype public_ip_address: str + :ivar private_ip_address: The assigned private Ip of a connected vpn client. + :vartype private_ip_address: str + :ivar vpn_user_name: The user name of a connected vpn client. + :vartype vpn_user_name: str + :ivar max_bandwidth: The max band width. + :vartype max_bandwidth: long + :ivar egress_packets_transferred: The egress packets per second. + :vartype egress_packets_transferred: long + :ivar egress_bytes_transferred: The egress bytes per second. + :vartype egress_bytes_transferred: long + :ivar ingress_packets_transferred: The ingress packets per second. + :vartype ingress_packets_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes per second. + :vartype ingress_bytes_transferred: long + :ivar max_packets_per_second: The max packets transferred per second. + :vartype max_packets_per_second: long + """ + + _validation = { + 'vpn_connection_id': {'readonly': True}, + 'vpn_connection_duration': {'readonly': True}, + 'vpn_connection_time': {'readonly': True}, + 'public_ip_address': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'vpn_user_name': {'readonly': True}, + 'max_bandwidth': {'readonly': True}, + 'egress_packets_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_packets_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'max_packets_per_second': {'readonly': True}, + } + + _attribute_map = { + 'vpn_connection_id': {'key': 'vpnConnectionId', 'type': 'str'}, + 'vpn_connection_duration': {'key': 'vpnConnectionDuration', 'type': 'long'}, + 'vpn_connection_time': {'key': 'vpnConnectionTime', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + 'vpn_user_name': {'key': 'vpnUserName', 'type': 'str'}, + 'max_bandwidth': {'key': 'maxBandwidth', 'type': 'long'}, + 'egress_packets_transferred': {'key': 'egressPacketsTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'egressBytesTransferred', 'type': 'long'}, + 'ingress_packets_transferred': {'key': 'ingressPacketsTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'ingressBytesTransferred', 'type': 'long'}, + 'max_packets_per_second': {'key': 'maxPacketsPerSecond', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientConnectionHealthDetail, self).__init__(**kwargs) + self.vpn_connection_id = None + self.vpn_connection_duration = None + self.vpn_connection_time = None + self.public_ip_address = None + self.private_ip_address = None + self.vpn_user_name = None + self.max_bandwidth = None + self.egress_packets_transferred = None + self.egress_bytes_transferred = None + self.ingress_packets_transferred = None + self.ingress_bytes_transferred = None + self.max_packets_per_second = None + + +class VpnClientConnectionHealthDetailListResult(msrest.serialization.Model): + """List of virtual network gateway vpn client connection health. + + :param value: List of vpn client connection health. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealthDetail] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VpnClientConnectionHealthDetail]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientConnectionHealthDetailListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class VpnClientIPsecParameters(msrest.serialization.Model): + """An IPSec parameters for a virtual network gateway P2S connection. + + All required parameters must be populated in order to send to Azure. + + :param sa_life_time_seconds: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) lifetime in seconds for P2S client. + :type sa_life_time_seconds: int + :param sa_data_size_kilobytes: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) payload size in KB for P2S client.. + :type sa_data_size_kilobytes: int + :param ipsec_encryption: Required. The IPSec encryption algorithm (IKE phase 1). Possible + values include: "None", "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES128", "GCMAES192", + "GCMAES256". + :type ipsec_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IpsecEncryption + :param ipsec_integrity: Required. The IPSec integrity algorithm (IKE phase 1). Possible values + include: "MD5", "SHA1", "SHA256", "GCMAES128", "GCMAES192", "GCMAES256". + :type ipsec_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IpsecIntegrity + :param ike_encryption: Required. The IKE encryption algorithm (IKE phase 2). Possible values + include: "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES256", "GCMAES128". + :type ike_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IkeEncryption + :param ike_integrity: Required. The IKE integrity algorithm (IKE phase 2). Possible values + include: "MD5", "SHA1", "SHA256", "SHA384", "GCMAES256", "GCMAES128". + :type ike_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IkeIntegrity + :param dh_group: Required. The DH Group used in IKE Phase 1 for initial SA. Possible values + include: "None", "DHGroup1", "DHGroup2", "DHGroup14", "DHGroup2048", "ECP256", "ECP384", + "DHGroup24". + :type dh_group: str or ~azure.mgmt.network.v2020_08_01.models.DhGroup + :param pfs_group: Required. The Pfs Group used in IKE Phase 2 for new child SA. Possible values + include: "None", "PFS1", "PFS2", "PFS2048", "ECP256", "ECP384", "PFS24", "PFS14", "PFSMM". + :type pfs_group: str or ~azure.mgmt.network.v2020_08_01.models.PfsGroup + """ + + _validation = { + 'sa_life_time_seconds': {'required': True}, + 'sa_data_size_kilobytes': {'required': True}, + 'ipsec_encryption': {'required': True}, + 'ipsec_integrity': {'required': True}, + 'ike_encryption': {'required': True}, + 'ike_integrity': {'required': True}, + 'dh_group': {'required': True}, + 'pfs_group': {'required': True}, + } + + _attribute_map = { + 'sa_life_time_seconds': {'key': 'saLifeTimeSeconds', 'type': 'int'}, + 'sa_data_size_kilobytes': {'key': 'saDataSizeKilobytes', 'type': 'int'}, + 'ipsec_encryption': {'key': 'ipsecEncryption', 'type': 'str'}, + 'ipsec_integrity': {'key': 'ipsecIntegrity', 'type': 'str'}, + 'ike_encryption': {'key': 'ikeEncryption', 'type': 'str'}, + 'ike_integrity': {'key': 'ikeIntegrity', 'type': 'str'}, + 'dh_group': {'key': 'dhGroup', 'type': 'str'}, + 'pfs_group': {'key': 'pfsGroup', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientIPsecParameters, self).__init__(**kwargs) + self.sa_life_time_seconds = kwargs['sa_life_time_seconds'] + self.sa_data_size_kilobytes = kwargs['sa_data_size_kilobytes'] + self.ipsec_encryption = kwargs['ipsec_encryption'] + self.ipsec_integrity = kwargs['ipsec_integrity'] + self.ike_encryption = kwargs['ike_encryption'] + self.ike_integrity = kwargs['ike_integrity'] + self.dh_group = kwargs['dh_group'] + self.pfs_group = kwargs['pfs_group'] + + +class VpnClientParameters(msrest.serialization.Model): + """Vpn Client Parameters for package generation. + + :param processor_architecture: VPN client Processor Architecture. Possible values include: + "Amd64", "X86". + :type processor_architecture: str or + ~azure.mgmt.network.v2020_08_01.models.ProcessorArchitecture + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + :param radius_server_auth_certificate: The public certificate data for the radius server + authentication certificate as a Base-64 encoded string. Required only if external radius + authentication has been configured with EAPTLS authentication. + :type radius_server_auth_certificate: str + :param client_root_certificates: A list of client root certificates public certificate data + encoded as Base-64 strings. Optional parameter for external radius based authentication with + EAPTLS. + :type client_root_certificates: list[str] + """ + + _attribute_map = { + 'processor_architecture': {'key': 'processorArchitecture', 'type': 'str'}, + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + 'radius_server_auth_certificate': {'key': 'radiusServerAuthCertificate', 'type': 'str'}, + 'client_root_certificates': {'key': 'clientRootCertificates', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientParameters, self).__init__(**kwargs) + self.processor_architecture = kwargs.get('processor_architecture', None) + self.authentication_method = kwargs.get('authentication_method', None) + self.radius_server_auth_certificate = kwargs.get('radius_server_auth_certificate', None) + self.client_root_certificates = kwargs.get('client_root_certificates', None) + + +class VpnClientRevokedCertificate(SubResource): + """VPN client revoked certificate of virtual network gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param thumbprint: The revoked VPN client certificate thumbprint. + :type thumbprint: str + :ivar provisioning_state: The provisioning state of the VPN client revoked certificate + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientRevokedCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.thumbprint = kwargs.get('thumbprint', None) + self.provisioning_state = None + + +class VpnClientRootCertificate(SubResource): + """VPN client root certificate of virtual network gateway. + + Variables are only 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 id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param public_cert_data: Required. The certificate public data. + :type public_cert_data: str + :ivar provisioning_state: The provisioning state of the VPN client root certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'public_cert_data': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'public_cert_data': {'key': 'properties.publicCertData', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientRootCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.public_cert_data = kwargs['public_cert_data'] + self.provisioning_state = None + + +class VpnConnection(SubResource): + """VpnConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param remote_vpn_site: Id of the connected vpn site. + :type remote_vpn_site: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param routing_weight: Routing weight for vpn connection. + :type routing_weight: int + :param dpd_timeout_seconds: DPD timeout in seconds for vpn connection. + :type dpd_timeout_seconds: int + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.VpnConnectionStatus + :param vpn_connection_protocol_type: Connection protocol used for this connection. Possible + values include: "IKEv2", "IKEv1". + :type vpn_connection_protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :ivar ingress_bytes_transferred: Ingress bytes transferred. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: Egress bytes transferred. + :vartype egress_bytes_transferred: long + :param connection_bandwidth: Expected bandwidth in MBPS. + :type connection_bandwidth: int + :param shared_key: SharedKey for the vpn connection. + :type shared_key: str + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param enable_rate_limiting: EnableBgp flag. + :type enable_rate_limiting: bool + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param use_local_azure_ip_address: Use local azure ip to initiate connection. + :type use_local_azure_ip_address: bool + :ivar provisioning_state: The provisioning state of the VPN connection resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_link_connections: List of all vpn site link connections to the gateway. + :type vpn_link_connections: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection] + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + """ + + _validation = { + 'etag': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'remote_vpn_site': {'key': 'properties.remoteVpnSite', 'type': 'SubResource'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'dpd_timeout_seconds': {'key': 'properties.dpdTimeoutSeconds', 'type': 'int'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'vpn_connection_protocol_type': {'key': 'properties.vpnConnectionProtocolType', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'connection_bandwidth': {'key': 'properties.connectionBandwidth', 'type': 'int'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'enable_rate_limiting': {'key': 'properties.enableRateLimiting', 'type': 'bool'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_link_connections': {'key': 'properties.vpnLinkConnections', 'type': '[VpnSiteLinkConnection]'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.remote_vpn_site = kwargs.get('remote_vpn_site', None) + self.routing_weight = kwargs.get('routing_weight', None) + self.dpd_timeout_seconds = kwargs.get('dpd_timeout_seconds', None) + self.connection_status = None + self.vpn_connection_protocol_type = kwargs.get('vpn_connection_protocol_type', None) + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.connection_bandwidth = kwargs.get('connection_bandwidth', None) + self.shared_key = kwargs.get('shared_key', None) + self.enable_bgp = kwargs.get('enable_bgp', None) + self.use_policy_based_traffic_selectors = kwargs.get('use_policy_based_traffic_selectors', None) + self.ipsec_policies = kwargs.get('ipsec_policies', None) + self.enable_rate_limiting = kwargs.get('enable_rate_limiting', None) + self.enable_internet_security = kwargs.get('enable_internet_security', None) + self.use_local_azure_ip_address = kwargs.get('use_local_azure_ip_address', None) + self.provisioning_state = None + self.vpn_link_connections = kwargs.get('vpn_link_connections', None) + self.routing_configuration = kwargs.get('routing_configuration', None) + + +class VpnConnectionPacketCaptureStartParameters(msrest.serialization.Model): + """Vpn Connection packet capture parameters supplied to start packet capture on gateway connection. + + :param filter_data: Start Packet capture parameters on vpn connection. + :type filter_data: str + :param link_connection_names: List of site link connection names. + :type link_connection_names: list[str] + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + 'link_connection_names': {'key': 'linkConnectionNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnConnectionPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = kwargs.get('filter_data', None) + self.link_connection_names = kwargs.get('link_connection_names', None) + + +class VpnConnectionPacketCaptureStopParameters(msrest.serialization.Model): + """Vpn Connection packet capture parameters supplied to stop packet capture on gateway connection. + + :param sas_url: SAS url for packet capture on vpn connection. + :type sas_url: str + :param link_connection_names: List of site link connection names. + :type link_connection_names: list[str] + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'link_connection_names': {'key': 'linkConnectionNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnConnectionPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + self.link_connection_names = kwargs.get('link_connection_names', None) + + +class VpnDeviceScriptParameters(msrest.serialization.Model): + """Vpn device configuration script generation parameters. + + :param vendor: The vendor for the vpn device. + :type vendor: str + :param device_family: The device family for the vpn device. + :type device_family: str + :param firmware_version: The firmware version for the vpn device. + :type firmware_version: str + """ + + _attribute_map = { + 'vendor': {'key': 'vendor', 'type': 'str'}, + 'device_family': {'key': 'deviceFamily', 'type': 'str'}, + 'firmware_version': {'key': 'firmwareVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnDeviceScriptParameters, self).__init__(**kwargs) + self.vendor = kwargs.get('vendor', None) + self.device_family = kwargs.get('device_family', None) + self.firmware_version = kwargs.get('firmware_version', None) + + +class VpnGateway(Resource): + """VpnGateway Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_hub: The VirtualHub to which the gateway belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param connections: List of all vpn connections to the gateway. + :type connections: list[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :param bgp_settings: Local network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar provisioning_state: The provisioning state of the VPN gateway resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_gateway_scale_unit: The scale unit for this vpn gateway. + :type vpn_gateway_scale_unit: int + :ivar ip_configurations: List of all IPs configured on the gateway. + :vartype ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayIpConfiguration] + :param is_routing_preference_internet: Enable Routing Preference property for the Public IP + Interface of the VpnGateway. + :type is_routing_preference_internet: bool + :param nat_rules: List of all the nat Rules associated with the gateway. + :type nat_rules: list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'ip_configurations': {'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'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'connections': {'key': 'properties.connections', 'type': '[VpnConnection]'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_gateway_scale_unit': {'key': 'properties.vpnGatewayScaleUnit', 'type': 'int'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[VpnGatewayIpConfiguration]'}, + 'is_routing_preference_internet': {'key': 'properties.isRoutingPreferenceInternet', 'type': 'bool'}, + 'nat_rules': {'key': 'properties.natRules', 'type': '[VpnGatewayNatRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnGateway, self).__init__(**kwargs) + self.etag = None + self.virtual_hub = kwargs.get('virtual_hub', None) + self.connections = kwargs.get('connections', None) + self.bgp_settings = kwargs.get('bgp_settings', None) + self.provisioning_state = None + self.vpn_gateway_scale_unit = kwargs.get('vpn_gateway_scale_unit', None) + self.ip_configurations = None + self.is_routing_preference_internet = kwargs.get('is_routing_preference_internet', None) + self.nat_rules = kwargs.get('nat_rules', None) + + +class VpnGatewayIpConfiguration(msrest.serialization.Model): + """IP Configuration of a VPN Gateway Resource. + + :param id: The identifier of the IP configuration for a VPN Gateway. + :type id: str + :param public_ip_address: The public IP address of this IP configuration. + :type public_ip_address: str + :param private_ip_address: The private IP address of this IP configuration. + :type private_ip_address: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnGatewayIpConfiguration, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.public_ip_address = kwargs.get('public_ip_address', None) + self.private_ip_address = kwargs.get('private_ip_address', None) + + +class VpnGatewayNatRule(SubResource): + """VpnGatewayNatRule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :ivar provisioning_state: The provisioning state of the NAT Rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param type_properties_type: The type of NAT rule for VPN NAT. Possible values include: + "Static", "Dynamic". + :type type_properties_type: str or ~azure.mgmt.network.v2020_08_01.models.VpnNatRuleType + :param mode: The Source NAT direction of a VPN NAT. Possible values include: "EgressSnat", + "IngressSnat". + :type mode: str or ~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMode + :param internal_mappings: The private IP address internal mapping for NAT. + :type internal_mappings: list[~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMapping] + :param external_mappings: The private IP address external mapping for NAT. + :type external_mappings: list[~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMapping] + :param ip_configuration_id: The IP Configuration ID this NAT rule applies to. + :type ip_configuration_id: str + :ivar egress_vpn_site_link_connections: List of egress VpnSiteLinkConnections. + :vartype egress_vpn_site_link_connections: + list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar ingress_vpn_site_link_connections: List of ingress VpnSiteLinkConnections. + :vartype ingress_vpn_site_link_connections: + list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'egress_vpn_site_link_connections': {'readonly': True}, + 'ingress_vpn_site_link_connections': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + 'mode': {'key': 'properties.mode', 'type': 'str'}, + 'internal_mappings': {'key': 'properties.internalMappings', 'type': '[VpnNatRuleMapping]'}, + 'external_mappings': {'key': 'properties.externalMappings', 'type': '[VpnNatRuleMapping]'}, + 'ip_configuration_id': {'key': 'properties.ipConfigurationId', 'type': 'str'}, + 'egress_vpn_site_link_connections': {'key': 'properties.egressVpnSiteLinkConnections', 'type': '[SubResource]'}, + 'ingress_vpn_site_link_connections': {'key': 'properties.ingressVpnSiteLinkConnections', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnGatewayNatRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.provisioning_state = None + self.type_properties_type = kwargs.get('type_properties_type', None) + self.mode = kwargs.get('mode', None) + self.internal_mappings = kwargs.get('internal_mappings', None) + self.external_mappings = kwargs.get('external_mappings', None) + self.ip_configuration_id = kwargs.get('ip_configuration_id', None) + self.egress_vpn_site_link_connections = None + self.ingress_vpn_site_link_connections = None + + +class VpnGatewayPacketCaptureStartParameters(msrest.serialization.Model): + """Start packet capture parameters. + + :param filter_data: Start Packet capture parameters on vpn gateway. + :type filter_data: str + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnGatewayPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = kwargs.get('filter_data', None) + + +class VpnGatewayPacketCaptureStopParameters(msrest.serialization.Model): + """Stop packet capture parameters. + + :param sas_url: SAS url for packet capture on vpn gateway. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnGatewayPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + + +class VpnLinkBgpSettings(msrest.serialization.Model): + """BGP settings details for a link. + + :param asn: The BGP speaker's ASN. + :type asn: long + :param bgp_peering_address: The BGP peering address and BGP identifier of this BGP speaker. + :type bgp_peering_address: str + """ + + _attribute_map = { + 'asn': {'key': 'asn', 'type': 'long'}, + 'bgp_peering_address': {'key': 'bgpPeeringAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnLinkBgpSettings, self).__init__(**kwargs) + self.asn = kwargs.get('asn', None) + self.bgp_peering_address = kwargs.get('bgp_peering_address', None) + + +class VpnLinkProviderProperties(msrest.serialization.Model): + """List of properties of a link provider. + + :param link_provider_name: Name of the link provider. + :type link_provider_name: str + :param link_speed_in_mbps: Link speed. + :type link_speed_in_mbps: int + """ + + _attribute_map = { + 'link_provider_name': {'key': 'linkProviderName', 'type': 'str'}, + 'link_speed_in_mbps': {'key': 'linkSpeedInMbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnLinkProviderProperties, self).__init__(**kwargs) + self.link_provider_name = kwargs.get('link_provider_name', None) + self.link_speed_in_mbps = kwargs.get('link_speed_in_mbps', None) + + +class VpnNatRuleMapping(msrest.serialization.Model): + """Vpn NatRule mapping. + + :param address_space: Address space for Vpn NatRule mapping. + :type address_space: str + """ + + _attribute_map = { + 'address_space': {'key': 'addressSpace', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnNatRuleMapping, self).__init__(**kwargs) + self.address_space = kwargs.get('address_space', None) + + +class VpnPacketCaptureStartParameters(msrest.serialization.Model): + """Start packet capture parameters on virtual network gateway. + + :param filter_data: Start Packet capture parameters. + :type filter_data: str + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = kwargs.get('filter_data', None) + + +class VpnPacketCaptureStopParameters(msrest.serialization.Model): + """Stop packet capture parameters. + + :param sas_url: SAS url for packet capture on virtual network gateway. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + + +class VpnProfileResponse(msrest.serialization.Model): + """Vpn Profile Response for package generation. + + :param profile_url: URL to the VPN profile. + :type profile_url: str + """ + + _attribute_map = { + 'profile_url': {'key': 'profileUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnProfileResponse, self).__init__(**kwargs) + self.profile_url = kwargs.get('profile_url', None) + + +class VpnServerConfigRadiusClientRootCertificate(msrest.serialization.Model): + """Properties of the Radius client root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param thumbprint: The Radius client root certificate thumbprint. + :type thumbprint: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfigRadiusClientRootCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.thumbprint = kwargs.get('thumbprint', None) + + +class VpnServerConfigRadiusServerRootCertificate(msrest.serialization.Model): + """Properties of Radius Server root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param public_cert_data: The certificate public data. + :type public_cert_data: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_cert_data': {'key': 'publicCertData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfigRadiusServerRootCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.public_cert_data = kwargs.get('public_cert_data', None) + + +class VpnServerConfiguration(Resource): + """VpnServerConfiguration Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param name_properties_name: The name of the VpnServerConfiguration that is unique within a + resource group. + :type name_properties_name: str + :param vpn_protocols: VPN protocols for the VpnServerConfiguration. + :type vpn_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnGatewayTunnelingProtocol] + :param vpn_authentication_types: VPN authentication types for the VpnServerConfiguration. + :type vpn_authentication_types: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnAuthenticationType] + :param vpn_client_root_certificates: VPN client root certificate of VpnServerConfiguration. + :type vpn_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigVpnClientRootCertificate] + :param vpn_client_revoked_certificates: VPN client revoked certificate of + VpnServerConfiguration. + :type vpn_client_revoked_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigVpnClientRevokedCertificate] + :param radius_server_root_certificates: Radius Server root certificate of + VpnServerConfiguration. + :type radius_server_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigRadiusServerRootCertificate] + :param radius_client_root_certificates: Radius client root certificate of + VpnServerConfiguration. + :type radius_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigRadiusClientRootCertificate] + :param vpn_client_ipsec_policies: VpnClientIpsecPolicies for VpnServerConfiguration. + :type vpn_client_ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param radius_server_address: The radius server address property of the VpnServerConfiguration + resource for point to site client connection. + :type radius_server_address: str + :param radius_server_secret: The radius secret property of the VpnServerConfiguration resource + for point to site client connection. + :type radius_server_secret: str + :param radius_servers: Multiple Radius Server configuration for VpnServerConfiguration. + :type radius_servers: list[~azure.mgmt.network.v2020_08_01.models.RadiusServer] + :param aad_authentication_parameters: The set of aad vpn authentication parameters. + :type aad_authentication_parameters: + ~azure.mgmt.network.v2020_08_01.models.AadAuthenticationParameters + :ivar provisioning_state: The provisioning state of the VpnServerConfiguration resource. + Possible values are: 'Updating', 'Deleting', and 'Failed'. + :vartype provisioning_state: str + :ivar p2_s_vpn_gateways: List of references to P2SVpnGateways. + :vartype p2_s_vpn_gateways: list[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :ivar etag_properties_etag: A unique read-only string that changes whenever the resource is + updated. + :vartype etag_properties_etag: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'p2_s_vpn_gateways': {'readonly': True}, + 'etag_properties_etag': {'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'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'vpn_protocols': {'key': 'properties.vpnProtocols', 'type': '[str]'}, + 'vpn_authentication_types': {'key': 'properties.vpnAuthenticationTypes', 'type': '[str]'}, + 'vpn_client_root_certificates': {'key': 'properties.vpnClientRootCertificates', 'type': '[VpnServerConfigVpnClientRootCertificate]'}, + 'vpn_client_revoked_certificates': {'key': 'properties.vpnClientRevokedCertificates', 'type': '[VpnServerConfigVpnClientRevokedCertificate]'}, + 'radius_server_root_certificates': {'key': 'properties.radiusServerRootCertificates', 'type': '[VpnServerConfigRadiusServerRootCertificate]'}, + 'radius_client_root_certificates': {'key': 'properties.radiusClientRootCertificates', 'type': '[VpnServerConfigRadiusClientRootCertificate]'}, + 'vpn_client_ipsec_policies': {'key': 'properties.vpnClientIpsecPolicies', 'type': '[IpsecPolicy]'}, + 'radius_server_address': {'key': 'properties.radiusServerAddress', 'type': 'str'}, + 'radius_server_secret': {'key': 'properties.radiusServerSecret', 'type': 'str'}, + 'radius_servers': {'key': 'properties.radiusServers', 'type': '[RadiusServer]'}, + 'aad_authentication_parameters': {'key': 'properties.aadAuthenticationParameters', 'type': 'AadAuthenticationParameters'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'p2_s_vpn_gateways': {'key': 'properties.p2SVpnGateways', 'type': '[P2SVpnGateway]'}, + 'etag_properties_etag': {'key': 'properties.etag', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfiguration, self).__init__(**kwargs) + self.etag = None + self.name_properties_name = kwargs.get('name_properties_name', None) + self.vpn_protocols = kwargs.get('vpn_protocols', None) + self.vpn_authentication_types = kwargs.get('vpn_authentication_types', None) + self.vpn_client_root_certificates = kwargs.get('vpn_client_root_certificates', None) + self.vpn_client_revoked_certificates = kwargs.get('vpn_client_revoked_certificates', None) + self.radius_server_root_certificates = kwargs.get('radius_server_root_certificates', None) + self.radius_client_root_certificates = kwargs.get('radius_client_root_certificates', None) + self.vpn_client_ipsec_policies = kwargs.get('vpn_client_ipsec_policies', None) + self.radius_server_address = kwargs.get('radius_server_address', None) + self.radius_server_secret = kwargs.get('radius_server_secret', None) + self.radius_servers = kwargs.get('radius_servers', None) + self.aad_authentication_parameters = kwargs.get('aad_authentication_parameters', None) + self.provisioning_state = None + self.p2_s_vpn_gateways = None + self.etag_properties_etag = None + + +class VpnServerConfigurationsResponse(msrest.serialization.Model): + """VpnServerConfigurations list associated with VirtualWan Response. + + :param vpn_server_configuration_resource_ids: List of VpnServerConfigurations associated with + VirtualWan. + :type vpn_server_configuration_resource_ids: list[str] + """ + + _attribute_map = { + 'vpn_server_configuration_resource_ids': {'key': 'vpnServerConfigurationResourceIds', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfigurationsResponse, self).__init__(**kwargs) + self.vpn_server_configuration_resource_ids = kwargs.get('vpn_server_configuration_resource_ids', None) + + +class VpnServerConfigVpnClientRevokedCertificate(msrest.serialization.Model): + """Properties of the revoked VPN client certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param thumbprint: The revoked VPN client certificate thumbprint. + :type thumbprint: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfigVpnClientRevokedCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.thumbprint = kwargs.get('thumbprint', None) + + +class VpnServerConfigVpnClientRootCertificate(msrest.serialization.Model): + """Properties of VPN client root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param public_cert_data: The certificate public data. + :type public_cert_data: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_cert_data': {'key': 'publicCertData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnServerConfigVpnClientRootCertificate, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.public_cert_data = kwargs.get('public_cert_data', None) + + +class VpnSite(Resource): + """VpnSite Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_wan: The VirtualWAN to which the vpnSite belongs. + :type virtual_wan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param device_properties: The device properties. + :type device_properties: ~azure.mgmt.network.v2020_08_01.models.DeviceProperties + :param ip_address: The ip-address for the vpn-site. + :type ip_address: str + :param site_key: The key for vpn-site that can be used for connections. + :type site_key: str + :param address_space: The AddressSpace that contains an array of IP address ranges. + :type address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param bgp_properties: The set of bgp properties. + :type bgp_properties: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar provisioning_state: The provisioning state of the VPN site resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param is_security_site: IsSecuritySite flag. + :type is_security_site: bool + :param vpn_site_links: List of all vpn site links. + :type vpn_site_links: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLink] + :param o365_policy: Office365 Policy. + :type o365_policy: ~azure.mgmt.network.v2020_08_01.models.O365PolicyProperties + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'virtual_wan': {'key': 'properties.virtualWan', 'type': 'SubResource'}, + 'device_properties': {'key': 'properties.deviceProperties', 'type': 'DeviceProperties'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'site_key': {'key': 'properties.siteKey', 'type': 'str'}, + 'address_space': {'key': 'properties.addressSpace', 'type': 'AddressSpace'}, + 'bgp_properties': {'key': 'properties.bgpProperties', 'type': 'BgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'is_security_site': {'key': 'properties.isSecuritySite', 'type': 'bool'}, + 'vpn_site_links': {'key': 'properties.vpnSiteLinks', 'type': '[VpnSiteLink]'}, + 'o365_policy': {'key': 'properties.o365Policy', 'type': 'O365PolicyProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnSite, self).__init__(**kwargs) + self.etag = None + self.virtual_wan = kwargs.get('virtual_wan', None) + self.device_properties = kwargs.get('device_properties', None) + self.ip_address = kwargs.get('ip_address', None) + self.site_key = kwargs.get('site_key', None) + self.address_space = kwargs.get('address_space', None) + self.bgp_properties = kwargs.get('bgp_properties', None) + self.provisioning_state = None + self.is_security_site = kwargs.get('is_security_site', None) + self.vpn_site_links = kwargs.get('vpn_site_links', None) + self.o365_policy = kwargs.get('o365_policy', None) + + +class VpnSiteId(msrest.serialization.Model): + """VpnSite Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar vpn_site: The resource-uri of the vpn-site for which config is to be fetched. + :vartype vpn_site: str + """ + + _validation = { + 'vpn_site': {'readonly': True}, + } + + _attribute_map = { + 'vpn_site': {'key': 'vpnSite', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnSiteId, self).__init__(**kwargs) + self.vpn_site = None + + +class VpnSiteLink(SubResource): + """VpnSiteLink Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: Resource type. + :vartype type: str + :param link_properties: The link provider properties. + :type link_properties: ~azure.mgmt.network.v2020_08_01.models.VpnLinkProviderProperties + :param ip_address: The ip-address for the vpn-site-link. + :type ip_address: str + :param fqdn: FQDN of vpn-site-link. + :type fqdn: str + :param bgp_properties: The set of bgp properties. + :type bgp_properties: ~azure.mgmt.network.v2020_08_01.models.VpnLinkBgpSettings + :ivar provisioning_state: The provisioning state of the VPN site link resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'link_properties': {'key': 'properties.linkProperties', 'type': 'VpnLinkProviderProperties'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'bgp_properties': {'key': 'properties.bgpProperties', 'type': 'VpnLinkBgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnSiteLink, self).__init__(**kwargs) + self.etag = None + self.name = kwargs.get('name', None) + self.type = None + self.link_properties = kwargs.get('link_properties', None) + self.ip_address = kwargs.get('ip_address', None) + self.fqdn = kwargs.get('fqdn', None) + self.bgp_properties = kwargs.get('bgp_properties', None) + self.provisioning_state = None + + +class VpnSiteLinkConnection(SubResource): + """VpnSiteLinkConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param vpn_site_link: Id of the connected vpn site link. + :type vpn_site_link: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param routing_weight: Routing weight for vpn connection. + :type routing_weight: int + :param vpn_link_connection_mode: Vpn link connection mode. Possible values include: "Default", + "ResponderOnly", "InitiatorOnly". + :type vpn_link_connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VpnLinkConnectionMode + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.VpnConnectionStatus + :param vpn_connection_protocol_type: Connection protocol used for this connection. Possible + values include: "IKEv2", "IKEv1". + :type vpn_connection_protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :ivar ingress_bytes_transferred: Ingress bytes transferred. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: Egress bytes transferred. + :vartype egress_bytes_transferred: long + :param connection_bandwidth: Expected bandwidth in MBPS. + :type connection_bandwidth: int + :param shared_key: SharedKey for the vpn connection. + :type shared_key: str + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param enable_rate_limiting: EnableBgp flag. + :type enable_rate_limiting: bool + :param use_local_azure_ip_address: Use local azure ip to initiate connection. + :type use_local_azure_ip_address: bool + :ivar provisioning_state: The provisioning state of the VPN site link connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ingress_nat_rules: List of ingress NatRules. + :type ingress_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param egress_nat_rules: List of egress NatRules. + :type egress_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vpn_site_link': {'key': 'properties.vpnSiteLink', 'type': 'SubResource'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'vpn_link_connection_mode': {'key': 'properties.vpnLinkConnectionMode', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'vpn_connection_protocol_type': {'key': 'properties.vpnConnectionProtocolType', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'connection_bandwidth': {'key': 'properties.connectionBandwidth', 'type': 'int'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'enable_rate_limiting': {'key': 'properties.enableRateLimiting', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'ingress_nat_rules': {'key': 'properties.ingressNatRules', 'type': '[SubResource]'}, + 'egress_nat_rules': {'key': 'properties.egressNatRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnSiteLinkConnection, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.type = None + self.vpn_site_link = kwargs.get('vpn_site_link', None) + self.routing_weight = kwargs.get('routing_weight', None) + self.vpn_link_connection_mode = kwargs.get('vpn_link_connection_mode', None) + self.connection_status = None + self.vpn_connection_protocol_type = kwargs.get('vpn_connection_protocol_type', None) + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.connection_bandwidth = kwargs.get('connection_bandwidth', None) + self.shared_key = kwargs.get('shared_key', None) + self.enable_bgp = kwargs.get('enable_bgp', None) + self.use_policy_based_traffic_selectors = kwargs.get('use_policy_based_traffic_selectors', None) + self.ipsec_policies = kwargs.get('ipsec_policies', None) + self.enable_rate_limiting = kwargs.get('enable_rate_limiting', None) + self.use_local_azure_ip_address = kwargs.get('use_local_azure_ip_address', None) + self.provisioning_state = None + self.ingress_nat_rules = kwargs.get('ingress_nat_rules', None) + self.egress_nat_rules = kwargs.get('egress_nat_rules', None) + + +class WebApplicationFirewallCustomRule(msrest.serialization.Model): + """Defines contents of a web application rule. + + Variables are only 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: The name of the resource that is unique within a policy. This name can be used to + access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Required. Priority of the rule. Rules with a lower value will be evaluated + before rules with a higher value. + :type priority: int + :param rule_type: Required. The rule type. Possible values include: "MatchRule", "Invalid". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallRuleType + :param match_conditions: Required. List of match conditions. + :type match_conditions: list[~azure.mgmt.network.v2020_08_01.models.MatchCondition] + :param action: Required. Type of Actions. Possible values include: "Allow", "Block", "Log". + :type action: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallAction + """ + + _validation = { + 'name': {'max_length': 128, 'min_length': 0}, + 'etag': {'readonly': True}, + 'priority': {'required': True}, + 'rule_type': {'required': True}, + 'match_conditions': {'required': True}, + 'action': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'match_conditions': {'key': 'matchConditions', 'type': '[MatchCondition]'}, + 'action': {'key': 'action', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebApplicationFirewallCustomRule, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.etag = None + self.priority = kwargs['priority'] + self.rule_type = kwargs['rule_type'] + self.match_conditions = kwargs['match_conditions'] + self.action = kwargs['action'] + + +class WebApplicationFirewallPolicy(Resource): + """Defines web application firewall policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param policy_settings: The PolicySettings for policy. + :type policy_settings: ~azure.mgmt.network.v2020_08_01.models.PolicySettings + :param custom_rules: The custom rules inside the policy. + :type custom_rules: + list[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallCustomRule] + :ivar application_gateways: A collection of references to application gateways. + :vartype application_gateways: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :ivar provisioning_state: The provisioning state of the web application firewall policy + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_state: Resource status of the policy. Possible values include: "Creating", + "Enabling", "Enabled", "Disabling", "Disabled", "Deleting". + :vartype resource_state: str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyResourceState + :param managed_rules: Describes the managedRules structure. + :type managed_rules: ~azure.mgmt.network.v2020_08_01.models.ManagedRulesDefinition + :ivar http_listeners: A collection of references to application gateway http listeners. + :vartype http_listeners: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar path_based_rules: A collection of references to application gateway path rules. + :vartype path_based_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'application_gateways': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_state': {'readonly': True}, + 'http_listeners': {'readonly': True}, + 'path_based_rules': {'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'}, + 'policy_settings': {'key': 'properties.policySettings', 'type': 'PolicySettings'}, + 'custom_rules': {'key': 'properties.customRules', 'type': '[WebApplicationFirewallCustomRule]'}, + 'application_gateways': {'key': 'properties.applicationGateways', 'type': '[ApplicationGateway]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_state': {'key': 'properties.resourceState', 'type': 'str'}, + 'managed_rules': {'key': 'properties.managedRules', 'type': 'ManagedRulesDefinition'}, + 'http_listeners': {'key': 'properties.httpListeners', 'type': '[SubResource]'}, + 'path_based_rules': {'key': 'properties.pathBasedRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(WebApplicationFirewallPolicy, self).__init__(**kwargs) + self.etag = None + self.policy_settings = kwargs.get('policy_settings', None) + self.custom_rules = kwargs.get('custom_rules', None) + self.application_gateways = None + self.provisioning_state = None + self.resource_state = None + self.managed_rules = kwargs.get('managed_rules', None) + self.http_listeners = None + self.path_based_rules = None + + +class WebApplicationFirewallPolicyListResult(msrest.serialization.Model): + """Result of the request to list WebApplicationFirewallPolicies. It contains a list of WebApplicationFirewallPolicy objects and a URL link to get the next set of results. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar value: List of WebApplicationFirewallPolicies within a resource group. + :vartype value: list[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy] + :ivar next_link: URL to get the next set of WebApplicationFirewallPolicy objects if there are + any. + :vartype next_link: str + """ + + _validation = { + 'value': {'readonly': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebApplicationFirewallPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebApplicationFirewallPolicyListResult, self).__init__(**kwargs) + self.value = None + self.next_link = None diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models_py3.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models_py3.py new file mode 100644 index 000000000000..f401dec9b10d --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_models_py3.py @@ -0,0 +1,25167 @@ +# 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 ._network_management_client_enums import * + + +class AadAuthenticationParameters(msrest.serialization.Model): + """AAD Vpn authentication type related parameters. + + :param aad_tenant: AAD Vpn authentication parameter AAD tenant. + :type aad_tenant: str + :param aad_audience: AAD Vpn authentication parameter AAD audience. + :type aad_audience: str + :param aad_issuer: AAD Vpn authentication parameter AAD issuer. + :type aad_issuer: str + """ + + _attribute_map = { + 'aad_tenant': {'key': 'aadTenant', 'type': 'str'}, + 'aad_audience': {'key': 'aadAudience', 'type': 'str'}, + 'aad_issuer': {'key': 'aadIssuer', 'type': 'str'}, + } + + def __init__( + self, + *, + aad_tenant: Optional[str] = None, + aad_audience: Optional[str] = None, + aad_issuer: Optional[str] = None, + **kwargs + ): + super(AadAuthenticationParameters, self).__init__(**kwargs) + self.aad_tenant = aad_tenant + self.aad_audience = aad_audience + self.aad_issuer = aad_issuer + + +class AddressSpace(msrest.serialization.Model): + """AddressSpace contains an array of IP address ranges that can be used by subnets of the virtual network. + + :param address_prefixes: A list of address blocks reserved for this virtual network in CIDR + notation. + :type address_prefixes: list[str] + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + } + + def __init__( + self, + *, + address_prefixes: Optional[List[str]] = None, + **kwargs + ): + super(AddressSpace, self).__init__(**kwargs) + self.address_prefixes = address_prefixes + + +class Resource(msrest.serialization.Model): + """Common resource representation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 = { + '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, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + self.location = location + self.tags = tags + + +class ApplicationGateway(Resource): + """Application gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting where the resource needs to come from. + :type zones: list[str] + :param identity: The identity of the application gateway, if configured. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :param sku: SKU of the application gateway resource. + :type sku: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySku + :param ssl_policy: SSL policy of the application gateway resource. + :type ssl_policy: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicy + :ivar operational_state: Operational state of the application gateway resource. Possible values + include: "Stopped", "Starting", "Running", "Stopping". + :vartype operational_state: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayOperationalState + :param gateway_ip_configurations: Subnets of the application gateway resource. For default + limits, see `Application Gateway limits `_. + :type gateway_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayIPConfiguration] + :param authentication_certificates: Authentication certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type authentication_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAuthenticationCertificate] + :param trusted_root_certificates: Trusted Root certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type trusted_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTrustedRootCertificate] + :param trusted_client_certificates: Trusted client certificates of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type trusted_client_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTrustedClientCertificate] + :param ssl_certificates: SSL certificates of the application gateway resource. For default + limits, see `Application Gateway limits `_. + :type ssl_certificates: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCertificate] + :param frontend_ip_configurations: Frontend IP addresses of the application gateway resource. + For default limits, see `Application Gateway limits `_. + :type frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFrontendIPConfiguration] + :param frontend_ports: Frontend ports of the application gateway resource. For default limits, + see `Application Gateway limits `_. + :type frontend_ports: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFrontendPort] + :param probes: Probes of the application gateway resource. + :type probes: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbe] + :param backend_address_pools: Backend address pool of the application gateway resource. For + default limits, see `Application Gateway limits `_. + :type backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool] + :param backend_http_settings_collection: Backend http settings of the application gateway + resource. For default limits, see `Application Gateway limits + `_. + :type backend_http_settings_collection: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHttpSettings] + :param http_listeners: Http listeners of the application gateway resource. For default limits, + see `Application Gateway limits `_. + :type http_listeners: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHttpListener] + :param ssl_profiles: SSL profiles of the application gateway resource. For default limits, see + `Application Gateway limits `_. + :type ssl_profiles: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProfile] + :param url_path_maps: URL path map of the application gateway resource. For default limits, see + `Application Gateway limits `_. + :type url_path_maps: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayUrlPathMap] + :param request_routing_rules: Request routing rules of the application gateway resource. + :type request_routing_rules: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRequestRoutingRule] + :param rewrite_rule_sets: Rewrite rules for the application gateway resource. + :type rewrite_rule_sets: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleSet] + :param redirect_configurations: Redirect configurations of the application gateway resource. + For default limits, see `Application Gateway limits `_. + :type redirect_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRedirectConfiguration] + :param web_application_firewall_configuration: Web application firewall configuration. + :type web_application_firewall_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayWebApplicationFirewallConfiguration + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_http2: Whether HTTP2 is enabled on the application gateway resource. + :type enable_http2: bool + :param enable_fips: Whether FIPS is enabled on the application gateway resource. + :type enable_fips: bool + :param autoscale_configuration: Autoscale Configuration. + :type autoscale_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAutoscaleConfiguration + :param private_link_configurations: PrivateLink configurations on application gateway. + :type private_link_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkConfiguration] + :ivar private_endpoint_connections: Private Endpoint connections on application gateway. + :vartype private_endpoint_connections: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :ivar resource_guid: The resource GUID property of the application gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the application gateway resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param custom_error_configurations: Custom error configurations of the application gateway + resource. + :type custom_error_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomError] + :param force_firewall_policy_association: If true, associates a firewall policy with an + application gateway regardless whether the policy differs from the WAF Config. + :type force_firewall_policy_association: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'operational_state': {'readonly': True}, + 'private_endpoint_connections': {'readonly': True}, + 'resource_guid': {'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'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'sku': {'key': 'properties.sku', 'type': 'ApplicationGatewaySku'}, + 'ssl_policy': {'key': 'properties.sslPolicy', 'type': 'ApplicationGatewaySslPolicy'}, + 'operational_state': {'key': 'properties.operationalState', 'type': 'str'}, + 'gateway_ip_configurations': {'key': 'properties.gatewayIPConfigurations', 'type': '[ApplicationGatewayIPConfiguration]'}, + 'authentication_certificates': {'key': 'properties.authenticationCertificates', 'type': '[ApplicationGatewayAuthenticationCertificate]'}, + 'trusted_root_certificates': {'key': 'properties.trustedRootCertificates', 'type': '[ApplicationGatewayTrustedRootCertificate]'}, + 'trusted_client_certificates': {'key': 'properties.trustedClientCertificates', 'type': '[ApplicationGatewayTrustedClientCertificate]'}, + 'ssl_certificates': {'key': 'properties.sslCertificates', 'type': '[ApplicationGatewaySslCertificate]'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[ApplicationGatewayFrontendIPConfiguration]'}, + 'frontend_ports': {'key': 'properties.frontendPorts', 'type': '[ApplicationGatewayFrontendPort]'}, + 'probes': {'key': 'properties.probes', 'type': '[ApplicationGatewayProbe]'}, + 'backend_address_pools': {'key': 'properties.backendAddressPools', 'type': '[ApplicationGatewayBackendAddressPool]'}, + 'backend_http_settings_collection': {'key': 'properties.backendHttpSettingsCollection', 'type': '[ApplicationGatewayBackendHttpSettings]'}, + 'http_listeners': {'key': 'properties.httpListeners', 'type': '[ApplicationGatewayHttpListener]'}, + 'ssl_profiles': {'key': 'properties.sslProfiles', 'type': '[ApplicationGatewaySslProfile]'}, + 'url_path_maps': {'key': 'properties.urlPathMaps', 'type': '[ApplicationGatewayUrlPathMap]'}, + 'request_routing_rules': {'key': 'properties.requestRoutingRules', 'type': '[ApplicationGatewayRequestRoutingRule]'}, + 'rewrite_rule_sets': {'key': 'properties.rewriteRuleSets', 'type': '[ApplicationGatewayRewriteRuleSet]'}, + 'redirect_configurations': {'key': 'properties.redirectConfigurations', 'type': '[ApplicationGatewayRedirectConfiguration]'}, + 'web_application_firewall_configuration': {'key': 'properties.webApplicationFirewallConfiguration', 'type': 'ApplicationGatewayWebApplicationFirewallConfiguration'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'enable_http2': {'key': 'properties.enableHttp2', 'type': 'bool'}, + 'enable_fips': {'key': 'properties.enableFips', 'type': 'bool'}, + 'autoscale_configuration': {'key': 'properties.autoscaleConfiguration', 'type': 'ApplicationGatewayAutoscaleConfiguration'}, + 'private_link_configurations': {'key': 'properties.privateLinkConfigurations', 'type': '[ApplicationGatewayPrivateLinkConfiguration]'}, + 'private_endpoint_connections': {'key': 'properties.privateEndpointConnections', 'type': '[ApplicationGatewayPrivateEndpointConnection]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'custom_error_configurations': {'key': 'properties.customErrorConfigurations', 'type': '[ApplicationGatewayCustomError]'}, + 'force_firewall_policy_association': {'key': 'properties.forceFirewallPolicyAssociation', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + zones: Optional[List[str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + sku: Optional["ApplicationGatewaySku"] = None, + ssl_policy: Optional["ApplicationGatewaySslPolicy"] = None, + gateway_ip_configurations: Optional[List["ApplicationGatewayIPConfiguration"]] = None, + authentication_certificates: Optional[List["ApplicationGatewayAuthenticationCertificate"]] = None, + trusted_root_certificates: Optional[List["ApplicationGatewayTrustedRootCertificate"]] = None, + trusted_client_certificates: Optional[List["ApplicationGatewayTrustedClientCertificate"]] = None, + ssl_certificates: Optional[List["ApplicationGatewaySslCertificate"]] = None, + frontend_ip_configurations: Optional[List["ApplicationGatewayFrontendIPConfiguration"]] = None, + frontend_ports: Optional[List["ApplicationGatewayFrontendPort"]] = None, + probes: Optional[List["ApplicationGatewayProbe"]] = None, + backend_address_pools: Optional[List["ApplicationGatewayBackendAddressPool"]] = None, + backend_http_settings_collection: Optional[List["ApplicationGatewayBackendHttpSettings"]] = None, + http_listeners: Optional[List["ApplicationGatewayHttpListener"]] = None, + ssl_profiles: Optional[List["ApplicationGatewaySslProfile"]] = None, + url_path_maps: Optional[List["ApplicationGatewayUrlPathMap"]] = None, + request_routing_rules: Optional[List["ApplicationGatewayRequestRoutingRule"]] = None, + rewrite_rule_sets: Optional[List["ApplicationGatewayRewriteRuleSet"]] = None, + redirect_configurations: Optional[List["ApplicationGatewayRedirectConfiguration"]] = None, + web_application_firewall_configuration: Optional["ApplicationGatewayWebApplicationFirewallConfiguration"] = None, + firewall_policy: Optional["SubResource"] = None, + enable_http2: Optional[bool] = None, + enable_fips: Optional[bool] = None, + autoscale_configuration: Optional["ApplicationGatewayAutoscaleConfiguration"] = None, + private_link_configurations: Optional[List["ApplicationGatewayPrivateLinkConfiguration"]] = None, + custom_error_configurations: Optional[List["ApplicationGatewayCustomError"]] = None, + force_firewall_policy_association: Optional[bool] = None, + **kwargs + ): + super(ApplicationGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.zones = zones + self.identity = identity + self.sku = sku + self.ssl_policy = ssl_policy + self.operational_state = None + self.gateway_ip_configurations = gateway_ip_configurations + self.authentication_certificates = authentication_certificates + self.trusted_root_certificates = trusted_root_certificates + self.trusted_client_certificates = trusted_client_certificates + self.ssl_certificates = ssl_certificates + self.frontend_ip_configurations = frontend_ip_configurations + self.frontend_ports = frontend_ports + self.probes = probes + self.backend_address_pools = backend_address_pools + self.backend_http_settings_collection = backend_http_settings_collection + self.http_listeners = http_listeners + self.ssl_profiles = ssl_profiles + self.url_path_maps = url_path_maps + self.request_routing_rules = request_routing_rules + self.rewrite_rule_sets = rewrite_rule_sets + self.redirect_configurations = redirect_configurations + self.web_application_firewall_configuration = web_application_firewall_configuration + self.firewall_policy = firewall_policy + self.enable_http2 = enable_http2 + self.enable_fips = enable_fips + self.autoscale_configuration = autoscale_configuration + self.private_link_configurations = private_link_configurations + self.private_endpoint_connections = None + self.resource_guid = None + self.provisioning_state = None + self.custom_error_configurations = custom_error_configurations + self.force_firewall_policy_association = force_firewall_policy_association + + +class SubResource(msrest.serialization.Model): + """Reference to another subresource. + + :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 ApplicationGatewayAuthenticationCertificate(SubResource): + """Authentication certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the authentication certificate that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :ivar provisioning_state: The provisioning state of the authentication certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + data: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayAuthenticationCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.data = data + self.provisioning_state = None + + +class ApplicationGatewayAutoscaleConfiguration(msrest.serialization.Model): + """Application Gateway autoscale configuration. + + All required parameters must be populated in order to send to Azure. + + :param min_capacity: Required. Lower bound on number of Application Gateway capacity. + :type min_capacity: int + :param max_capacity: Upper bound on number of Application Gateway capacity. + :type max_capacity: int + """ + + _validation = { + 'min_capacity': {'required': True, 'minimum': 0}, + 'max_capacity': {'minimum': 2}, + } + + _attribute_map = { + 'min_capacity': {'key': 'minCapacity', 'type': 'int'}, + 'max_capacity': {'key': 'maxCapacity', 'type': 'int'}, + } + + def __init__( + self, + *, + min_capacity: int, + max_capacity: Optional[int] = None, + **kwargs + ): + super(ApplicationGatewayAutoscaleConfiguration, self).__init__(**kwargs) + self.min_capacity = min_capacity + self.max_capacity = max_capacity + + +class ApplicationGatewayAvailableSslOptions(Resource): + """Response for ApplicationGatewayAvailableSslOptions API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 predefined_policies: List of available Ssl predefined policy. + :type predefined_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param default_policy: Name of the Ssl predefined policy applied by default to application + gateway. Possible values include: "AppGwSslPolicy20150501", "AppGwSslPolicy20170401", + "AppGwSslPolicy20170401S". + :type default_policy: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyName + :param available_cipher_suites: List of available Ssl cipher suites. + :type available_cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param available_protocols: List of available Ssl protocols. + :type available_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol] + """ + + _validation = { + '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}'}, + 'predefined_policies': {'key': 'properties.predefinedPolicies', 'type': '[SubResource]'}, + 'default_policy': {'key': 'properties.defaultPolicy', 'type': 'str'}, + 'available_cipher_suites': {'key': 'properties.availableCipherSuites', 'type': '[str]'}, + 'available_protocols': {'key': 'properties.availableProtocols', 'type': '[str]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + predefined_policies: Optional[List["SubResource"]] = None, + default_policy: Optional[Union[str, "ApplicationGatewaySslPolicyName"]] = None, + available_cipher_suites: Optional[List[Union[str, "ApplicationGatewaySslCipherSuite"]]] = None, + available_protocols: Optional[List[Union[str, "ApplicationGatewaySslProtocol"]]] = None, + **kwargs + ): + super(ApplicationGatewayAvailableSslOptions, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.predefined_policies = predefined_policies + self.default_policy = default_policy + self.available_cipher_suites = available_cipher_suites + self.available_protocols = available_protocols + + +class ApplicationGatewayAvailableSslPredefinedPolicies(msrest.serialization.Model): + """Response for ApplicationGatewayAvailableSslOptions API service call. + + :param value: List of available Ssl predefined policy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPredefinedPolicy] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewaySslPredefinedPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationGatewaySslPredefinedPolicy"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayAvailableSslPredefinedPolicies, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ApplicationGatewayAvailableWafRuleSetsResult(msrest.serialization.Model): + """Response for ApplicationGatewayAvailableWafRuleSets API service call. + + :param value: The list of application gateway rule sets. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRuleSet] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayFirewallRuleSet]'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationGatewayFirewallRuleSet"]] = None, + **kwargs + ): + super(ApplicationGatewayAvailableWafRuleSetsResult, self).__init__(**kwargs) + self.value = value + + +class ApplicationGatewayBackendAddress(msrest.serialization.Model): + """Backend address of an application gateway. + + :param fqdn: Fully qualified domain name (FQDN). + :type fqdn: str + :param ip_address: IP address. + :type ip_address: str + """ + + _attribute_map = { + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + fqdn: Optional[str] = None, + ip_address: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayBackendAddress, self).__init__(**kwargs) + self.fqdn = fqdn + self.ip_address = ip_address + + +class ApplicationGatewayBackendAddressPool(SubResource): + """Backend Address Pool of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the backend address pool that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar backend_ip_configurations: Collection of references to IPs defined in network interfaces. + :vartype backend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :param backend_addresses: Backend addresses. + :type backend_addresses: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddress] + :ivar provisioning_state: The provisioning state of the backend address pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configurations': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backend_ip_configurations': {'key': 'properties.backendIPConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'backend_addresses': {'key': 'properties.backendAddresses', 'type': '[ApplicationGatewayBackendAddress]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + backend_addresses: Optional[List["ApplicationGatewayBackendAddress"]] = None, + **kwargs + ): + super(ApplicationGatewayBackendAddressPool, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.backend_ip_configurations = None + self.backend_addresses = backend_addresses + self.provisioning_state = None + + +class ApplicationGatewayBackendHealth(msrest.serialization.Model): + """Response for ApplicationGatewayBackendHealth API service call. + + :param backend_address_pools: A list of ApplicationGatewayBackendHealthPool resources. + :type backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthPool] + """ + + _attribute_map = { + 'backend_address_pools': {'key': 'backendAddressPools', 'type': '[ApplicationGatewayBackendHealthPool]'}, + } + + def __init__( + self, + *, + backend_address_pools: Optional[List["ApplicationGatewayBackendHealthPool"]] = None, + **kwargs + ): + super(ApplicationGatewayBackendHealth, self).__init__(**kwargs) + self.backend_address_pools = backend_address_pools + + +class ApplicationGatewayBackendHealthHttpSettings(msrest.serialization.Model): + """Application gateway BackendHealthHttp settings. + + :param backend_http_settings: Reference to an ApplicationGatewayBackendHttpSettings resource. + :type backend_http_settings: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHttpSettings + :param servers: List of ApplicationGatewayBackendHealthServer resources. + :type servers: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthServer] + """ + + _attribute_map = { + 'backend_http_settings': {'key': 'backendHttpSettings', 'type': 'ApplicationGatewayBackendHttpSettings'}, + 'servers': {'key': 'servers', 'type': '[ApplicationGatewayBackendHealthServer]'}, + } + + def __init__( + self, + *, + backend_http_settings: Optional["ApplicationGatewayBackendHttpSettings"] = None, + servers: Optional[List["ApplicationGatewayBackendHealthServer"]] = None, + **kwargs + ): + super(ApplicationGatewayBackendHealthHttpSettings, self).__init__(**kwargs) + self.backend_http_settings = backend_http_settings + self.servers = servers + + +class ApplicationGatewayBackendHealthOnDemand(msrest.serialization.Model): + """Result of on demand test probe. + + :param backend_address_pool: Reference to an ApplicationGatewayBackendAddressPool resource. + :type backend_address_pool: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool + :param backend_health_http_settings: Application gateway BackendHealthHttp settings. + :type backend_health_http_settings: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthHttpSettings + """ + + _attribute_map = { + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'ApplicationGatewayBackendAddressPool'}, + 'backend_health_http_settings': {'key': 'backendHealthHttpSettings', 'type': 'ApplicationGatewayBackendHealthHttpSettings'}, + } + + def __init__( + self, + *, + backend_address_pool: Optional["ApplicationGatewayBackendAddressPool"] = None, + backend_health_http_settings: Optional["ApplicationGatewayBackendHealthHttpSettings"] = None, + **kwargs + ): + super(ApplicationGatewayBackendHealthOnDemand, self).__init__(**kwargs) + self.backend_address_pool = backend_address_pool + self.backend_health_http_settings = backend_health_http_settings + + +class ApplicationGatewayBackendHealthPool(msrest.serialization.Model): + """Application gateway BackendHealth pool. + + :param backend_address_pool: Reference to an ApplicationGatewayBackendAddressPool resource. + :type backend_address_pool: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool + :param backend_http_settings_collection: List of ApplicationGatewayBackendHealthHttpSettings + resources. + :type backend_http_settings_collection: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthHttpSettings] + """ + + _attribute_map = { + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'ApplicationGatewayBackendAddressPool'}, + 'backend_http_settings_collection': {'key': 'backendHttpSettingsCollection', 'type': '[ApplicationGatewayBackendHealthHttpSettings]'}, + } + + def __init__( + self, + *, + backend_address_pool: Optional["ApplicationGatewayBackendAddressPool"] = None, + backend_http_settings_collection: Optional[List["ApplicationGatewayBackendHealthHttpSettings"]] = None, + **kwargs + ): + super(ApplicationGatewayBackendHealthPool, self).__init__(**kwargs) + self.backend_address_pool = backend_address_pool + self.backend_http_settings_collection = backend_http_settings_collection + + +class ApplicationGatewayBackendHealthServer(msrest.serialization.Model): + """Application gateway backendhealth http settings. + + :param address: IP address or FQDN of backend server. + :type address: str + :param ip_configuration: Reference to IP configuration of backend server. + :type ip_configuration: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param health: Health of backend server. Possible values include: "Unknown", "Up", "Down", + "Partial", "Draining". + :type health: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthServerHealth + :param health_probe_log: Health Probe Log. + :type health_probe_log: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + 'ip_configuration': {'key': 'ipConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'health': {'key': 'health', 'type': 'str'}, + 'health_probe_log': {'key': 'healthProbeLog', 'type': 'str'}, + } + + def __init__( + self, + *, + address: Optional[str] = None, + ip_configuration: Optional["NetworkInterfaceIPConfiguration"] = None, + health: Optional[Union[str, "ApplicationGatewayBackendHealthServerHealth"]] = None, + health_probe_log: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayBackendHealthServer, self).__init__(**kwargs) + self.address = address + self.ip_configuration = ip_configuration + self.health = health + self.health_probe_log = health_probe_log + + +class ApplicationGatewayBackendHttpSettings(SubResource): + """Backend address pool settings of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the backend http settings that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param port: The destination port on the backend. + :type port: int + :param protocol: The protocol used to communicate with the backend. Possible values include: + "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param cookie_based_affinity: Cookie based affinity. Possible values include: "Enabled", + "Disabled". + :type cookie_based_affinity: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCookieBasedAffinity + :param request_timeout: Request timeout in seconds. Application Gateway will fail the request + if response is not received within RequestTimeout. Acceptable values are from 1 second to 86400 + seconds. + :type request_timeout: int + :param probe: Probe resource of an application gateway. + :type probe: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param authentication_certificates: Array of references to application gateway authentication + certificates. + :type authentication_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param trusted_root_certificates: Array of references to application gateway trusted root + certificates. + :type trusted_root_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param connection_draining: Connection draining of the backend http settings resource. + :type connection_draining: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayConnectionDraining + :param host_name: Host header to be sent to the backend servers. + :type host_name: str + :param pick_host_name_from_backend_address: Whether to pick host header should be picked from + the host name of the backend server. Default value is false. + :type pick_host_name_from_backend_address: bool + :param affinity_cookie_name: Cookie name to use for the affinity cookie. + :type affinity_cookie_name: str + :param probe_enabled: Whether the probe is enabled. Default value is false. + :type probe_enabled: bool + :param path: Path which should be used as a prefix for all HTTP requests. Null means no path + will be prefixed. Default value is null. + :type path: str + :ivar provisioning_state: The provisioning state of the backend HTTP settings resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'cookie_based_affinity': {'key': 'properties.cookieBasedAffinity', 'type': 'str'}, + 'request_timeout': {'key': 'properties.requestTimeout', 'type': 'int'}, + 'probe': {'key': 'properties.probe', 'type': 'SubResource'}, + 'authentication_certificates': {'key': 'properties.authenticationCertificates', 'type': '[SubResource]'}, + 'trusted_root_certificates': {'key': 'properties.trustedRootCertificates', 'type': '[SubResource]'}, + 'connection_draining': {'key': 'properties.connectionDraining', 'type': 'ApplicationGatewayConnectionDraining'}, + 'host_name': {'key': 'properties.hostName', 'type': 'str'}, + 'pick_host_name_from_backend_address': {'key': 'properties.pickHostNameFromBackendAddress', 'type': 'bool'}, + 'affinity_cookie_name': {'key': 'properties.affinityCookieName', 'type': 'str'}, + 'probe_enabled': {'key': 'properties.probeEnabled', 'type': 'bool'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + port: Optional[int] = None, + protocol: Optional[Union[str, "ApplicationGatewayProtocol"]] = None, + cookie_based_affinity: Optional[Union[str, "ApplicationGatewayCookieBasedAffinity"]] = None, + request_timeout: Optional[int] = None, + probe: Optional["SubResource"] = None, + authentication_certificates: Optional[List["SubResource"]] = None, + trusted_root_certificates: Optional[List["SubResource"]] = None, + connection_draining: Optional["ApplicationGatewayConnectionDraining"] = None, + host_name: Optional[str] = None, + pick_host_name_from_backend_address: Optional[bool] = None, + affinity_cookie_name: Optional[str] = None, + probe_enabled: Optional[bool] = None, + path: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayBackendHttpSettings, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.port = port + self.protocol = protocol + self.cookie_based_affinity = cookie_based_affinity + self.request_timeout = request_timeout + self.probe = probe + self.authentication_certificates = authentication_certificates + self.trusted_root_certificates = trusted_root_certificates + self.connection_draining = connection_draining + self.host_name = host_name + self.pick_host_name_from_backend_address = pick_host_name_from_backend_address + self.affinity_cookie_name = affinity_cookie_name + self.probe_enabled = probe_enabled + self.path = path + self.provisioning_state = None + + +class ApplicationGatewayClientAuthConfiguration(msrest.serialization.Model): + """Application gateway client authentication configuration. + + :param verify_client_cert_issuer_dn: Verify client certificate issuer name on the application + gateway. + :type verify_client_cert_issuer_dn: bool + """ + + _attribute_map = { + 'verify_client_cert_issuer_dn': {'key': 'verifyClientCertIssuerDN', 'type': 'bool'}, + } + + def __init__( + self, + *, + verify_client_cert_issuer_dn: Optional[bool] = None, + **kwargs + ): + super(ApplicationGatewayClientAuthConfiguration, self).__init__(**kwargs) + self.verify_client_cert_issuer_dn = verify_client_cert_issuer_dn + + +class ApplicationGatewayConnectionDraining(msrest.serialization.Model): + """Connection draining allows open connections to a backend server to be active for a specified time after the backend server got removed from the configuration. + + All required parameters must be populated in order to send to Azure. + + :param enabled: Required. Whether connection draining is enabled or not. + :type enabled: bool + :param drain_timeout_in_sec: Required. The number of seconds connection draining is active. + Acceptable values are from 1 second to 3600 seconds. + :type drain_timeout_in_sec: int + """ + + _validation = { + 'enabled': {'required': True}, + 'drain_timeout_in_sec': {'required': True, 'maximum': 3600, 'minimum': 1}, + } + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'drain_timeout_in_sec': {'key': 'drainTimeoutInSec', 'type': 'int'}, + } + + def __init__( + self, + *, + enabled: bool, + drain_timeout_in_sec: int, + **kwargs + ): + super(ApplicationGatewayConnectionDraining, self).__init__(**kwargs) + self.enabled = enabled + self.drain_timeout_in_sec = drain_timeout_in_sec + + +class ApplicationGatewayCustomError(msrest.serialization.Model): + """Customer error of an application gateway. + + :param status_code: Status code of the application gateway customer error. Possible values + include: "HttpStatus403", "HttpStatus502". + :type status_code: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomErrorStatusCode + :param custom_error_page_url: Error page URL of the application gateway customer error. + :type custom_error_page_url: str + """ + + _attribute_map = { + 'status_code': {'key': 'statusCode', 'type': 'str'}, + 'custom_error_page_url': {'key': 'customErrorPageUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + status_code: Optional[Union[str, "ApplicationGatewayCustomErrorStatusCode"]] = None, + custom_error_page_url: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayCustomError, self).__init__(**kwargs) + self.status_code = status_code + self.custom_error_page_url = custom_error_page_url + + +class ApplicationGatewayFirewallDisabledRuleGroup(msrest.serialization.Model): + """Allows to disable rules within a rule group or an entire rule group. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The name of the rule group that will be disabled. + :type rule_group_name: str + :param rules: The list of rules that will be disabled. If null, all rules of the rule group + will be disabled. + :type rules: list[int] + """ + + _validation = { + 'rule_group_name': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[int]'}, + } + + def __init__( + self, + *, + rule_group_name: str, + rules: Optional[List[int]] = None, + **kwargs + ): + super(ApplicationGatewayFirewallDisabledRuleGroup, self).__init__(**kwargs) + self.rule_group_name = rule_group_name + self.rules = rules + + +class ApplicationGatewayFirewallExclusion(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param match_variable: Required. The variable to be excluded. + :type match_variable: str + :param selector_match_operator: Required. When matchVariable is a collection, operate on the + selector to specify which elements in the collection this exclusion applies to. + :type selector_match_operator: str + :param selector: Required. When matchVariable is a collection, operator used to specify which + elements in the collection this exclusion applies to. + :type selector: str + """ + + _validation = { + 'match_variable': {'required': True}, + 'selector_match_operator': {'required': True}, + 'selector': {'required': True}, + } + + _attribute_map = { + 'match_variable': {'key': 'matchVariable', 'type': 'str'}, + 'selector_match_operator': {'key': 'selectorMatchOperator', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + *, + match_variable: str, + selector_match_operator: str, + selector: str, + **kwargs + ): + super(ApplicationGatewayFirewallExclusion, self).__init__(**kwargs) + self.match_variable = match_variable + self.selector_match_operator = selector_match_operator + self.selector = selector + + +class ApplicationGatewayFirewallRule(msrest.serialization.Model): + """A web application firewall rule. + + All required parameters must be populated in order to send to Azure. + + :param rule_id: Required. The identifier of the web application firewall rule. + :type rule_id: int + :param description: The description of the web application firewall rule. + :type description: str + """ + + _validation = { + 'rule_id': {'required': True}, + } + + _attribute_map = { + 'rule_id': {'key': 'ruleId', 'type': 'int'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + rule_id: int, + description: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayFirewallRule, self).__init__(**kwargs) + self.rule_id = rule_id + self.description = description + + +class ApplicationGatewayFirewallRuleGroup(msrest.serialization.Model): + """A web application firewall rule group. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The name of the web application firewall rule group. + :type rule_group_name: str + :param description: The description of the web application firewall rule group. + :type description: str + :param rules: Required. The rules of the web application firewall rule group. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRule] + """ + + _validation = { + 'rule_group_name': {'required': True}, + 'rules': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[ApplicationGatewayFirewallRule]'}, + } + + def __init__( + self, + *, + rule_group_name: str, + rules: List["ApplicationGatewayFirewallRule"], + description: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayFirewallRuleGroup, self).__init__(**kwargs) + self.rule_group_name = rule_group_name + self.description = description + self.rules = rules + + +class ApplicationGatewayFirewallRuleSet(Resource): + """A web application firewall rule set. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar provisioning_state: The provisioning state of the web application firewall rule set. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param rule_set_type: The type of the web application firewall rule set. + :type rule_set_type: str + :param rule_set_version: The version of the web application firewall rule set type. + :type rule_set_version: str + :param rule_groups: The rule groups of the web application firewall rule set. + :type rule_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallRuleGroup] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'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}'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'rule_set_type': {'key': 'properties.ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'properties.ruleSetVersion', 'type': 'str'}, + 'rule_groups': {'key': 'properties.ruleGroups', 'type': '[ApplicationGatewayFirewallRuleGroup]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + rule_set_type: Optional[str] = None, + rule_set_version: Optional[str] = None, + rule_groups: Optional[List["ApplicationGatewayFirewallRuleGroup"]] = None, + **kwargs + ): + super(ApplicationGatewayFirewallRuleSet, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.provisioning_state = None + self.rule_set_type = rule_set_type + self.rule_set_version = rule_set_version + self.rule_groups = rule_groups + + +class ApplicationGatewayFrontendIPConfiguration(SubResource): + """Frontend IP configuration of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the frontend IP configuration that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param private_ip_address: PrivateIPAddress of the network interface IP Configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: Reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference to the PublicIP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param private_link_configuration: Reference to the application gateway private link + configuration. + :type private_link_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the frontend IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'private_link_configuration': {'key': 'properties.privateLinkConfiguration', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["SubResource"] = None, + public_ip_address: Optional["SubResource"] = None, + private_link_configuration: Optional["SubResource"] = None, + **kwargs + ): + super(ApplicationGatewayFrontendIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.public_ip_address = public_ip_address + self.private_link_configuration = private_link_configuration + self.provisioning_state = None + + +class ApplicationGatewayFrontendPort(SubResource): + """Frontend port of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the frontend port that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param port: Frontend port. + :type port: int + :ivar provisioning_state: The provisioning state of the frontend port resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + port: Optional[int] = None, + **kwargs + ): + super(ApplicationGatewayFrontendPort, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.port = port + self.provisioning_state = None + + +class ApplicationGatewayHeaderConfiguration(msrest.serialization.Model): + """Header configuration of the Actions set in Application Gateway. + + :param header_name: Header name of the header configuration. + :type header_name: str + :param header_value: Header value of the header configuration. + :type header_value: str + """ + + _attribute_map = { + 'header_name': {'key': 'headerName', 'type': 'str'}, + 'header_value': {'key': 'headerValue', 'type': 'str'}, + } + + def __init__( + self, + *, + header_name: Optional[str] = None, + header_value: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayHeaderConfiguration, self).__init__(**kwargs) + self.header_name = header_name + self.header_value = header_value + + +class ApplicationGatewayHttpListener(SubResource): + """Http listener of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the HTTP listener that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: Frontend IP configuration resource of an application gateway. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param frontend_port: Frontend port resource of an application gateway. + :type frontend_port: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: Protocol of the HTTP listener. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host_name: Host name of HTTP listener. + :type host_name: str + :param ssl_certificate: SSL certificate resource of an application gateway. + :type ssl_certificate: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ssl_profile: SSL profile resource of the application gateway. + :type ssl_profile: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param require_server_name_indication: Applicable only if protocol is https. Enables SNI for + multi-hosting. + :type require_server_name_indication: bool + :ivar provisioning_state: The provisioning state of the HTTP listener resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param custom_error_configurations: Custom error configurations of the HTTP listener. + :type custom_error_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayCustomError] + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param host_names: List of Host names for HTTP Listener that allows special wildcard characters + as well. + :type host_names: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'host_name': {'key': 'properties.hostName', 'type': 'str'}, + 'ssl_certificate': {'key': 'properties.sslCertificate', 'type': 'SubResource'}, + 'ssl_profile': {'key': 'properties.sslProfile', 'type': 'SubResource'}, + 'require_server_name_indication': {'key': 'properties.requireServerNameIndication', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'custom_error_configurations': {'key': 'properties.customErrorConfigurations', 'type': '[ApplicationGatewayCustomError]'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + frontend_ip_configuration: Optional["SubResource"] = None, + frontend_port: Optional["SubResource"] = None, + protocol: Optional[Union[str, "ApplicationGatewayProtocol"]] = None, + host_name: Optional[str] = None, + ssl_certificate: Optional["SubResource"] = None, + ssl_profile: Optional["SubResource"] = None, + require_server_name_indication: Optional[bool] = None, + custom_error_configurations: Optional[List["ApplicationGatewayCustomError"]] = None, + firewall_policy: Optional["SubResource"] = None, + host_names: Optional[List[str]] = None, + **kwargs + ): + super(ApplicationGatewayHttpListener, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.frontend_ip_configuration = frontend_ip_configuration + self.frontend_port = frontend_port + self.protocol = protocol + self.host_name = host_name + self.ssl_certificate = ssl_certificate + self.ssl_profile = ssl_profile + self.require_server_name_indication = require_server_name_indication + self.provisioning_state = None + self.custom_error_configurations = custom_error_configurations + self.firewall_policy = firewall_policy + self.host_names = host_names + + +class ApplicationGatewayIPConfiguration(SubResource): + """IP configuration of an application gateway. Currently 1 public and 1 private IP configuration is allowed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the IP configuration that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param subnet: Reference to the subnet resource. A subnet from where application gateway gets + its private address. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the application gateway IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + subnet: Optional["SubResource"] = None, + **kwargs + ): + super(ApplicationGatewayIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.subnet = subnet + self.provisioning_state = None + + +class ApplicationGatewayListResult(msrest.serialization.Model): + """Response for ListApplicationGateways API service call. + + :param value: List of an application gateways in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationGateway"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ApplicationGatewayOnDemandProbe(msrest.serialization.Model): + """Details of on demand test probe request. + + :param protocol: The protocol used for the probe. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host: Host name to send the probe to. + :type host: str + :param path: Relative path of probe. Valid path starts from '/'. Probe is sent to + :code:``://:code:``::code:``:code:``. + :type path: str + :param timeout: The probe timeout in seconds. Probe marked as failed if valid response is not + received with this timeout period. Acceptable values are from 1 second to 86400 seconds. + :type timeout: int + :param pick_host_name_from_backend_http_settings: Whether the host header should be picked from + the backend http settings. Default value is false. + :type pick_host_name_from_backend_http_settings: bool + :param match: Criterion for classifying a healthy probe response. + :type match: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbeHealthResponseMatch + :param backend_address_pool: Reference to backend pool of application gateway to which probe + request will be sent. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Reference to backend http setting of application gateway to be + used for test probe. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'host': {'key': 'host', 'type': 'str'}, + 'path': {'key': 'path', 'type': 'str'}, + 'timeout': {'key': 'timeout', 'type': 'int'}, + 'pick_host_name_from_backend_http_settings': {'key': 'pickHostNameFromBackendHttpSettings', 'type': 'bool'}, + 'match': {'key': 'match', 'type': 'ApplicationGatewayProbeHealthResponseMatch'}, + 'backend_address_pool': {'key': 'backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'backendHttpSettings', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + protocol: Optional[Union[str, "ApplicationGatewayProtocol"]] = None, + host: Optional[str] = None, + path: Optional[str] = None, + timeout: Optional[int] = None, + pick_host_name_from_backend_http_settings: Optional[bool] = None, + match: Optional["ApplicationGatewayProbeHealthResponseMatch"] = None, + backend_address_pool: Optional["SubResource"] = None, + backend_http_settings: Optional["SubResource"] = None, + **kwargs + ): + super(ApplicationGatewayOnDemandProbe, self).__init__(**kwargs) + self.protocol = protocol + self.host = host + self.path = path + self.timeout = timeout + self.pick_host_name_from_backend_http_settings = pick_host_name_from_backend_http_settings + self.match = match + self.backend_address_pool = backend_address_pool + self.backend_http_settings = backend_http_settings + + +class ApplicationGatewayPathRule(SubResource): + """Path rule of URL path map of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the path rule that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param paths: Path rules of URL path map. + :type paths: list[str] + :param backend_address_pool: Backend address pool resource of URL path map path rule. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Backend http settings resource of URL path map path rule. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param redirect_configuration: Redirect configuration resource of URL path map path rule. + :type redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param rewrite_rule_set: Rewrite rule set resource of URL path map path rule. + :type rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the path rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param firewall_policy: Reference to the FirewallPolicy resource. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'paths': {'key': 'properties.paths', 'type': '[str]'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'properties.backendHttpSettings', 'type': 'SubResource'}, + 'redirect_configuration': {'key': 'properties.redirectConfiguration', 'type': 'SubResource'}, + 'rewrite_rule_set': {'key': 'properties.rewriteRuleSet', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + paths: Optional[List[str]] = None, + backend_address_pool: Optional["SubResource"] = None, + backend_http_settings: Optional["SubResource"] = None, + redirect_configuration: Optional["SubResource"] = None, + rewrite_rule_set: Optional["SubResource"] = None, + firewall_policy: Optional["SubResource"] = None, + **kwargs + ): + super(ApplicationGatewayPathRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.paths = paths + self.backend_address_pool = backend_address_pool + self.backend_http_settings = backend_http_settings + self.redirect_configuration = redirect_configuration + self.rewrite_rule_set = rewrite_rule_set + self.provisioning_state = None + self.firewall_policy = firewall_policy + + +class ApplicationGatewayPrivateEndpointConnection(SubResource): + """Private Endpoint connection on an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private endpoint connection on an application gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar private_endpoint: The resource of private end point. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param private_link_service_connection_state: A collection of information about the state of + the connection between service consumer and provider. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + :ivar provisioning_state: The provisioning state of the application gateway private endpoint + connection resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar link_identifier: The consumer link id. + :vartype link_identifier: str + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'link_identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'link_identifier': {'key': 'properties.linkIdentifier', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_link_service_connection_state: Optional["PrivateLinkServiceConnectionState"] = None, + **kwargs + ): + super(ApplicationGatewayPrivateEndpointConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_endpoint = None + self.private_link_service_connection_state = private_link_service_connection_state + self.provisioning_state = None + self.link_identifier = None + + +class ApplicationGatewayPrivateEndpointConnectionListResult(msrest.serialization.Model): + """Response for ListApplicationGatewayPrivateEndpointConnection API service call. Gets all private endpoint connections for an application gateway. + + :param value: List of private endpoint connections on an application gateway. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayPrivateEndpointConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationGatewayPrivateEndpointConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayPrivateEndpointConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ApplicationGatewayPrivateLinkConfiguration(SubResource): + """Private Link Configuration on an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private link configuration that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param ip_configurations: An array of application gateway private link ip configurations. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkIpConfiguration] + :ivar provisioning_state: The provisioning state of the application gateway private link + configuration. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[ApplicationGatewayPrivateLinkIpConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + ip_configurations: Optional[List["ApplicationGatewayPrivateLinkIpConfiguration"]] = None, + **kwargs + ): + super(ApplicationGatewayPrivateLinkConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.ip_configurations = ip_configurations + self.provisioning_state = None + + +class ApplicationGatewayPrivateLinkIpConfiguration(SubResource): + """The application gateway private link ip configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of application gateway private link ip configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: The resource type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: Reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param primary: Whether the ip configuration is primary or not. + :type primary: bool + :ivar provisioning_state: The provisioning state of the application gateway private link IP + configuration. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["SubResource"] = None, + primary: Optional[bool] = None, + **kwargs + ): + super(ApplicationGatewayPrivateLinkIpConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.primary = primary + self.provisioning_state = None + + +class ApplicationGatewayPrivateLinkResource(SubResource): + """PrivateLink Resource of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the private link resource that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar group_id: Group identifier of private link resource. + :vartype group_id: str + :ivar required_members: Required member names of private link resource. + :vartype required_members: list[str] + :param required_zone_names: Required DNS zone names of the the private link resource. + :type required_zone_names: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'group_id': {'key': 'properties.groupId', 'type': 'str'}, + 'required_members': {'key': 'properties.requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'properties.requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + required_zone_names: Optional[List[str]] = None, + **kwargs + ): + super(ApplicationGatewayPrivateLinkResource, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.group_id = None + self.required_members = None + self.required_zone_names = required_zone_names + + +class ApplicationGatewayPrivateLinkResourceListResult(msrest.serialization.Model): + """Response for ListApplicationGatewayPrivateLinkResources API service call. Gets all private link resources for an application gateway. + + :param value: List of private link resources of an application gateway. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkResource] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationGatewayPrivateLinkResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationGatewayPrivateLinkResource"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayPrivateLinkResourceListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ApplicationGatewayProbe(SubResource): + """Probe of the application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the probe that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param protocol: The protocol used for the probe. Possible values include: "Http", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProtocol + :param host: Host name to send the probe to. + :type host: str + :param path: Relative path of probe. Valid path starts from '/'. Probe is sent to + :code:``://:code:``::code:``:code:``. + :type path: str + :param interval: The probing interval in seconds. This is the time interval between two + consecutive probes. Acceptable values are from 1 second to 86400 seconds. + :type interval: int + :param timeout: The probe timeout in seconds. Probe marked as failed if valid response is not + received with this timeout period. Acceptable values are from 1 second to 86400 seconds. + :type timeout: int + :param unhealthy_threshold: The probe retry count. Backend server is marked down after + consecutive probe failure count reaches UnhealthyThreshold. Acceptable values are from 1 second + to 20. + :type unhealthy_threshold: int + :param pick_host_name_from_backend_http_settings: Whether the host header should be picked from + the backend http settings. Default value is false. + :type pick_host_name_from_backend_http_settings: bool + :param min_servers: Minimum number of servers that are always marked healthy. Default value is + 0. + :type min_servers: int + :param match: Criterion for classifying a healthy probe response. + :type match: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayProbeHealthResponseMatch + :ivar provisioning_state: The provisioning state of the probe resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param port: Custom port which will be used for probing the backend servers. The valid value + ranges from 1 to 65535. In case not set, port from http settings will be used. This property is + valid for Standard_v2 and WAF_v2 only. + :type port: int + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'port': {'maximum': 65535, 'minimum': 1}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'host': {'key': 'properties.host', 'type': 'str'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'interval': {'key': 'properties.interval', 'type': 'int'}, + 'timeout': {'key': 'properties.timeout', 'type': 'int'}, + 'unhealthy_threshold': {'key': 'properties.unhealthyThreshold', 'type': 'int'}, + 'pick_host_name_from_backend_http_settings': {'key': 'properties.pickHostNameFromBackendHttpSettings', 'type': 'bool'}, + 'min_servers': {'key': 'properties.minServers', 'type': 'int'}, + 'match': {'key': 'properties.match', 'type': 'ApplicationGatewayProbeHealthResponseMatch'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + protocol: Optional[Union[str, "ApplicationGatewayProtocol"]] = None, + host: Optional[str] = None, + path: Optional[str] = None, + interval: Optional[int] = None, + timeout: Optional[int] = None, + unhealthy_threshold: Optional[int] = None, + pick_host_name_from_backend_http_settings: Optional[bool] = None, + min_servers: Optional[int] = None, + match: Optional["ApplicationGatewayProbeHealthResponseMatch"] = None, + port: Optional[int] = None, + **kwargs + ): + super(ApplicationGatewayProbe, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.protocol = protocol + self.host = host + self.path = path + self.interval = interval + self.timeout = timeout + self.unhealthy_threshold = unhealthy_threshold + self.pick_host_name_from_backend_http_settings = pick_host_name_from_backend_http_settings + self.min_servers = min_servers + self.match = match + self.provisioning_state = None + self.port = port + + +class ApplicationGatewayProbeHealthResponseMatch(msrest.serialization.Model): + """Application gateway probe health response match. + + :param body: Body that must be contained in the health response. Default value is empty. + :type body: str + :param status_codes: Allowed ranges of healthy status codes. Default range of healthy status + codes is 200-399. + :type status_codes: list[str] + """ + + _attribute_map = { + 'body': {'key': 'body', 'type': 'str'}, + 'status_codes': {'key': 'statusCodes', 'type': '[str]'}, + } + + def __init__( + self, + *, + body: Optional[str] = None, + status_codes: Optional[List[str]] = None, + **kwargs + ): + super(ApplicationGatewayProbeHealthResponseMatch, self).__init__(**kwargs) + self.body = body + self.status_codes = status_codes + + +class ApplicationGatewayRedirectConfiguration(SubResource): + """Redirect configuration of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the redirect configuration that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param redirect_type: HTTP redirection type. Possible values include: "Permanent", "Found", + "SeeOther", "Temporary". + :type redirect_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRedirectType + :param target_listener: Reference to a listener to redirect the request to. + :type target_listener: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param target_url: Url to redirect the request to. + :type target_url: str + :param include_path: Include path in the redirected url. + :type include_path: bool + :param include_query_string: Include query string in the redirected url. + :type include_query_string: bool + :param request_routing_rules: Request routing specifying redirect configuration. + :type request_routing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param url_path_maps: Url path maps specifying default redirect configuration. + :type url_path_maps: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param path_rules: Path rules specifying redirect configuration. + :type path_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'redirect_type': {'key': 'properties.redirectType', 'type': 'str'}, + 'target_listener': {'key': 'properties.targetListener', 'type': 'SubResource'}, + 'target_url': {'key': 'properties.targetUrl', 'type': 'str'}, + 'include_path': {'key': 'properties.includePath', 'type': 'bool'}, + 'include_query_string': {'key': 'properties.includeQueryString', 'type': 'bool'}, + 'request_routing_rules': {'key': 'properties.requestRoutingRules', 'type': '[SubResource]'}, + 'url_path_maps': {'key': 'properties.urlPathMaps', 'type': '[SubResource]'}, + 'path_rules': {'key': 'properties.pathRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + redirect_type: Optional[Union[str, "ApplicationGatewayRedirectType"]] = None, + target_listener: Optional["SubResource"] = None, + target_url: Optional[str] = None, + include_path: Optional[bool] = None, + include_query_string: Optional[bool] = None, + request_routing_rules: Optional[List["SubResource"]] = None, + url_path_maps: Optional[List["SubResource"]] = None, + path_rules: Optional[List["SubResource"]] = None, + **kwargs + ): + super(ApplicationGatewayRedirectConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.redirect_type = redirect_type + self.target_listener = target_listener + self.target_url = target_url + self.include_path = include_path + self.include_query_string = include_query_string + self.request_routing_rules = request_routing_rules + self.url_path_maps = url_path_maps + self.path_rules = path_rules + + +class ApplicationGatewayRequestRoutingRule(SubResource): + """Request routing rule of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the request routing rule that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param rule_type: Rule type. Possible values include: "Basic", "PathBasedRouting". + :type rule_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRequestRoutingRuleType + :param priority: Priority of the request routing rule. + :type priority: int + :param backend_address_pool: Backend address pool resource of the application gateway. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_http_settings: Backend http settings resource of the application gateway. + :type backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param http_listener: Http listener resource of the application gateway. + :type http_listener: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param url_path_map: URL path map resource of the application gateway. + :type url_path_map: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param rewrite_rule_set: Rewrite Rule Set resource in Basic rule of the application gateway. + :type rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param redirect_configuration: Redirect configuration resource of the application gateway. + :type redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the request routing rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'priority': {'maximum': 20000, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'rule_type': {'key': 'properties.ruleType', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'backend_http_settings': {'key': 'properties.backendHttpSettings', 'type': 'SubResource'}, + 'http_listener': {'key': 'properties.httpListener', 'type': 'SubResource'}, + 'url_path_map': {'key': 'properties.urlPathMap', 'type': 'SubResource'}, + 'rewrite_rule_set': {'key': 'properties.rewriteRuleSet', 'type': 'SubResource'}, + 'redirect_configuration': {'key': 'properties.redirectConfiguration', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + rule_type: Optional[Union[str, "ApplicationGatewayRequestRoutingRuleType"]] = None, + priority: Optional[int] = None, + backend_address_pool: Optional["SubResource"] = None, + backend_http_settings: Optional["SubResource"] = None, + http_listener: Optional["SubResource"] = None, + url_path_map: Optional["SubResource"] = None, + rewrite_rule_set: Optional["SubResource"] = None, + redirect_configuration: Optional["SubResource"] = None, + **kwargs + ): + super(ApplicationGatewayRequestRoutingRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.rule_type = rule_type + self.priority = priority + self.backend_address_pool = backend_address_pool + self.backend_http_settings = backend_http_settings + self.http_listener = http_listener + self.url_path_map = url_path_map + self.rewrite_rule_set = rewrite_rule_set + self.redirect_configuration = redirect_configuration + self.provisioning_state = None + + +class ApplicationGatewayRewriteRule(msrest.serialization.Model): + """Rewrite rule of an application gateway. + + :param name: Name of the rewrite rule that is unique within an Application Gateway. + :type name: str + :param rule_sequence: Rule Sequence of the rewrite rule that determines the order of execution + of a particular rule in a RewriteRuleSet. + :type rule_sequence: int + :param conditions: Conditions based on which the action set execution will be evaluated. + :type conditions: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleCondition] + :param action_set: Set of actions to be done as part of the rewrite Rule. + :type action_set: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRuleActionSet + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'rule_sequence': {'key': 'ruleSequence', 'type': 'int'}, + 'conditions': {'key': 'conditions', 'type': '[ApplicationGatewayRewriteRuleCondition]'}, + 'action_set': {'key': 'actionSet', 'type': 'ApplicationGatewayRewriteRuleActionSet'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + rule_sequence: Optional[int] = None, + conditions: Optional[List["ApplicationGatewayRewriteRuleCondition"]] = None, + action_set: Optional["ApplicationGatewayRewriteRuleActionSet"] = None, + **kwargs + ): + super(ApplicationGatewayRewriteRule, self).__init__(**kwargs) + self.name = name + self.rule_sequence = rule_sequence + self.conditions = conditions + self.action_set = action_set + + +class ApplicationGatewayRewriteRuleActionSet(msrest.serialization.Model): + """Set of actions in the Rewrite Rule in Application Gateway. + + :param request_header_configurations: Request Header Actions in the Action Set. + :type request_header_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHeaderConfiguration] + :param response_header_configurations: Response Header Actions in the Action Set. + :type response_header_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayHeaderConfiguration] + :param url_configuration: Url Configuration Action in the Action Set. + :type url_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayUrlConfiguration + """ + + _attribute_map = { + 'request_header_configurations': {'key': 'requestHeaderConfigurations', 'type': '[ApplicationGatewayHeaderConfiguration]'}, + 'response_header_configurations': {'key': 'responseHeaderConfigurations', 'type': '[ApplicationGatewayHeaderConfiguration]'}, + 'url_configuration': {'key': 'urlConfiguration', 'type': 'ApplicationGatewayUrlConfiguration'}, + } + + def __init__( + self, + *, + request_header_configurations: Optional[List["ApplicationGatewayHeaderConfiguration"]] = None, + response_header_configurations: Optional[List["ApplicationGatewayHeaderConfiguration"]] = None, + url_configuration: Optional["ApplicationGatewayUrlConfiguration"] = None, + **kwargs + ): + super(ApplicationGatewayRewriteRuleActionSet, self).__init__(**kwargs) + self.request_header_configurations = request_header_configurations + self.response_header_configurations = response_header_configurations + self.url_configuration = url_configuration + + +class ApplicationGatewayRewriteRuleCondition(msrest.serialization.Model): + """Set of conditions in the Rewrite Rule in Application Gateway. + + :param variable: The condition parameter of the RewriteRuleCondition. + :type variable: str + :param pattern: The pattern, either fixed string or regular expression, that evaluates the + truthfulness of the condition. + :type pattern: str + :param ignore_case: Setting this paramter to truth value with force the pattern to do a case + in-sensitive comparison. + :type ignore_case: bool + :param negate: Setting this value as truth will force to check the negation of the condition + given by the user. + :type negate: bool + """ + + _attribute_map = { + 'variable': {'key': 'variable', 'type': 'str'}, + 'pattern': {'key': 'pattern', 'type': 'str'}, + 'ignore_case': {'key': 'ignoreCase', 'type': 'bool'}, + 'negate': {'key': 'negate', 'type': 'bool'}, + } + + def __init__( + self, + *, + variable: Optional[str] = None, + pattern: Optional[str] = None, + ignore_case: Optional[bool] = None, + negate: Optional[bool] = None, + **kwargs + ): + super(ApplicationGatewayRewriteRuleCondition, self).__init__(**kwargs) + self.variable = variable + self.pattern = pattern + self.ignore_case = ignore_case + self.negate = negate + + +class ApplicationGatewayRewriteRuleSet(SubResource): + """Rewrite rule set of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the rewrite rule set that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param rewrite_rules: Rewrite rules in the rewrite rule set. + :type rewrite_rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayRewriteRule] + :ivar provisioning_state: The provisioning state of the rewrite rule set resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'rewrite_rules': {'key': 'properties.rewriteRules', 'type': '[ApplicationGatewayRewriteRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + rewrite_rules: Optional[List["ApplicationGatewayRewriteRule"]] = None, + **kwargs + ): + super(ApplicationGatewayRewriteRuleSet, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.rewrite_rules = rewrite_rules + self.provisioning_state = None + + +class ApplicationGatewaySku(msrest.serialization.Model): + """SKU of an application gateway. + + :param name: Name of an application gateway SKU. Possible values include: "Standard_Small", + "Standard_Medium", "Standard_Large", "WAF_Medium", "WAF_Large", "Standard_v2", "WAF_v2". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySkuName + :param tier: Tier of an application gateway. Possible values include: "Standard", "WAF", + "Standard_v2", "WAF_v2". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayTier + :param capacity: Capacity (instance count) of an application gateway. + :type capacity: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "ApplicationGatewaySkuName"]] = None, + tier: Optional[Union[str, "ApplicationGatewayTier"]] = None, + capacity: Optional[int] = None, + **kwargs + ): + super(ApplicationGatewaySku, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.capacity = capacity + + +class ApplicationGatewaySslCertificate(SubResource): + """SSL certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the SSL certificate that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Base-64 encoded pfx certificate. Only applicable in PUT Request. + :type data: str + :param password: Password for the pfx file specified in data. Only applicable in PUT request. + :type password: str + :ivar public_cert_data: Base-64 encoded Public cert data corresponding to pfx specified in + data. Only applicable in GET request. + :vartype public_cert_data: str + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :ivar provisioning_state: The provisioning state of the SSL certificate resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'public_cert_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'public_cert_data': {'key': 'properties.publicCertData', 'type': 'str'}, + 'key_vault_secret_id': {'key': 'properties.keyVaultSecretId', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + data: Optional[str] = None, + password: Optional[str] = None, + key_vault_secret_id: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewaySslCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.data = data + self.password = password + self.public_cert_data = None + self.key_vault_secret_id = key_vault_secret_id + self.provisioning_state = None + + +class ApplicationGatewaySslPolicy(msrest.serialization.Model): + """Application Gateway Ssl policy. + + :param disabled_ssl_protocols: Ssl protocols to be disabled on application gateway. + :type disabled_ssl_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol] + :param policy_type: Type of Ssl Policy. Possible values include: "Predefined", "Custom". + :type policy_type: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyType + :param policy_name: Name of Ssl predefined policy. Possible values include: + "AppGwSslPolicy20150501", "AppGwSslPolicy20170401", "AppGwSslPolicy20170401S". + :type policy_name: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicyName + :param cipher_suites: Ssl cipher suites to be enabled in the specified order to application + gateway. + :type cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param min_protocol_version: Minimum version of Ssl protocol to be supported on application + gateway. Possible values include: "TLSv1_0", "TLSv1_1", "TLSv1_2". + :type min_protocol_version: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol + """ + + _attribute_map = { + 'disabled_ssl_protocols': {'key': 'disabledSslProtocols', 'type': '[str]'}, + 'policy_type': {'key': 'policyType', 'type': 'str'}, + 'policy_name': {'key': 'policyName', 'type': 'str'}, + 'cipher_suites': {'key': 'cipherSuites', 'type': '[str]'}, + 'min_protocol_version': {'key': 'minProtocolVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + disabled_ssl_protocols: Optional[List[Union[str, "ApplicationGatewaySslProtocol"]]] = None, + policy_type: Optional[Union[str, "ApplicationGatewaySslPolicyType"]] = None, + policy_name: Optional[Union[str, "ApplicationGatewaySslPolicyName"]] = None, + cipher_suites: Optional[List[Union[str, "ApplicationGatewaySslCipherSuite"]]] = None, + min_protocol_version: Optional[Union[str, "ApplicationGatewaySslProtocol"]] = None, + **kwargs + ): + super(ApplicationGatewaySslPolicy, self).__init__(**kwargs) + self.disabled_ssl_protocols = disabled_ssl_protocols + self.policy_type = policy_type + self.policy_name = policy_name + self.cipher_suites = cipher_suites + self.min_protocol_version = min_protocol_version + + +class ApplicationGatewaySslPredefinedPolicy(SubResource): + """An Ssl predefined policy. + + :param id: Resource ID. + :type id: str + :param name: Name of the Ssl predefined policy. + :type name: str + :param cipher_suites: Ssl cipher suites to be enabled in the specified order for application + gateway. + :type cipher_suites: list[str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslCipherSuite] + :param min_protocol_version: Minimum version of Ssl protocol to be supported on application + gateway. Possible values include: "TLSv1_0", "TLSv1_1", "TLSv1_2". + :type min_protocol_version: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslProtocol + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'cipher_suites': {'key': 'properties.cipherSuites', 'type': '[str]'}, + 'min_protocol_version': {'key': 'properties.minProtocolVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + cipher_suites: Optional[List[Union[str, "ApplicationGatewaySslCipherSuite"]]] = None, + min_protocol_version: Optional[Union[str, "ApplicationGatewaySslProtocol"]] = None, + **kwargs + ): + super(ApplicationGatewaySslPredefinedPolicy, self).__init__(id=id, **kwargs) + self.name = name + self.cipher_suites = cipher_suites + self.min_protocol_version = min_protocol_version + + +class ApplicationGatewaySslProfile(SubResource): + """SSL profile of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the SSL profile that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param trusted_client_certificates: Array of references to application gateway trusted client + certificates. + :type trusted_client_certificates: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param ssl_policy: SSL policy of the application gateway resource. + :type ssl_policy: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPolicy + :param client_auth_configuration: Client authentication configuration of the application + gateway resource. + :type client_auth_configuration: + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayClientAuthConfiguration + :ivar provisioning_state: The provisioning state of the HTTP listener resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'trusted_client_certificates': {'key': 'properties.trustedClientCertificates', 'type': '[SubResource]'}, + 'ssl_policy': {'key': 'properties.sslPolicy', 'type': 'ApplicationGatewaySslPolicy'}, + 'client_auth_configuration': {'key': 'properties.clientAuthConfiguration', 'type': 'ApplicationGatewayClientAuthConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + trusted_client_certificates: Optional[List["SubResource"]] = None, + ssl_policy: Optional["ApplicationGatewaySslPolicy"] = None, + client_auth_configuration: Optional["ApplicationGatewayClientAuthConfiguration"] = None, + **kwargs + ): + super(ApplicationGatewaySslProfile, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.trusted_client_certificates = trusted_client_certificates + self.ssl_policy = ssl_policy + self.client_auth_configuration = client_auth_configuration + self.provisioning_state = None + + +class ApplicationGatewayTrustedClientCertificate(SubResource): + """Trusted client certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the trusted client certificate that is unique within an Application + Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :ivar provisioning_state: The provisioning state of the trusted client certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + data: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayTrustedClientCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.data = data + self.provisioning_state = None + + +class ApplicationGatewayTrustedRootCertificate(SubResource): + """Trusted Root certificates of an application gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the trusted root certificate that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param data: Certificate public data. + :type data: str + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :ivar provisioning_state: The provisioning state of the trusted root certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'properties.data', 'type': 'str'}, + 'key_vault_secret_id': {'key': 'properties.keyVaultSecretId', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + data: Optional[str] = None, + key_vault_secret_id: Optional[str] = None, + **kwargs + ): + super(ApplicationGatewayTrustedRootCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.data = data + self.key_vault_secret_id = key_vault_secret_id + self.provisioning_state = None + + +class ApplicationGatewayUrlConfiguration(msrest.serialization.Model): + """Url configuration of the Actions set in Application Gateway. + + :param modified_path: Url path which user has provided for url rewrite. Null means no path will + be updated. Default value is null. + :type modified_path: str + :param modified_query_string: Query string which user has provided for url rewrite. Null means + no query string will be updated. Default value is null. + :type modified_query_string: str + :param reroute: If set as true, it will re-evaluate the url path map provided in path based + request routing rules using modified path. Default value is false. + :type reroute: bool + """ + + _attribute_map = { + 'modified_path': {'key': 'modifiedPath', 'type': 'str'}, + 'modified_query_string': {'key': 'modifiedQueryString', 'type': 'str'}, + 'reroute': {'key': 'reroute', 'type': 'bool'}, + } + + def __init__( + self, + *, + modified_path: Optional[str] = None, + modified_query_string: Optional[str] = None, + reroute: Optional[bool] = None, + **kwargs + ): + super(ApplicationGatewayUrlConfiguration, self).__init__(**kwargs) + self.modified_path = modified_path + self.modified_query_string = modified_query_string + self.reroute = reroute + + +class ApplicationGatewayUrlPathMap(SubResource): + """UrlPathMaps give a url path to the backend mapping information for PathBasedRouting. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the URL path map that is unique within an Application Gateway. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param default_backend_address_pool: Default backend address pool resource of URL path map. + :type default_backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_backend_http_settings: Default backend http settings resource of URL path map. + :type default_backend_http_settings: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_rewrite_rule_set: Default Rewrite rule set resource of URL path map. + :type default_rewrite_rule_set: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param default_redirect_configuration: Default redirect configuration resource of URL path map. + :type default_redirect_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param path_rules: Path rule of URL path map resource. + :type path_rules: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPathRule] + :ivar provisioning_state: The provisioning state of the URL path map resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_backend_address_pool': {'key': 'properties.defaultBackendAddressPool', 'type': 'SubResource'}, + 'default_backend_http_settings': {'key': 'properties.defaultBackendHttpSettings', 'type': 'SubResource'}, + 'default_rewrite_rule_set': {'key': 'properties.defaultRewriteRuleSet', 'type': 'SubResource'}, + 'default_redirect_configuration': {'key': 'properties.defaultRedirectConfiguration', 'type': 'SubResource'}, + 'path_rules': {'key': 'properties.pathRules', 'type': '[ApplicationGatewayPathRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + default_backend_address_pool: Optional["SubResource"] = None, + default_backend_http_settings: Optional["SubResource"] = None, + default_rewrite_rule_set: Optional["SubResource"] = None, + default_redirect_configuration: Optional["SubResource"] = None, + path_rules: Optional[List["ApplicationGatewayPathRule"]] = None, + **kwargs + ): + super(ApplicationGatewayUrlPathMap, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.default_backend_address_pool = default_backend_address_pool + self.default_backend_http_settings = default_backend_http_settings + self.default_rewrite_rule_set = default_rewrite_rule_set + self.default_redirect_configuration = default_redirect_configuration + self.path_rules = path_rules + self.provisioning_state = None + + +class ApplicationGatewayWebApplicationFirewallConfiguration(msrest.serialization.Model): + """Application gateway web application firewall configuration. + + All required parameters must be populated in order to send to Azure. + + :param enabled: Required. Whether the web application firewall is enabled or not. + :type enabled: bool + :param firewall_mode: Required. Web application firewall mode. Possible values include: + "Detection", "Prevention". + :type firewall_mode: str or + ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallMode + :param rule_set_type: Required. The type of the web application firewall rule set. Possible + values are: 'OWASP'. + :type rule_set_type: str + :param rule_set_version: Required. The version of the rule set type. + :type rule_set_version: str + :param disabled_rule_groups: The disabled rule groups. + :type disabled_rule_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallDisabledRuleGroup] + :param request_body_check: Whether allow WAF to check request Body. + :type request_body_check: bool + :param max_request_body_size: Maximum request body size for WAF. + :type max_request_body_size: int + :param max_request_body_size_in_kb: Maximum request body size in Kb for WAF. + :type max_request_body_size_in_kb: int + :param file_upload_limit_in_mb: Maximum file upload size in Mb for WAF. + :type file_upload_limit_in_mb: int + :param exclusions: The exclusion list. + :type exclusions: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayFirewallExclusion] + """ + + _validation = { + 'enabled': {'required': True}, + 'firewall_mode': {'required': True}, + 'rule_set_type': {'required': True}, + 'rule_set_version': {'required': True}, + 'max_request_body_size': {'maximum': 128, 'minimum': 8}, + 'max_request_body_size_in_kb': {'maximum': 128, 'minimum': 8}, + 'file_upload_limit_in_mb': {'minimum': 0}, + } + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'firewall_mode': {'key': 'firewallMode', 'type': 'str'}, + 'rule_set_type': {'key': 'ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'ruleSetVersion', 'type': 'str'}, + 'disabled_rule_groups': {'key': 'disabledRuleGroups', 'type': '[ApplicationGatewayFirewallDisabledRuleGroup]'}, + 'request_body_check': {'key': 'requestBodyCheck', 'type': 'bool'}, + 'max_request_body_size': {'key': 'maxRequestBodySize', 'type': 'int'}, + 'max_request_body_size_in_kb': {'key': 'maxRequestBodySizeInKb', 'type': 'int'}, + 'file_upload_limit_in_mb': {'key': 'fileUploadLimitInMb', 'type': 'int'}, + 'exclusions': {'key': 'exclusions', 'type': '[ApplicationGatewayFirewallExclusion]'}, + } + + def __init__( + self, + *, + enabled: bool, + firewall_mode: Union[str, "ApplicationGatewayFirewallMode"], + rule_set_type: str, + rule_set_version: str, + disabled_rule_groups: Optional[List["ApplicationGatewayFirewallDisabledRuleGroup"]] = None, + request_body_check: Optional[bool] = None, + max_request_body_size: Optional[int] = None, + max_request_body_size_in_kb: Optional[int] = None, + file_upload_limit_in_mb: Optional[int] = None, + exclusions: Optional[List["ApplicationGatewayFirewallExclusion"]] = None, + **kwargs + ): + super(ApplicationGatewayWebApplicationFirewallConfiguration, self).__init__(**kwargs) + self.enabled = enabled + self.firewall_mode = firewall_mode + self.rule_set_type = rule_set_type + self.rule_set_version = rule_set_version + self.disabled_rule_groups = disabled_rule_groups + self.request_body_check = request_body_check + self.max_request_body_size = max_request_body_size + self.max_request_body_size_in_kb = max_request_body_size_in_kb + self.file_upload_limit_in_mb = file_upload_limit_in_mb + self.exclusions = exclusions + + +class FirewallPolicyRule(msrest.serialization.Model): + """Properties of a rule. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: ApplicationRule, NatRule, NetworkRule. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + } + + _subtype_map = { + 'rule_type': {'ApplicationRule': 'ApplicationRule', 'NatRule': 'NatRule', 'NetworkRule': 'NetworkRule'} + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(FirewallPolicyRule, self).__init__(**kwargs) + self.name = name + self.description = description + self.rule_type = None # type: Optional[str] + + +class ApplicationRule(FirewallPolicyRule): + """Rule of type application. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param protocols: Array of Application Protocols. + :type protocols: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleApplicationProtocol] + :param target_fqdns: List of FQDNs for this rule. + :type target_fqdns: list[str] + :param target_urls: List of Urls for this rule condition. + :type target_urls: list[str] + :param fqdn_tags: List of FQDN Tags for this rule. + :type fqdn_tags: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param terminate_tls: Terminate TLS connections for this rule. + :type terminate_tls: bool + :param web_categories: List of destination azure web categories. + :type web_categories: list[str] + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[FirewallPolicyRuleApplicationProtocol]'}, + 'target_fqdns': {'key': 'targetFqdns', 'type': '[str]'}, + 'target_urls': {'key': 'targetUrls', 'type': '[str]'}, + 'fqdn_tags': {'key': 'fqdnTags', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'terminate_tls': {'key': 'terminateTLS', 'type': 'bool'}, + 'web_categories': {'key': 'webCategories', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + protocols: Optional[List["FirewallPolicyRuleApplicationProtocol"]] = None, + target_fqdns: Optional[List[str]] = None, + target_urls: Optional[List[str]] = None, + fqdn_tags: Optional[List[str]] = None, + source_ip_groups: Optional[List[str]] = None, + terminate_tls: Optional[bool] = None, + web_categories: Optional[List[str]] = None, + **kwargs + ): + super(ApplicationRule, self).__init__(name=name, description=description, **kwargs) + self.rule_type = 'ApplicationRule' # type: str + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.protocols = protocols + self.target_fqdns = target_fqdns + self.target_urls = target_urls + self.fqdn_tags = fqdn_tags + self.source_ip_groups = source_ip_groups + self.terminate_tls = terminate_tls + self.web_categories = web_categories + + +class ApplicationSecurityGroup(Resource): + """An application security group in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the application security group resource. It + uniquely identifies a resource, even if the user changes its name or migrate the resource + across subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the application security group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ApplicationSecurityGroup, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.resource_guid = None + self.provisioning_state = None + + +class ApplicationSecurityGroupListResult(msrest.serialization.Model): + """A list of application security groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of application security groups. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationSecurityGroup"]] = None, + **kwargs + ): + super(ApplicationSecurityGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AuthorizationListResult(msrest.serialization.Model): + """Response for ListAuthorizations API service call retrieves all authorizations that belongs to an ExpressRouteCircuit. + + :param value: The authorizations in an ExpressRoute Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitAuthorization]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitAuthorization"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(AuthorizationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class AutoApprovedPrivateLinkService(msrest.serialization.Model): + """The information of an AutoApprovedPrivateLinkService. + + :param private_link_service: The id of the private link service resource. + :type private_link_service: str + """ + + _attribute_map = { + 'private_link_service': {'key': 'privateLinkService', 'type': 'str'}, + } + + def __init__( + self, + *, + private_link_service: Optional[str] = None, + **kwargs + ): + super(AutoApprovedPrivateLinkService, self).__init__(**kwargs) + self.private_link_service = private_link_service + + +class AutoApprovedPrivateLinkServicesResult(msrest.serialization.Model): + """An array of private link service id that can be linked to a private end point with auto approved. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of auto approved private link service. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkService] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AutoApprovedPrivateLinkService]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AutoApprovedPrivateLinkService"]] = None, + **kwargs + ): + super(AutoApprovedPrivateLinkServicesResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Availability(msrest.serialization.Model): + """Availability of the metric. + + :param time_grain: The time grain of the availability. + :type time_grain: str + :param retention: The retention of the availability. + :type retention: str + :param blob_duration: Duration of the availability blob. + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + *, + time_grain: Optional[str] = None, + retention: Optional[str] = None, + blob_duration: Optional[str] = None, + **kwargs + ): + super(Availability, self).__init__(**kwargs) + self.time_grain = time_grain + self.retention = retention + self.blob_duration = blob_duration + + +class AvailableDelegation(msrest.serialization.Model): + """The serviceName of an AvailableDelegation indicates a possible delegation for a subnet. + + :param name: The name of the AvailableDelegation resource. + :type name: str + :param id: A unique identifier of the AvailableDelegation resource. + :type id: str + :param type: Resource type. + :type type: str + :param service_name: The name of the service and resource. + :type service_name: str + :param actions: The actions permitted to the service upon delegation. + :type actions: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + 'actions': {'key': 'actions', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + id: Optional[str] = None, + type: Optional[str] = None, + service_name: Optional[str] = None, + actions: Optional[List[str]] = None, + **kwargs + ): + super(AvailableDelegation, self).__init__(**kwargs) + self.name = name + self.id = id + self.type = type + self.service_name = service_name + self.actions = actions + + +class AvailableDelegationsResult(msrest.serialization.Model): + """An array of available delegations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available delegations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailableDelegation] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailableDelegation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AvailableDelegation"]] = None, + **kwargs + ): + super(AvailableDelegationsResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AvailablePrivateEndpointType(msrest.serialization.Model): + """The information of an AvailablePrivateEndpointType. + + :param name: The name of the service and resource. + :type name: str + :param id: A unique identifier of the AvailablePrivateEndpoint Type resource. + :type id: str + :param type: Resource type. + :type type: str + :param resource_name: The name of the service and resource. + :type resource_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + id: Optional[str] = None, + type: Optional[str] = None, + resource_name: Optional[str] = None, + **kwargs + ): + super(AvailablePrivateEndpointType, self).__init__(**kwargs) + self.name = name + self.id = id + self.type = type + self.resource_name = resource_name + + +class AvailablePrivateEndpointTypesResult(msrest.serialization.Model): + """An array of available PrivateEndpoint types. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available privateEndpoint type. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointType] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailablePrivateEndpointType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AvailablePrivateEndpointType"]] = None, + **kwargs + ): + super(AvailablePrivateEndpointTypesResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AvailableProvidersList(msrest.serialization.Model): + """List of available countries with details. + + All required parameters must be populated in order to send to Azure. + + :param countries: Required. List of available countries. + :type countries: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListCountry] + """ + + _validation = { + 'countries': {'required': True}, + } + + _attribute_map = { + 'countries': {'key': 'countries', 'type': '[AvailableProvidersListCountry]'}, + } + + def __init__( + self, + *, + countries: List["AvailableProvidersListCountry"], + **kwargs + ): + super(AvailableProvidersList, self).__init__(**kwargs) + self.countries = countries + + +class AvailableProvidersListCity(msrest.serialization.Model): + """City or town details. + + :param city_name: The city or town name. + :type city_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + """ + + _attribute_map = { + 'city_name': {'key': 'cityName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + } + + def __init__( + self, + *, + city_name: Optional[str] = None, + providers: Optional[List[str]] = None, + **kwargs + ): + super(AvailableProvidersListCity, self).__init__(**kwargs) + self.city_name = city_name + self.providers = providers + + +class AvailableProvidersListCountry(msrest.serialization.Model): + """Country details. + + :param country_name: The country name. + :type country_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + :param states: List of available states in the country. + :type states: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListState] + """ + + _attribute_map = { + 'country_name': {'key': 'countryName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'states': {'key': 'states', 'type': '[AvailableProvidersListState]'}, + } + + def __init__( + self, + *, + country_name: Optional[str] = None, + providers: Optional[List[str]] = None, + states: Optional[List["AvailableProvidersListState"]] = None, + **kwargs + ): + super(AvailableProvidersListCountry, self).__init__(**kwargs) + self.country_name = country_name + self.providers = providers + self.states = states + + +class AvailableProvidersListParameters(msrest.serialization.Model): + """Constraints that determine the list of available Internet service providers. + + :param azure_locations: A list of Azure regions. + :type azure_locations: list[str] + :param country: The country for available providers list. + :type country: str + :param state: The state for available providers list. + :type state: str + :param city: The city or town for available providers list. + :type city: str + """ + + _attribute_map = { + 'azure_locations': {'key': 'azureLocations', 'type': '[str]'}, + 'country': {'key': 'country', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + } + + def __init__( + self, + *, + azure_locations: Optional[List[str]] = None, + country: Optional[str] = None, + state: Optional[str] = None, + city: Optional[str] = None, + **kwargs + ): + super(AvailableProvidersListParameters, self).__init__(**kwargs) + self.azure_locations = azure_locations + self.country = country + self.state = state + self.city = city + + +class AvailableProvidersListState(msrest.serialization.Model): + """State details. + + :param state_name: The state name. + :type state_name: str + :param providers: A list of Internet service providers. + :type providers: list[str] + :param cities: List of available cities or towns in the state. + :type cities: list[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListCity] + """ + + _attribute_map = { + 'state_name': {'key': 'stateName', 'type': 'str'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'cities': {'key': 'cities', 'type': '[AvailableProvidersListCity]'}, + } + + def __init__( + self, + *, + state_name: Optional[str] = None, + providers: Optional[List[str]] = None, + cities: Optional[List["AvailableProvidersListCity"]] = None, + **kwargs + ): + super(AvailableProvidersListState, self).__init__(**kwargs) + self.state_name = state_name + self.providers = providers + self.cities = cities + + +class AvailableServiceAlias(msrest.serialization.Model): + """The available service alias. + + :param name: The name of the service alias. + :type name: str + :param id: The ID of the service alias. + :type id: str + :param type: The type of the resource. + :type type: str + :param resource_name: The resource name of the service alias. + :type resource_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + id: Optional[str] = None, + type: Optional[str] = None, + resource_name: Optional[str] = None, + **kwargs + ): + super(AvailableServiceAlias, self).__init__(**kwargs) + self.name = name + self.id = id + self.type = type + self.resource_name = resource_name + + +class AvailableServiceAliasesResult(msrest.serialization.Model): + """An array of available service aliases. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of available service aliases. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAlias] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AvailableServiceAlias]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AvailableServiceAlias"]] = None, + **kwargs + ): + super(AvailableServiceAliasesResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AzureAsyncOperationResult(msrest.serialization.Model): + """The response body contains the status of the specified asynchronous operation, indicating whether it has succeeded, is in progress, or has failed. Note that this status is distinct from the HTTP status code returned for the Get Operation Status operation itself. If the asynchronous operation succeeded, the response body includes the HTTP status code for the successful request. If the asynchronous operation failed, the response body includes the HTTP status code for the failed request and error information regarding the failure. + + :param status: Status of the Azure async operation. Possible values include: "InProgress", + "Succeeded", "Failed". + :type status: str or ~azure.mgmt.network.v2020_08_01.models.NetworkOperationStatus + :param error: Details of the error occurred during specified asynchronous operation. + :type error: ~azure.mgmt.network.v2020_08_01.models.Error + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'Error'}, + } + + def __init__( + self, + *, + status: Optional[Union[str, "NetworkOperationStatus"]] = None, + error: Optional["Error"] = None, + **kwargs + ): + super(AzureAsyncOperationResult, self).__init__(**kwargs) + self.status = status + self.error = error + + +class AzureFirewall(Resource): + """Azure Firewall resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 zones: A list of availability zones denoting where the resource needs to come from. + :type zones: list[str] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param application_rule_collections: Collection of application rule collections used by Azure + Firewall. + :type application_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleCollection] + :param nat_rule_collections: Collection of NAT rule collections used by Azure Firewall. + :type nat_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRuleCollection] + :param network_rule_collections: Collection of network rule collections used by Azure Firewall. + :type network_rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleCollection] + :param ip_configurations: IP configuration of the Azure Firewall resource. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallIPConfiguration] + :param management_ip_configuration: IP configuration of the Azure Firewall used for management + traffic. + :type management_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallIPConfiguration + :ivar provisioning_state: The provisioning state of the Azure firewall resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param threat_intel_mode: The operation mode for Threat Intelligence. Possible values include: + "Alert", "Deny", "Off". + :type threat_intel_mode: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallThreatIntelMode + :param virtual_hub: The virtualHub to which the firewall belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param firewall_policy: The firewallPolicy associated with this azure firewall. + :type firewall_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param hub_ip_addresses: IP addresses associated with AzureFirewall. + :type hub_ip_addresses: ~azure.mgmt.network.v2020_08_01.models.HubIPAddresses + :ivar ip_groups: IpGroups associated with AzureFirewall. + :vartype ip_groups: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallIpGroups] + :param sku: The Azure Firewall Resource SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSku + :param additional_properties: The additional properties used to further config this azure + firewall. + :type additional_properties: dict[str, str] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'ip_groups': {'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}'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'application_rule_collections': {'key': 'properties.applicationRuleCollections', 'type': '[AzureFirewallApplicationRuleCollection]'}, + 'nat_rule_collections': {'key': 'properties.natRuleCollections', 'type': '[AzureFirewallNatRuleCollection]'}, + 'network_rule_collections': {'key': 'properties.networkRuleCollections', 'type': '[AzureFirewallNetworkRuleCollection]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[AzureFirewallIPConfiguration]'}, + 'management_ip_configuration': {'key': 'properties.managementIpConfiguration', 'type': 'AzureFirewallIPConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'threat_intel_mode': {'key': 'properties.threatIntelMode', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'firewall_policy': {'key': 'properties.firewallPolicy', 'type': 'SubResource'}, + 'hub_ip_addresses': {'key': 'properties.hubIPAddresses', 'type': 'HubIPAddresses'}, + 'ip_groups': {'key': 'properties.ipGroups', 'type': '[AzureFirewallIpGroups]'}, + 'sku': {'key': 'properties.sku', 'type': 'AzureFirewallSku'}, + 'additional_properties': {'key': 'properties.additionalProperties', 'type': '{str}'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + zones: Optional[List[str]] = None, + application_rule_collections: Optional[List["AzureFirewallApplicationRuleCollection"]] = None, + nat_rule_collections: Optional[List["AzureFirewallNatRuleCollection"]] = None, + network_rule_collections: Optional[List["AzureFirewallNetworkRuleCollection"]] = None, + ip_configurations: Optional[List["AzureFirewallIPConfiguration"]] = None, + management_ip_configuration: Optional["AzureFirewallIPConfiguration"] = None, + threat_intel_mode: Optional[Union[str, "AzureFirewallThreatIntelMode"]] = None, + virtual_hub: Optional["SubResource"] = None, + firewall_policy: Optional["SubResource"] = None, + hub_ip_addresses: Optional["HubIPAddresses"] = None, + sku: Optional["AzureFirewallSku"] = None, + additional_properties: Optional[Dict[str, str]] = None, + **kwargs + ): + super(AzureFirewall, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.zones = zones + self.etag = None + self.application_rule_collections = application_rule_collections + self.nat_rule_collections = nat_rule_collections + self.network_rule_collections = network_rule_collections + self.ip_configurations = ip_configurations + self.management_ip_configuration = management_ip_configuration + self.provisioning_state = None + self.threat_intel_mode = threat_intel_mode + self.virtual_hub = virtual_hub + self.firewall_policy = firewall_policy + self.hub_ip_addresses = hub_ip_addresses + self.ip_groups = None + self.sku = sku + self.additional_properties = additional_properties + + +class AzureFirewallApplicationRule(msrest.serialization.Model): + """Properties of an application rule. + + :param name: Name of the application rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param protocols: Array of ApplicationRuleProtocols. + :type protocols: + list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleProtocol] + :param target_fqdns: List of FQDNs for this rule. + :type target_fqdns: list[str] + :param fqdn_tags: List of FQDN Tags for this rule. + :type fqdn_tags: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[AzureFirewallApplicationRuleProtocol]'}, + 'target_fqdns': {'key': 'targetFqdns', 'type': '[str]'}, + 'fqdn_tags': {'key': 'fqdnTags', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + source_addresses: Optional[List[str]] = None, + protocols: Optional[List["AzureFirewallApplicationRuleProtocol"]] = None, + target_fqdns: Optional[List[str]] = None, + fqdn_tags: Optional[List[str]] = None, + source_ip_groups: Optional[List[str]] = None, + **kwargs + ): + super(AzureFirewallApplicationRule, self).__init__(**kwargs) + self.name = name + self.description = description + self.source_addresses = source_addresses + self.protocols = protocols + self.target_fqdns = target_fqdns + self.fqdn_tags = fqdn_tags + self.source_ip_groups = source_ip_groups + + +class AzureFirewallApplicationRuleCollection(SubResource): + """Application rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the application rule collection resource. + :type priority: int + :param action: The action type of a rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCAction + :param rules: Collection of rules used by a application rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRule] + :ivar provisioning_state: The provisioning state of the application rule collection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallApplicationRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + priority: Optional[int] = None, + action: Optional["AzureFirewallRCAction"] = None, + rules: Optional[List["AzureFirewallApplicationRule"]] = None, + **kwargs + ): + super(AzureFirewallApplicationRuleCollection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.priority = priority + self.action = action + self.rules = rules + self.provisioning_state = None + + +class AzureFirewallApplicationRuleProtocol(msrest.serialization.Model): + """Properties of the application rule protocol. + + :param protocol_type: Protocol type. Possible values include: "Http", "Https", "Mssql". + :type protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallApplicationRuleProtocolType + :param port: Port number for the protocol, cannot be greater than 64000. This field is + optional. + :type port: int + """ + + _validation = { + 'port': {'maximum': 64000, 'minimum': 0}, + } + + _attribute_map = { + 'protocol_type': {'key': 'protocolType', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + protocol_type: Optional[Union[str, "AzureFirewallApplicationRuleProtocolType"]] = None, + port: Optional[int] = None, + **kwargs + ): + super(AzureFirewallApplicationRuleProtocol, self).__init__(**kwargs) + self.protocol_type = protocol_type + self.port = port + + +class AzureFirewallFqdnTag(Resource): + """Azure Firewall FQDN Tag Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the Azure firewall FQDN tag resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar fqdn_tag_name: The name of this FQDN Tag. + :vartype fqdn_tag_name: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'fqdn_tag_name': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'fqdn_tag_name': {'key': 'properties.fqdnTagName', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(AzureFirewallFqdnTag, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.provisioning_state = None + self.fqdn_tag_name = None + + +class AzureFirewallFqdnTagListResult(msrest.serialization.Model): + """Response for ListAzureFirewallFqdnTags API service call. + + :param value: List of Azure Firewall FQDN Tags in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallFqdnTag] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureFirewallFqdnTag]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AzureFirewallFqdnTag"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(AzureFirewallFqdnTagListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class AzureFirewallIPConfiguration(SubResource): + """IP configuration of an Azure Firewall. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar private_ip_address: The Firewall Internal Load Balancer IP to be used as the next hop in + User Defined Routes. + :vartype private_ip_address: str + :param subnet: Reference to the subnet resource. This resource must be named + 'AzureFirewallSubnet' or 'AzureFirewallManagementSubnet'. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference to the PublicIP resource. This field is a mandatory input + if subnet is not null. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the Azure firewall IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + subnet: Optional["SubResource"] = None, + public_ip_address: Optional["SubResource"] = None, + **kwargs + ): + super(AzureFirewallIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_ip_address = None + self.subnet = subnet + self.public_ip_address = public_ip_address + self.provisioning_state = None + + +class AzureFirewallIpGroups(msrest.serialization.Model): + """IpGroups associated with azure firewall. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar change_number: The iteration number. + :vartype change_number: str + """ + + _validation = { + 'id': {'readonly': True}, + 'change_number': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureFirewallIpGroups, self).__init__(**kwargs) + self.id = None + self.change_number = None + + +class AzureFirewallListResult(msrest.serialization.Model): + """Response for ListAzureFirewalls API service call. + + :param value: List of Azure Firewalls in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureFirewall]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AzureFirewall"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(AzureFirewallListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class AzureFirewallNatRCAction(msrest.serialization.Model): + """AzureFirewall NAT Rule Collection Action. + + :param type: The type of action. Possible values include: "Snat", "Dnat". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRCActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "AzureFirewallNatRCActionType"]] = None, + **kwargs + ): + super(AzureFirewallNatRCAction, self).__init__(**kwargs) + self.type = type + + +class AzureFirewallNatRule(msrest.serialization.Model): + """Properties of a NAT rule. + + :param name: Name of the NAT rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses for this rule. Supports IP + ranges, prefixes, and service tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param protocols: Array of AzureFirewallNetworkRuleProtocols applicable to this NAT rule. + :type protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleProtocol] + :param translated_address: The translated address for this NAT rule. + :type translated_address: str + :param translated_port: The translated port for this NAT rule. + :type translated_port: str + :param translated_fqdn: The translated FQDN for this NAT rule. + :type translated_fqdn: str + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'protocols': {'key': 'protocols', 'type': '[str]'}, + 'translated_address': {'key': 'translatedAddress', 'type': 'str'}, + 'translated_port': {'key': 'translatedPort', 'type': 'str'}, + 'translated_fqdn': {'key': 'translatedFqdn', 'type': 'str'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + destination_ports: Optional[List[str]] = None, + protocols: Optional[List[Union[str, "AzureFirewallNetworkRuleProtocol"]]] = None, + translated_address: Optional[str] = None, + translated_port: Optional[str] = None, + translated_fqdn: Optional[str] = None, + source_ip_groups: Optional[List[str]] = None, + **kwargs + ): + super(AzureFirewallNatRule, self).__init__(**kwargs) + self.name = name + self.description = description + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.destination_ports = destination_ports + self.protocols = protocols + self.translated_address = translated_address + self.translated_port = translated_port + self.translated_fqdn = translated_fqdn + self.source_ip_groups = source_ip_groups + + +class AzureFirewallNatRuleCollection(SubResource): + """NAT rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the NAT rule collection resource. + :type priority: int + :param action: The action type of a NAT rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRCAction + :param rules: Collection of rules used by a NAT rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNatRule] + :ivar provisioning_state: The provisioning state of the NAT rule collection resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallNatRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallNatRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + priority: Optional[int] = None, + action: Optional["AzureFirewallNatRCAction"] = None, + rules: Optional[List["AzureFirewallNatRule"]] = None, + **kwargs + ): + super(AzureFirewallNatRuleCollection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.priority = priority + self.action = action + self.rules = rules + self.provisioning_state = None + + +class AzureFirewallNetworkRule(msrest.serialization.Model): + """Properties of the network rule. + + :param name: Name of the network rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param protocols: Array of AzureFirewallNetworkRuleProtocols. + :type protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRuleProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param destination_fqdns: List of destination FQDNs. + :type destination_fqdns: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocols': {'key': 'protocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'destination_fqdns': {'key': 'destinationFqdns', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + protocols: Optional[List[Union[str, "AzureFirewallNetworkRuleProtocol"]]] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + destination_ports: Optional[List[str]] = None, + destination_fqdns: Optional[List[str]] = None, + source_ip_groups: Optional[List[str]] = None, + destination_ip_groups: Optional[List[str]] = None, + **kwargs + ): + super(AzureFirewallNetworkRule, self).__init__(**kwargs) + self.name = name + self.description = description + self.protocols = protocols + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.destination_ports = destination_ports + self.destination_fqdns = destination_fqdns + self.source_ip_groups = source_ip_groups + self.destination_ip_groups = destination_ip_groups + + +class AzureFirewallNetworkRuleCollection(SubResource): + """Network rule collection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the Azure firewall. This name can + be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Priority of the network rule collection resource. + :type priority: int + :param action: The action type of a rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCAction + :param rules: Collection of rules used by a network rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallNetworkRule] + :ivar provisioning_state: The provisioning state of the network rule collection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'action': {'key': 'properties.action', 'type': 'AzureFirewallRCAction'}, + 'rules': {'key': 'properties.rules', 'type': '[AzureFirewallNetworkRule]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + priority: Optional[int] = None, + action: Optional["AzureFirewallRCAction"] = None, + rules: Optional[List["AzureFirewallNetworkRule"]] = None, + **kwargs + ): + super(AzureFirewallNetworkRuleCollection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.priority = priority + self.action = action + self.rules = rules + self.provisioning_state = None + + +class AzureFirewallPublicIPAddress(msrest.serialization.Model): + """Public IP Address associated with azure firewall. + + :param address: Public IP Address value. + :type address: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + *, + address: Optional[str] = None, + **kwargs + ): + super(AzureFirewallPublicIPAddress, self).__init__(**kwargs) + self.address = address + + +class AzureFirewallRCAction(msrest.serialization.Model): + """Properties of the AzureFirewallRCAction. + + :param type: The type of action. Possible values include: "Allow", "Deny". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallRCActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "AzureFirewallRCActionType"]] = None, + **kwargs + ): + super(AzureFirewallRCAction, self).__init__(**kwargs) + self.type = type + + +class AzureFirewallSku(msrest.serialization.Model): + """SKU of an Azure Firewall. + + :param name: Name of an Azure Firewall SKU. Possible values include: "AZFW_VNet", "AZFW_Hub". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSkuName + :param tier: Tier of an Azure Firewall. Possible values include: "Standard", "Premium". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.AzureFirewallSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "AzureFirewallSkuName"]] = None, + tier: Optional[Union[str, "AzureFirewallSkuTier"]] = None, + **kwargs + ): + super(AzureFirewallSku, self).__init__(**kwargs) + self.name = name + self.tier = tier + + +class AzureReachabilityReport(msrest.serialization.Model): + """Azure reachability report details. + + All required parameters must be populated in order to send to Azure. + + :param aggregation_level: Required. The aggregation level of Azure reachability report. Can be + Country, State or City. + :type aggregation_level: str + :param provider_location: Required. Parameters that define a geographic location. + :type provider_location: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLocation + :param reachability_report: Required. List of Azure reachability report items. + :type reachability_report: + list[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportItem] + """ + + _validation = { + 'aggregation_level': {'required': True}, + 'provider_location': {'required': True}, + 'reachability_report': {'required': True}, + } + + _attribute_map = { + 'aggregation_level': {'key': 'aggregationLevel', 'type': 'str'}, + 'provider_location': {'key': 'providerLocation', 'type': 'AzureReachabilityReportLocation'}, + 'reachability_report': {'key': 'reachabilityReport', 'type': '[AzureReachabilityReportItem]'}, + } + + def __init__( + self, + *, + aggregation_level: str, + provider_location: "AzureReachabilityReportLocation", + reachability_report: List["AzureReachabilityReportItem"], + **kwargs + ): + super(AzureReachabilityReport, self).__init__(**kwargs) + self.aggregation_level = aggregation_level + self.provider_location = provider_location + self.reachability_report = reachability_report + + +class AzureReachabilityReportItem(msrest.serialization.Model): + """Azure reachability report details for a given provider location. + + :param provider: The Internet service provider. + :type provider: str + :param azure_location: The Azure region. + :type azure_location: str + :param latencies: List of latency details for each of the time series. + :type latencies: + list[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLatencyInfo] + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'azure_location': {'key': 'azureLocation', 'type': 'str'}, + 'latencies': {'key': 'latencies', 'type': '[AzureReachabilityReportLatencyInfo]'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + azure_location: Optional[str] = None, + latencies: Optional[List["AzureReachabilityReportLatencyInfo"]] = None, + **kwargs + ): + super(AzureReachabilityReportItem, self).__init__(**kwargs) + self.provider = provider + self.azure_location = azure_location + self.latencies = latencies + + +class AzureReachabilityReportLatencyInfo(msrest.serialization.Model): + """Details on latency for a time series. + + :param time_stamp: The time stamp. + :type time_stamp: ~datetime.datetime + :param score: The relative latency score between 1 and 100, higher values indicating a faster + connection. + :type score: int + """ + + _validation = { + 'score': {'maximum': 100, 'minimum': 1}, + } + + _attribute_map = { + 'time_stamp': {'key': 'timeStamp', 'type': 'iso-8601'}, + 'score': {'key': 'score', 'type': 'int'}, + } + + def __init__( + self, + *, + time_stamp: Optional[datetime.datetime] = None, + score: Optional[int] = None, + **kwargs + ): + super(AzureReachabilityReportLatencyInfo, self).__init__(**kwargs) + self.time_stamp = time_stamp + self.score = score + + +class AzureReachabilityReportLocation(msrest.serialization.Model): + """Parameters that define a geographic location. + + All required parameters must be populated in order to send to Azure. + + :param country: Required. The name of the country. + :type country: str + :param state: The name of the state. + :type state: str + :param city: The name of the city or town. + :type city: str + """ + + _validation = { + 'country': {'required': True}, + } + + _attribute_map = { + 'country': {'key': 'country', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + } + + def __init__( + self, + *, + country: str, + state: Optional[str] = None, + city: Optional[str] = None, + **kwargs + ): + super(AzureReachabilityReportLocation, self).__init__(**kwargs) + self.country = country + self.state = state + self.city = city + + +class AzureReachabilityReportParameters(msrest.serialization.Model): + """Geographic and time constraints for Azure reachability report. + + All required parameters must be populated in order to send to Azure. + + :param provider_location: Required. Parameters that define a geographic location. + :type provider_location: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportLocation + :param providers: List of Internet service providers. + :type providers: list[str] + :param azure_locations: Optional Azure regions to scope the query to. + :type azure_locations: list[str] + :param start_time: Required. The start time for the Azure reachability report. + :type start_time: ~datetime.datetime + :param end_time: Required. The end time for the Azure reachability report. + :type end_time: ~datetime.datetime + """ + + _validation = { + 'provider_location': {'required': True}, + 'start_time': {'required': True}, + 'end_time': {'required': True}, + } + + _attribute_map = { + 'provider_location': {'key': 'providerLocation', 'type': 'AzureReachabilityReportLocation'}, + 'providers': {'key': 'providers', 'type': '[str]'}, + 'azure_locations': {'key': 'azureLocations', 'type': '[str]'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + provider_location: "AzureReachabilityReportLocation", + start_time: datetime.datetime, + end_time: datetime.datetime, + providers: Optional[List[str]] = None, + azure_locations: Optional[List[str]] = None, + **kwargs + ): + super(AzureReachabilityReportParameters, self).__init__(**kwargs) + self.provider_location = provider_location + self.providers = providers + self.azure_locations = azure_locations + self.start_time = start_time + self.end_time = end_time + + +class AzureWebCategory(msrest.serialization.Model): + """Azure Web Category Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar group: The name of the group that the category belongs to. + :vartype group: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'group': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'group': {'key': 'properties.group', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(AzureWebCategory, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + self.etag = None + self.group = None + + +class AzureWebCategoryListResult(msrest.serialization.Model): + """Response for ListAzureWebCategories API service call. + + :param value: List of Azure Web Categories for a given Subscription. + :type value: list[~azure.mgmt.network.v2020_08_01.models.AzureWebCategory] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AzureWebCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["AzureWebCategory"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(AzureWebCategoryListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BackendAddressPool(SubResource): + """Pool of backend IP addresses. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of backend address pools + used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param location: The location of the backend address pool. + :type location: str + :param load_balancer_backend_addresses: An array of backend addresses. + :type load_balancer_backend_addresses: + list[~azure.mgmt.network.v2020_08_01.models.LoadBalancerBackendAddress] + :ivar backend_ip_configurations: An array of references to IP addresses defined in network + interfaces. + :vartype backend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar load_balancing_rules: An array of references to load balancing rules that use this + backend address pool. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar outbound_rule: A reference to an outbound rule that uses this backend address pool. + :vartype outbound_rule: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar outbound_rules: An array of references to outbound rules that use this backend address + pool. + :vartype outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the backend address pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configurations': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'outbound_rule': {'readonly': True}, + 'outbound_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'load_balancer_backend_addresses': {'key': 'properties.loadBalancerBackendAddresses', 'type': '[LoadBalancerBackendAddress]'}, + 'backend_ip_configurations': {'key': 'properties.backendIPConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'outbound_rule': {'key': 'properties.outboundRule', 'type': 'SubResource'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + location: Optional[str] = None, + load_balancer_backend_addresses: Optional[List["LoadBalancerBackendAddress"]] = None, + **kwargs + ): + super(BackendAddressPool, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.location = location + self.load_balancer_backend_addresses = load_balancer_backend_addresses + self.backend_ip_configurations = None + self.load_balancing_rules = None + self.outbound_rule = None + self.outbound_rules = None + self.provisioning_state = None + + +class BastionActiveSession(msrest.serialization.Model): + """The session detail for a target. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar session_id: A unique id for the session. + :vartype session_id: str + :ivar start_time: The time when the session started. + :vartype start_time: object + :ivar target_subscription_id: The subscription id for the target virtual machine. + :vartype target_subscription_id: str + :ivar resource_type: The type of the resource. + :vartype resource_type: str + :ivar target_host_name: The host name of the target. + :vartype target_host_name: str + :ivar target_resource_group: The resource group of the target. + :vartype target_resource_group: str + :ivar user_name: The user name who is active on this session. + :vartype user_name: str + :ivar target_ip_address: The IP Address of the target. + :vartype target_ip_address: str + :ivar protocol: The protocol used to connect to the target. Possible values include: "SSH", + "RDP". + :vartype protocol: str or ~azure.mgmt.network.v2020_08_01.models.BastionConnectProtocol + :ivar target_resource_id: The resource id of the target. + :vartype target_resource_id: str + :ivar session_duration_in_mins: Duration in mins the session has been active. + :vartype session_duration_in_mins: float + """ + + _validation = { + 'session_id': {'readonly': True}, + 'start_time': {'readonly': True}, + 'target_subscription_id': {'readonly': True}, + 'resource_type': {'readonly': True}, + 'target_host_name': {'readonly': True}, + 'target_resource_group': {'readonly': True}, + 'user_name': {'readonly': True}, + 'target_ip_address': {'readonly': True}, + 'protocol': {'readonly': True}, + 'target_resource_id': {'readonly': True}, + 'session_duration_in_mins': {'readonly': True}, + } + + _attribute_map = { + 'session_id': {'key': 'sessionId', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'object'}, + 'target_subscription_id': {'key': 'targetSubscriptionId', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'target_host_name': {'key': 'targetHostName', 'type': 'str'}, + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'user_name': {'key': 'userName', 'type': 'str'}, + 'target_ip_address': {'key': 'targetIpAddress', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'session_duration_in_mins': {'key': 'sessionDurationInMins', 'type': 'float'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionActiveSession, self).__init__(**kwargs) + self.session_id = None + self.start_time = None + self.target_subscription_id = None + self.resource_type = None + self.target_host_name = None + self.target_resource_group = None + self.user_name = None + self.target_ip_address = None + self.protocol = None + self.target_resource_id = None + self.session_duration_in_mins = None + + +class BastionActiveSessionListResult(msrest.serialization.Model): + """Response for GetActiveSessions. + + :param value: List of active sessions on the bastion. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionActiveSession] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionActiveSession]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BastionActiveSession"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(BastionActiveSessionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BastionHost(Resource): + """Bastion Host resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: IP configuration of the Bastion Host resource. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.BastionHostIPConfiguration] + :param dns_name: FQDN for the endpoint on which bastion host is accessible. + :type dns_name: str + :ivar provisioning_state: The provisioning state of the bastion host resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[BastionHostIPConfiguration]'}, + 'dns_name': {'key': 'properties.dnsName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + ip_configurations: Optional[List["BastionHostIPConfiguration"]] = None, + dns_name: Optional[str] = None, + **kwargs + ): + super(BastionHost, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.ip_configurations = ip_configurations + self.dns_name = dns_name + self.provisioning_state = None + + +class BastionHostIPConfiguration(SubResource): + """IP configuration of an Bastion Host. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Ip configuration type. + :vartype type: str + :param subnet: Reference of the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: Reference of the PublicIP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the bastion host IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_ip_allocation_method: Private IP allocation method. Possible values include: + "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + subnet: Optional["SubResource"] = None, + public_ip_address: Optional["SubResource"] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + **kwargs + ): + super(BastionHostIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.subnet = subnet + self.public_ip_address = public_ip_address + self.provisioning_state = None + self.private_ip_allocation_method = private_ip_allocation_method + + +class BastionHostListResult(msrest.serialization.Model): + """Response for ListBastionHosts API service call. + + :param value: List of Bastion Hosts in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionHost] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionHost]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BastionHost"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(BastionHostListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BastionSessionDeleteResult(msrest.serialization.Model): + """Response for DisconnectActiveSessions. + + :param value: List of sessions with their corresponding state. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionSessionState] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionSessionState]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BastionSessionState"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(BastionSessionDeleteResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BastionSessionState(msrest.serialization.Model): + """The session state detail for a target. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar session_id: A unique id for the session. + :vartype session_id: str + :ivar message: Used for extra information. + :vartype message: str + :ivar state: The state of the session. Disconnected/Failed/NotFound. + :vartype state: str + """ + + _validation = { + 'session_id': {'readonly': True}, + 'message': {'readonly': True}, + 'state': {'readonly': True}, + } + + _attribute_map = { + 'session_id': {'key': 'sessionId', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BastionSessionState, self).__init__(**kwargs) + self.session_id = None + self.message = None + self.state = None + + +class BastionShareableLink(msrest.serialization.Model): + """Bastion Shareable Link. + + Variables are only 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 vm: Required. Reference of the virtual machine resource. + :type vm: ~azure.mgmt.network.v2020_08_01.models.Resource + :ivar bsl: The unique Bastion Shareable Link to the virtual machine. + :vartype bsl: str + :ivar created_at: The time when the link was created. + :vartype created_at: str + :ivar message: Optional field indicating the warning or error message related to the vm in case + of partial failure. + :vartype message: str + """ + + _validation = { + 'vm': {'required': True}, + 'bsl': {'readonly': True}, + 'created_at': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'vm': {'key': 'vm', 'type': 'Resource'}, + 'bsl': {'key': 'bsl', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + vm: "Resource", + **kwargs + ): + super(BastionShareableLink, self).__init__(**kwargs) + self.vm = vm + self.bsl = None + self.created_at = None + self.message = None + + +class BastionShareableLinkListRequest(msrest.serialization.Model): + """Post request for all the Bastion Shareable Link endpoints. + + :param vms: List of VM references. + :type vms: list[~azure.mgmt.network.v2020_08_01.models.BastionShareableLink] + """ + + _attribute_map = { + 'vms': {'key': 'vms', 'type': '[BastionShareableLink]'}, + } + + def __init__( + self, + *, + vms: Optional[List["BastionShareableLink"]] = None, + **kwargs + ): + super(BastionShareableLinkListRequest, self).__init__(**kwargs) + self.vms = vms + + +class BastionShareableLinkListResult(msrest.serialization.Model): + """Response for all the Bastion Shareable Link endpoints. + + :param value: List of Bastion Shareable Links for the request. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BastionShareableLink] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BastionShareableLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BastionShareableLink"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(BastionShareableLinkListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BGPCommunity(msrest.serialization.Model): + """Contains bgp community information offered in Service Community resources. + + :param service_supported_region: The region which the service support. e.g. For O365, region is + Global. + :type service_supported_region: str + :param community_name: The name of the bgp community. e.g. Skype. + :type community_name: str + :param community_value: The value of the bgp community. For more information: + https://docs.microsoft.com/en-us/azure/expressroute/expressroute-routing. + :type community_value: str + :param community_prefixes: The prefixes that the bgp community contains. + :type community_prefixes: list[str] + :param is_authorized_to_use: Customer is authorized to use bgp community or not. + :type is_authorized_to_use: bool + :param service_group: The service group of the bgp community contains. + :type service_group: str + """ + + _attribute_map = { + 'service_supported_region': {'key': 'serviceSupportedRegion', 'type': 'str'}, + 'community_name': {'key': 'communityName', 'type': 'str'}, + 'community_value': {'key': 'communityValue', 'type': 'str'}, + 'community_prefixes': {'key': 'communityPrefixes', 'type': '[str]'}, + 'is_authorized_to_use': {'key': 'isAuthorizedToUse', 'type': 'bool'}, + 'service_group': {'key': 'serviceGroup', 'type': 'str'}, + } + + def __init__( + self, + *, + service_supported_region: Optional[str] = None, + community_name: Optional[str] = None, + community_value: Optional[str] = None, + community_prefixes: Optional[List[str]] = None, + is_authorized_to_use: Optional[bool] = None, + service_group: Optional[str] = None, + **kwargs + ): + super(BGPCommunity, self).__init__(**kwargs) + self.service_supported_region = service_supported_region + self.community_name = community_name + self.community_value = community_value + self.community_prefixes = community_prefixes + self.is_authorized_to_use = is_authorized_to_use + self.service_group = service_group + + +class BgpConnection(SubResource): + """Virtual Appliance Site resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the connection. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Connection type. + :vartype type: str + :param peer_asn: Peer ASN. + :type peer_asn: long + :param peer_ip: Peer IP. + :type peer_ip: str + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar connection_state: The current state of the VirtualHub to Peer. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_state: str or ~azure.mgmt.network.v2020_08_01.models.HubBgpConnectionStatus + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + 'connection_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peer_asn': {'key': 'properties.peerAsn', 'type': 'long'}, + 'peer_ip': {'key': 'properties.peerIp', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'connection_state': {'key': 'properties.connectionState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + peer_asn: Optional[int] = None, + peer_ip: Optional[str] = None, + **kwargs + ): + super(BgpConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.peer_asn = peer_asn + self.peer_ip = peer_ip + self.provisioning_state = None + self.connection_state = None + + +class BgpPeerStatus(msrest.serialization.Model): + """BGP peer status details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The virtual network gateway's local address. + :vartype local_address: str + :ivar neighbor: The remote BGP peer. + :vartype neighbor: str + :ivar asn: The autonomous system number of the remote BGP peer. + :vartype asn: long + :ivar state: The BGP peer state. Possible values include: "Unknown", "Stopped", "Idle", + "Connecting", "Connected". + :vartype state: str or ~azure.mgmt.network.v2020_08_01.models.BgpPeerState + :ivar connected_duration: For how long the peering has been up. + :vartype connected_duration: str + :ivar routes_received: The number of routes learned from this peer. + :vartype routes_received: long + :ivar messages_sent: The number of BGP messages sent. + :vartype messages_sent: long + :ivar messages_received: The number of BGP messages received. + :vartype messages_received: long + """ + + _validation = { + 'local_address': {'readonly': True}, + 'neighbor': {'readonly': True}, + 'asn': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'state': {'readonly': True}, + 'connected_duration': {'readonly': True}, + 'routes_received': {'readonly': True}, + 'messages_sent': {'readonly': True}, + 'messages_received': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'asn': {'key': 'asn', 'type': 'long'}, + 'state': {'key': 'state', 'type': 'str'}, + 'connected_duration': {'key': 'connectedDuration', 'type': 'str'}, + 'routes_received': {'key': 'routesReceived', 'type': 'long'}, + 'messages_sent': {'key': 'messagesSent', 'type': 'long'}, + 'messages_received': {'key': 'messagesReceived', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(BgpPeerStatus, self).__init__(**kwargs) + self.local_address = None + self.neighbor = None + self.asn = None + self.state = None + self.connected_duration = None + self.routes_received = None + self.messages_sent = None + self.messages_received = None + + +class BgpPeerStatusListResult(msrest.serialization.Model): + """Response for list BGP peer status API service call. + + :param value: List of BGP peers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpPeerStatus] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpPeerStatus]'}, + } + + def __init__( + self, + *, + value: Optional[List["BgpPeerStatus"]] = None, + **kwargs + ): + super(BgpPeerStatusListResult, self).__init__(**kwargs) + self.value = value + + +class BgpServiceCommunity(Resource): + """Service Community Properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 service_name: The name of the bgp community. e.g. Skype. + :type service_name: str + :param bgp_communities: A list of bgp communities. + :type bgp_communities: list[~azure.mgmt.network.v2020_08_01.models.BGPCommunity] + """ + + _validation = { + '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}'}, + 'service_name': {'key': 'properties.serviceName', 'type': 'str'}, + 'bgp_communities': {'key': 'properties.bgpCommunities', 'type': '[BGPCommunity]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + service_name: Optional[str] = None, + bgp_communities: Optional[List["BGPCommunity"]] = None, + **kwargs + ): + super(BgpServiceCommunity, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.service_name = service_name + self.bgp_communities = bgp_communities + + +class BgpServiceCommunityListResult(msrest.serialization.Model): + """Response for the ListServiceCommunity API service call. + + :param value: A list of service community resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpServiceCommunity] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpServiceCommunity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BgpServiceCommunity"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(BgpServiceCommunityListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class BgpSettings(msrest.serialization.Model): + """BGP settings details. + + :param asn: The BGP speaker's ASN. + :type asn: long + :param bgp_peering_address: The BGP peering address and BGP identifier of this BGP speaker. + :type bgp_peering_address: str + :param peer_weight: The weight added to routes learned from this BGP speaker. + :type peer_weight: int + :param bgp_peering_addresses: BGP peering address with IP configuration ID for virtual network + gateway. + :type bgp_peering_addresses: + list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationBgpPeeringAddress] + """ + + _validation = { + 'asn': {'maximum': 4294967295, 'minimum': 0}, + } + + _attribute_map = { + 'asn': {'key': 'asn', 'type': 'long'}, + 'bgp_peering_address': {'key': 'bgpPeeringAddress', 'type': 'str'}, + 'peer_weight': {'key': 'peerWeight', 'type': 'int'}, + 'bgp_peering_addresses': {'key': 'bgpPeeringAddresses', 'type': '[IPConfigurationBgpPeeringAddress]'}, + } + + def __init__( + self, + *, + asn: Optional[int] = None, + bgp_peering_address: Optional[str] = None, + peer_weight: Optional[int] = None, + bgp_peering_addresses: Optional[List["IPConfigurationBgpPeeringAddress"]] = None, + **kwargs + ): + super(BgpSettings, self).__init__(**kwargs) + self.asn = asn + self.bgp_peering_address = bgp_peering_address + self.peer_weight = peer_weight + self.bgp_peering_addresses = bgp_peering_addresses + + +class BreakOutCategoryPolicies(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param allow: Flag to control breakout of o365 allow category. + :type allow: bool + :param optimize: Flag to control breakout of o365 optimize category. + :type optimize: bool + :param default: Flag to control breakout of o365 default category. + :type default: bool + """ + + _attribute_map = { + 'allow': {'key': 'allow', 'type': 'bool'}, + 'optimize': {'key': 'optimize', 'type': 'bool'}, + 'default': {'key': 'default', 'type': 'bool'}, + } + + def __init__( + self, + *, + allow: Optional[bool] = None, + optimize: Optional[bool] = None, + default: Optional[bool] = None, + **kwargs + ): + super(BreakOutCategoryPolicies, self).__init__(**kwargs) + self.allow = allow + self.optimize = optimize + self.default = default + + +class CheckPrivateLinkServiceVisibilityRequest(msrest.serialization.Model): + """Request body of the CheckPrivateLinkServiceVisibility API service call. + + :param private_link_service_alias: The alias of the private link service. + :type private_link_service_alias: str + """ + + _attribute_map = { + 'private_link_service_alias': {'key': 'privateLinkServiceAlias', 'type': 'str'}, + } + + def __init__( + self, + *, + private_link_service_alias: Optional[str] = None, + **kwargs + ): + super(CheckPrivateLinkServiceVisibilityRequest, self).__init__(**kwargs) + self.private_link_service_alias = private_link_service_alias + + +class CloudErrorBody(msrest.serialization.Model): + """An error response from the service. + + :param code: An identifier for the error. Codes are invariant and are intended to be consumed + programmatically. + :type code: str + :param message: A message describing the error, intended to be suitable for display in a user + interface. + :type message: str + :param target: The target of the particular error. For example, the name of the property in + error. + :type target: str + :param details: A list of additional details about the error. + :type details: list[~azure.mgmt.network.v2020_08_01.models.CloudErrorBody] + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[CloudErrorBody]'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + target: Optional[str] = None, + details: Optional[List["CloudErrorBody"]] = None, + **kwargs + ): + super(CloudErrorBody, self).__init__(**kwargs) + self.code = code + self.message = message + self.target = target + self.details = details + + +class Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties(msrest.serialization.Model): + """Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties. + + 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(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionMonitor(msrest.serialization.Model): + """Parameters that define the operation to create a connection monitor. + + :param location: Connection monitor location. + :type location: str + :param tags: A set of tags. Connection monitor tags. + :type tags: dict[str, str] + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'source': {'key': 'properties.source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'properties.destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'properties.autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'properties.monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'properties.endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'properties.testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'properties.testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'properties.outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'properties.notes', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + source: Optional["ConnectionMonitorSource"] = None, + destination: Optional["ConnectionMonitorDestination"] = None, + auto_start: Optional[bool] = True, + monitoring_interval_in_seconds: Optional[int] = 60, + endpoints: Optional[List["ConnectionMonitorEndpoint"]] = None, + test_configurations: Optional[List["ConnectionMonitorTestConfiguration"]] = None, + test_groups: Optional[List["ConnectionMonitorTestGroup"]] = None, + outputs: Optional[List["ConnectionMonitorOutput"]] = None, + notes: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitor, self).__init__(**kwargs) + self.location = location + self.tags = tags + self.source = source + self.destination = destination + self.auto_start = auto_start + self.monitoring_interval_in_seconds = monitoring_interval_in_seconds + self.endpoints = endpoints + self.test_configurations = test_configurations + self.test_groups = test_groups + self.outputs = outputs + self.notes = notes + + +class ConnectionMonitorDestination(msrest.serialization.Model): + """Describes the destination of connection monitor. + + :param resource_id: The ID of the resource used as the destination by connection monitor. + :type resource_id: str + :param address: Address of the connection monitor destination (IP or domain name). + :type address: str + :param port: The destination port used by connection monitor. + :type port: int + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + resource_id: Optional[str] = None, + address: Optional[str] = None, + port: Optional[int] = None, + **kwargs + ): + super(ConnectionMonitorDestination, self).__init__(**kwargs) + self.resource_id = resource_id + self.address = address + self.port = port + + +class ConnectionMonitorEndpoint(msrest.serialization.Model): + """Describes the connection monitor endpoint. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor endpoint. + :type name: str + :param type: The endpoint type. Possible values include: "AzureVM", "AzureVNet", "AzureSubnet", + "ExternalAddress", "MMAWorkspaceMachine", "MMAWorkspaceNetwork". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.EndpointType + :param resource_id: Resource ID of the connection monitor endpoint. + :type resource_id: str + :param address: Address of the connection monitor endpoint (IP or domain name). + :type address: str + :param filter: Filter for sub-items within the endpoint. + :type filter: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilter + :param scope: Endpoint scope. + :type scope: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScope + :param coverage_level: Test coverage for the endpoint. Possible values include: "Default", + "Low", "BelowAverage", "Average", "AboveAverage", "Full". + :type coverage_level: str or ~azure.mgmt.network.v2020_08_01.models.CoverageLevel + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'filter': {'key': 'filter', 'type': 'ConnectionMonitorEndpointFilter'}, + 'scope': {'key': 'scope', 'type': 'ConnectionMonitorEndpointScope'}, + 'coverage_level': {'key': 'coverageLevel', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + type: Optional[Union[str, "EndpointType"]] = None, + resource_id: Optional[str] = None, + address: Optional[str] = None, + filter: Optional["ConnectionMonitorEndpointFilter"] = None, + scope: Optional["ConnectionMonitorEndpointScope"] = None, + coverage_level: Optional[Union[str, "CoverageLevel"]] = None, + **kwargs + ): + super(ConnectionMonitorEndpoint, self).__init__(**kwargs) + self.name = name + self.type = type + self.resource_id = resource_id + self.address = address + self.filter = filter + self.scope = scope + self.coverage_level = coverage_level + + +class ConnectionMonitorEndpointFilter(msrest.serialization.Model): + """Describes the connection monitor endpoint filter. + + :param type: The behavior of the endpoint filter. Currently only 'Include' is supported. + Possible values include: "Include". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterType + :param items: List of items in the filter. + :type items: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterItem] + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'items': {'key': 'items', 'type': '[ConnectionMonitorEndpointFilterItem]'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ConnectionMonitorEndpointFilterType"]] = None, + items: Optional[List["ConnectionMonitorEndpointFilterItem"]] = None, + **kwargs + ): + super(ConnectionMonitorEndpointFilter, self).__init__(**kwargs) + self.type = type + self.items = items + + +class ConnectionMonitorEndpointFilterItem(msrest.serialization.Model): + """Describes the connection monitor endpoint filter item. + + :param type: The type of item included in the filter. Currently only 'AgentAddress' is + supported. Possible values include: "AgentAddress". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointFilterItemType + :param address: The address of the filter item. + :type address: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ConnectionMonitorEndpointFilterItemType"]] = None, + address: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorEndpointFilterItem, self).__init__(**kwargs) + self.type = type + self.address = address + + +class ConnectionMonitorEndpointScope(msrest.serialization.Model): + """Describes the connection monitor endpoint scope. + + :param include: List of items which needs to be included to the endpoint scope. + :type include: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScopeItem] + :param exclude: List of items which needs to be excluded from the endpoint scope. + :type exclude: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpointScopeItem] + """ + + _attribute_map = { + 'include': {'key': 'include', 'type': '[ConnectionMonitorEndpointScopeItem]'}, + 'exclude': {'key': 'exclude', 'type': '[ConnectionMonitorEndpointScopeItem]'}, + } + + def __init__( + self, + *, + include: Optional[List["ConnectionMonitorEndpointScopeItem"]] = None, + exclude: Optional[List["ConnectionMonitorEndpointScopeItem"]] = None, + **kwargs + ): + super(ConnectionMonitorEndpointScope, self).__init__(**kwargs) + self.include = include + self.exclude = exclude + + +class ConnectionMonitorEndpointScopeItem(msrest.serialization.Model): + """Describes the connection monitor endpoint scope item. + + :param address: The address of the endpoint item. Supported types are IPv4/IPv6 subnet mask or + IPv4/IPv6 IP address. + :type address: str + """ + + _attribute_map = { + 'address': {'key': 'address', 'type': 'str'}, + } + + def __init__( + self, + *, + address: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorEndpointScopeItem, self).__init__(**kwargs) + self.address = address + + +class ConnectionMonitorHttpConfiguration(msrest.serialization.Model): + """Describes the HTTP configuration. + + :param port: The port to connect to. + :type port: int + :param method: The HTTP method to use. Possible values include: "Get", "Post". + :type method: str or ~azure.mgmt.network.v2020_08_01.models.HTTPConfigurationMethod + :param path: The path component of the URI. For instance, "/dir1/dir2". + :type path: str + :param request_headers: The HTTP headers to transmit with the request. + :type request_headers: list[~azure.mgmt.network.v2020_08_01.models.HTTPHeader] + :param valid_status_code_ranges: HTTP status codes to consider successful. For instance, + "2xx,301-304,418". + :type valid_status_code_ranges: list[str] + :param prefer_https: Value indicating whether HTTPS is preferred over HTTP in cases where the + choice is not explicit. + :type prefer_https: bool + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'port': {'key': 'port', 'type': 'int'}, + 'method': {'key': 'method', 'type': 'str'}, + 'path': {'key': 'path', 'type': 'str'}, + 'request_headers': {'key': 'requestHeaders', 'type': '[HTTPHeader]'}, + 'valid_status_code_ranges': {'key': 'validStatusCodeRanges', 'type': '[str]'}, + 'prefer_https': {'key': 'preferHTTPS', 'type': 'bool'}, + } + + def __init__( + self, + *, + port: Optional[int] = None, + method: Optional[Union[str, "HTTPConfigurationMethod"]] = None, + path: Optional[str] = None, + request_headers: Optional[List["HTTPHeader"]] = None, + valid_status_code_ranges: Optional[List[str]] = None, + prefer_https: Optional[bool] = None, + **kwargs + ): + super(ConnectionMonitorHttpConfiguration, self).__init__(**kwargs) + self.port = port + self.method = method + self.path = path + self.request_headers = request_headers + self.valid_status_code_ranges = valid_status_code_ranges + self.prefer_https = prefer_https + + +class ConnectionMonitorIcmpConfiguration(msrest.serialization.Model): + """Describes the ICMP configuration. + + :param disable_trace_route: Value indicating whether path evaluation with trace route should be + disabled. + :type disable_trace_route: bool + """ + + _attribute_map = { + 'disable_trace_route': {'key': 'disableTraceRoute', 'type': 'bool'}, + } + + def __init__( + self, + *, + disable_trace_route: Optional[bool] = None, + **kwargs + ): + super(ConnectionMonitorIcmpConfiguration, self).__init__(**kwargs) + self.disable_trace_route = disable_trace_route + + +class ConnectionMonitorListResult(msrest.serialization.Model): + """List of connection monitors. + + :param value: Information about connection monitors. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ConnectionMonitorResult]'}, + } + + def __init__( + self, + *, + value: Optional[List["ConnectionMonitorResult"]] = None, + **kwargs + ): + super(ConnectionMonitorListResult, self).__init__(**kwargs) + self.value = value + + +class ConnectionMonitorOutput(msrest.serialization.Model): + """Describes a connection monitor output destination. + + :param type: Connection monitor output destination type. Currently, only "Workspace" is + supported. Possible values include: "Workspace". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.OutputType + :param workspace_settings: Describes the settings for producing output into a log analytics + workspace. + :type workspace_settings: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorWorkspaceSettings + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'workspace_settings': {'key': 'workspaceSettings', 'type': 'ConnectionMonitorWorkspaceSettings'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "OutputType"]] = None, + workspace_settings: Optional["ConnectionMonitorWorkspaceSettings"] = None, + **kwargs + ): + super(ConnectionMonitorOutput, self).__init__(**kwargs) + self.type = type + self.workspace_settings = workspace_settings + + +class ConnectionMonitorParameters(msrest.serialization.Model): + """Parameters that define the operation to create a connection monitor. + + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'notes', 'type': 'str'}, + } + + def __init__( + self, + *, + source: Optional["ConnectionMonitorSource"] = None, + destination: Optional["ConnectionMonitorDestination"] = None, + auto_start: Optional[bool] = True, + monitoring_interval_in_seconds: Optional[int] = 60, + endpoints: Optional[List["ConnectionMonitorEndpoint"]] = None, + test_configurations: Optional[List["ConnectionMonitorTestConfiguration"]] = None, + test_groups: Optional[List["ConnectionMonitorTestGroup"]] = None, + outputs: Optional[List["ConnectionMonitorOutput"]] = None, + notes: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorParameters, self).__init__(**kwargs) + self.source = source + self.destination = destination + self.auto_start = auto_start + self.monitoring_interval_in_seconds = monitoring_interval_in_seconds + self.endpoints = endpoints + self.test_configurations = test_configurations + self.test_groups = test_groups + self.outputs = outputs + self.notes = notes + + +class ConnectionMonitorQueryResult(msrest.serialization.Model): + """List of connection states snapshots. + + :param source_status: Status of connection monitor source. Possible values include: "Unknown", + "Active", "Inactive". + :type source_status: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSourceStatus + :param states: Information about connection states. + :type states: list[~azure.mgmt.network.v2020_08_01.models.ConnectionStateSnapshot] + """ + + _attribute_map = { + 'source_status': {'key': 'sourceStatus', 'type': 'str'}, + 'states': {'key': 'states', 'type': '[ConnectionStateSnapshot]'}, + } + + def __init__( + self, + *, + source_status: Optional[Union[str, "ConnectionMonitorSourceStatus"]] = None, + states: Optional[List["ConnectionStateSnapshot"]] = None, + **kwargs + ): + super(ConnectionMonitorQueryResult, self).__init__(**kwargs) + self.source_status = source_status + self.states = states + + +class ConnectionMonitorResult(msrest.serialization.Model): + """Information about the connection monitor. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: Name of the connection monitor. + :vartype name: str + :ivar id: ID of the connection monitor. + :vartype id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Connection monitor type. + :vartype type: str + :param location: Connection monitor location. + :type location: str + :param tags: A set of tags. Connection monitor tags. + :type tags: dict[str, str] + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + :ivar provisioning_state: The provisioning state of the connection monitor. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar start_time: The date and time when the connection monitor was started. + :vartype start_time: ~datetime.datetime + :ivar monitoring_status: The monitoring status of the connection monitor. + :vartype monitoring_status: str + :ivar connection_monitor_type: Type of connection monitor. Possible values include: + "MultiEndpoint", "SingleSourceDestination". + :vartype connection_monitor_type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorType + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'monitoring_status': {'readonly': True}, + 'connection_monitor_type': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'source': {'key': 'properties.source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'properties.destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'properties.autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'properties.monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'properties.endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'properties.testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'properties.testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'properties.outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'properties.notes', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'monitoring_status': {'key': 'properties.monitoringStatus', 'type': 'str'}, + 'connection_monitor_type': {'key': 'properties.connectionMonitorType', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + source: Optional["ConnectionMonitorSource"] = None, + destination: Optional["ConnectionMonitorDestination"] = None, + auto_start: Optional[bool] = True, + monitoring_interval_in_seconds: Optional[int] = 60, + endpoints: Optional[List["ConnectionMonitorEndpoint"]] = None, + test_configurations: Optional[List["ConnectionMonitorTestConfiguration"]] = None, + test_groups: Optional[List["ConnectionMonitorTestGroup"]] = None, + outputs: Optional[List["ConnectionMonitorOutput"]] = None, + notes: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.etag = None + self.type = None + self.location = location + self.tags = tags + self.source = source + self.destination = destination + self.auto_start = auto_start + self.monitoring_interval_in_seconds = monitoring_interval_in_seconds + self.endpoints = endpoints + self.test_configurations = test_configurations + self.test_groups = test_groups + self.outputs = outputs + self.notes = notes + self.provisioning_state = None + self.start_time = None + self.monitoring_status = None + self.connection_monitor_type = None + + +class ConnectionMonitorResultProperties(ConnectionMonitorParameters): + """Describes the properties of a connection monitor. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param source: Describes the source of connection monitor. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSource + :param destination: Describes the destination of connection monitor. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorDestination + :param auto_start: Determines if the connection monitor will start automatically once created. + :type auto_start: bool + :param monitoring_interval_in_seconds: Monitoring interval in seconds. + :type monitoring_interval_in_seconds: int + :param endpoints: List of connection monitor endpoints. + :type endpoints: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorEndpoint] + :param test_configurations: List of connection monitor test configurations. + :type test_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfiguration] + :param test_groups: List of connection monitor test groups. + :type test_groups: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestGroup] + :param outputs: List of connection monitor outputs. + :type outputs: list[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorOutput] + :param notes: Optional notes to be associated with the connection monitor. + :type notes: str + :ivar provisioning_state: The provisioning state of the connection monitor. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar start_time: The date and time when the connection monitor was started. + :vartype start_time: ~datetime.datetime + :ivar monitoring_status: The monitoring status of the connection monitor. + :vartype monitoring_status: str + :ivar connection_monitor_type: Type of connection monitor. Possible values include: + "MultiEndpoint", "SingleSourceDestination". + :vartype connection_monitor_type: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorType + """ + + _validation = { + 'monitoring_interval_in_seconds': {'maximum': 1800, 'minimum': 30}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'monitoring_status': {'readonly': True}, + 'connection_monitor_type': {'readonly': True}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectionMonitorSource'}, + 'destination': {'key': 'destination', 'type': 'ConnectionMonitorDestination'}, + 'auto_start': {'key': 'autoStart', 'type': 'bool'}, + 'monitoring_interval_in_seconds': {'key': 'monitoringIntervalInSeconds', 'type': 'int'}, + 'endpoints': {'key': 'endpoints', 'type': '[ConnectionMonitorEndpoint]'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[ConnectionMonitorTestConfiguration]'}, + 'test_groups': {'key': 'testGroups', 'type': '[ConnectionMonitorTestGroup]'}, + 'outputs': {'key': 'outputs', 'type': '[ConnectionMonitorOutput]'}, + 'notes': {'key': 'notes', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'monitoring_status': {'key': 'monitoringStatus', 'type': 'str'}, + 'connection_monitor_type': {'key': 'connectionMonitorType', 'type': 'str'}, + } + + def __init__( + self, + *, + source: Optional["ConnectionMonitorSource"] = None, + destination: Optional["ConnectionMonitorDestination"] = None, + auto_start: Optional[bool] = True, + monitoring_interval_in_seconds: Optional[int] = 60, + endpoints: Optional[List["ConnectionMonitorEndpoint"]] = None, + test_configurations: Optional[List["ConnectionMonitorTestConfiguration"]] = None, + test_groups: Optional[List["ConnectionMonitorTestGroup"]] = None, + outputs: Optional[List["ConnectionMonitorOutput"]] = None, + notes: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorResultProperties, self).__init__(source=source, destination=destination, auto_start=auto_start, monitoring_interval_in_seconds=monitoring_interval_in_seconds, endpoints=endpoints, test_configurations=test_configurations, test_groups=test_groups, outputs=outputs, notes=notes, **kwargs) + self.provisioning_state = None + self.start_time = None + self.monitoring_status = None + self.connection_monitor_type = None + + +class ConnectionMonitorSource(msrest.serialization.Model): + """Describes the source of connection monitor. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. The ID of the resource used as the source by connection monitor. + :type resource_id: str + :param port: The source port used by connection monitor. + :type port: int + """ + + _validation = { + 'resource_id': {'required': True}, + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + resource_id: str, + port: Optional[int] = None, + **kwargs + ): + super(ConnectionMonitorSource, self).__init__(**kwargs) + self.resource_id = resource_id + self.port = port + + +class ConnectionMonitorSuccessThreshold(msrest.serialization.Model): + """Describes the threshold for declaring a test successful. + + :param checks_failed_percent: The maximum percentage of failed checks permitted for a test to + evaluate as successful. + :type checks_failed_percent: int + :param round_trip_time_ms: The maximum round-trip time in milliseconds permitted for a test to + evaluate as successful. + :type round_trip_time_ms: float + """ + + _attribute_map = { + 'checks_failed_percent': {'key': 'checksFailedPercent', 'type': 'int'}, + 'round_trip_time_ms': {'key': 'roundTripTimeMs', 'type': 'float'}, + } + + def __init__( + self, + *, + checks_failed_percent: Optional[int] = None, + round_trip_time_ms: Optional[float] = None, + **kwargs + ): + super(ConnectionMonitorSuccessThreshold, self).__init__(**kwargs) + self.checks_failed_percent = checks_failed_percent + self.round_trip_time_ms = round_trip_time_ms + + +class ConnectionMonitorTcpConfiguration(msrest.serialization.Model): + """Describes the TCP configuration. + + :param port: The port to connect to. + :type port: int + :param disable_trace_route: Value indicating whether path evaluation with trace route should be + disabled. + :type disable_trace_route: bool + :param destination_port_behavior: Destination port behavior. Possible values include: "None", + "ListenIfAvailable". + :type destination_port_behavior: str or + ~azure.mgmt.network.v2020_08_01.models.DestinationPortBehavior + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'port': {'key': 'port', 'type': 'int'}, + 'disable_trace_route': {'key': 'disableTraceRoute', 'type': 'bool'}, + 'destination_port_behavior': {'key': 'destinationPortBehavior', 'type': 'str'}, + } + + def __init__( + self, + *, + port: Optional[int] = None, + disable_trace_route: Optional[bool] = None, + destination_port_behavior: Optional[Union[str, "DestinationPortBehavior"]] = None, + **kwargs + ): + super(ConnectionMonitorTcpConfiguration, self).__init__(**kwargs) + self.port = port + self.disable_trace_route = disable_trace_route + self.destination_port_behavior = destination_port_behavior + + +class ConnectionMonitorTestConfiguration(msrest.serialization.Model): + """Describes a connection monitor test configuration. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor test configuration. + :type name: str + :param test_frequency_sec: The frequency of test evaluation, in seconds. + :type test_frequency_sec: int + :param protocol: Required. The protocol to use in test evaluation. Possible values include: + "Tcp", "Http", "Icmp". + :type protocol: str or + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTestConfigurationProtocol + :param preferred_ip_version: The preferred IP version to use in test evaluation. The connection + monitor may choose to use a different version depending on other parameters. Possible values + include: "IPv4", "IPv6". + :type preferred_ip_version: str or ~azure.mgmt.network.v2020_08_01.models.PreferredIPVersion + :param http_configuration: The parameters used to perform test evaluation over HTTP. + :type http_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorHttpConfiguration + :param tcp_configuration: The parameters used to perform test evaluation over TCP. + :type tcp_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorTcpConfiguration + :param icmp_configuration: The parameters used to perform test evaluation over ICMP. + :type icmp_configuration: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorIcmpConfiguration + :param success_threshold: The threshold for declaring a test successful. + :type success_threshold: + ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorSuccessThreshold + """ + + _validation = { + 'name': {'required': True}, + 'protocol': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'test_frequency_sec': {'key': 'testFrequencySec', 'type': 'int'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'preferred_ip_version': {'key': 'preferredIPVersion', 'type': 'str'}, + 'http_configuration': {'key': 'httpConfiguration', 'type': 'ConnectionMonitorHttpConfiguration'}, + 'tcp_configuration': {'key': 'tcpConfiguration', 'type': 'ConnectionMonitorTcpConfiguration'}, + 'icmp_configuration': {'key': 'icmpConfiguration', 'type': 'ConnectionMonitorIcmpConfiguration'}, + 'success_threshold': {'key': 'successThreshold', 'type': 'ConnectionMonitorSuccessThreshold'}, + } + + def __init__( + self, + *, + name: str, + protocol: Union[str, "ConnectionMonitorTestConfigurationProtocol"], + test_frequency_sec: Optional[int] = None, + preferred_ip_version: Optional[Union[str, "PreferredIPVersion"]] = None, + http_configuration: Optional["ConnectionMonitorHttpConfiguration"] = None, + tcp_configuration: Optional["ConnectionMonitorTcpConfiguration"] = None, + icmp_configuration: Optional["ConnectionMonitorIcmpConfiguration"] = None, + success_threshold: Optional["ConnectionMonitorSuccessThreshold"] = None, + **kwargs + ): + super(ConnectionMonitorTestConfiguration, self).__init__(**kwargs) + self.name = name + self.test_frequency_sec = test_frequency_sec + self.protocol = protocol + self.preferred_ip_version = preferred_ip_version + self.http_configuration = http_configuration + self.tcp_configuration = tcp_configuration + self.icmp_configuration = icmp_configuration + self.success_threshold = success_threshold + + +class ConnectionMonitorTestGroup(msrest.serialization.Model): + """Describes the connection monitor test group. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the connection monitor test group. + :type name: str + :param disable: Value indicating whether test group is disabled. + :type disable: bool + :param test_configurations: Required. List of test configuration names. + :type test_configurations: list[str] + :param sources: Required. List of source endpoint names. + :type sources: list[str] + :param destinations: Required. List of destination endpoint names. + :type destinations: list[str] + """ + + _validation = { + 'name': {'required': True}, + 'test_configurations': {'required': True}, + 'sources': {'required': True}, + 'destinations': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'disable': {'key': 'disable', 'type': 'bool'}, + 'test_configurations': {'key': 'testConfigurations', 'type': '[str]'}, + 'sources': {'key': 'sources', 'type': '[str]'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: str, + test_configurations: List[str], + sources: List[str], + destinations: List[str], + disable: Optional[bool] = None, + **kwargs + ): + super(ConnectionMonitorTestGroup, self).__init__(**kwargs) + self.name = name + self.disable = disable + self.test_configurations = test_configurations + self.sources = sources + self.destinations = destinations + + +class ConnectionMonitorWorkspaceSettings(msrest.serialization.Model): + """Describes the settings for producing output into a log analytics workspace. + + :param workspace_resource_id: Log analytics workspace resource ID. + :type workspace_resource_id: str + """ + + _attribute_map = { + 'workspace_resource_id': {'key': 'workspaceResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + workspace_resource_id: Optional[str] = None, + **kwargs + ): + super(ConnectionMonitorWorkspaceSettings, self).__init__(**kwargs) + self.workspace_resource_id = workspace_resource_id + + +class ConnectionResetSharedKey(msrest.serialization.Model): + """The virtual network connection reset shared key. + + All required parameters must be populated in order to send to Azure. + + :param key_length: Required. The virtual network connection reset shared key length, should + between 1 and 128. + :type key_length: int + """ + + _validation = { + 'key_length': {'required': True, 'maximum': 128, 'minimum': 1}, + } + + _attribute_map = { + 'key_length': {'key': 'keyLength', 'type': 'int'}, + } + + def __init__( + self, + *, + key_length: int, + **kwargs + ): + super(ConnectionResetSharedKey, self).__init__(**kwargs) + self.key_length = key_length + + +class ConnectionSharedKey(SubResource): + """Response for GetConnectionSharedKey API service call. + + All required parameters must be populated in order to send to Azure. + + :param id: Resource ID. + :type id: str + :param value: Required. The virtual network connection shared key value. + :type value: str + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + value: str, + id: Optional[str] = None, + **kwargs + ): + super(ConnectionSharedKey, self).__init__(id=id, **kwargs) + self.value = value + + +class ConnectionStateSnapshot(msrest.serialization.Model): + """Connection state snapshot. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param connection_state: The connection state. Possible values include: "Reachable", + "Unreachable", "Unknown". + :type connection_state: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionState + :param start_time: The start time of the connection snapshot. + :type start_time: ~datetime.datetime + :param end_time: The end time of the connection snapshot. + :type end_time: ~datetime.datetime + :param evaluation_state: Connectivity analysis evaluation state. Possible values include: + "NotStarted", "InProgress", "Completed". + :type evaluation_state: str or ~azure.mgmt.network.v2020_08_01.models.EvaluationState + :param avg_latency_in_ms: Average latency in ms. + :type avg_latency_in_ms: long + :param min_latency_in_ms: Minimum latency in ms. + :type min_latency_in_ms: long + :param max_latency_in_ms: Maximum latency in ms. + :type max_latency_in_ms: long + :param probes_sent: The number of sent probes. + :type probes_sent: long + :param probes_failed: The number of failed probes. + :type probes_failed: long + :ivar hops: List of hops between the source and the destination. + :vartype hops: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityHop] + """ + + _validation = { + 'avg_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'min_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'max_latency_in_ms': {'maximum': 4294967295, 'minimum': 0}, + 'probes_sent': {'maximum': 4294967295, 'minimum': 0}, + 'probes_failed': {'maximum': 4294967295, 'minimum': 0}, + 'hops': {'readonly': True}, + } + + _attribute_map = { + 'connection_state': {'key': 'connectionState', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'evaluation_state': {'key': 'evaluationState', 'type': 'str'}, + 'avg_latency_in_ms': {'key': 'avgLatencyInMs', 'type': 'long'}, + 'min_latency_in_ms': {'key': 'minLatencyInMs', 'type': 'long'}, + 'max_latency_in_ms': {'key': 'maxLatencyInMs', 'type': 'long'}, + 'probes_sent': {'key': 'probesSent', 'type': 'long'}, + 'probes_failed': {'key': 'probesFailed', 'type': 'long'}, + 'hops': {'key': 'hops', 'type': '[ConnectivityHop]'}, + } + + def __init__( + self, + *, + connection_state: Optional[Union[str, "ConnectionState"]] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + evaluation_state: Optional[Union[str, "EvaluationState"]] = None, + avg_latency_in_ms: Optional[int] = None, + min_latency_in_ms: Optional[int] = None, + max_latency_in_ms: Optional[int] = None, + probes_sent: Optional[int] = None, + probes_failed: Optional[int] = None, + **kwargs + ): + super(ConnectionStateSnapshot, self).__init__(**kwargs) + self.connection_state = connection_state + self.start_time = start_time + self.end_time = end_time + self.evaluation_state = evaluation_state + self.avg_latency_in_ms = avg_latency_in_ms + self.min_latency_in_ms = min_latency_in_ms + self.max_latency_in_ms = max_latency_in_ms + self.probes_sent = probes_sent + self.probes_failed = probes_failed + self.hops = None + + +class ConnectivityDestination(msrest.serialization.Model): + """Parameters that define destination of connection. + + :param resource_id: The ID of the resource to which a connection attempt will be made. + :type resource_id: str + :param address: The IP address or URI the resource to which a connection attempt will be made. + :type address: str + :param port: Port on which check connectivity will be performed. + :type port: int + """ + + _validation = { + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + resource_id: Optional[str] = None, + address: Optional[str] = None, + port: Optional[int] = None, + **kwargs + ): + super(ConnectivityDestination, self).__init__(**kwargs) + self.resource_id = resource_id + self.address = address + self.port = port + + +class ConnectivityHop(msrest.serialization.Model): + """Information about a hop between the source and the destination. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the hop. + :vartype type: str + :ivar id: The ID of the hop. + :vartype id: str + :ivar address: The IP address of the hop. + :vartype address: str + :ivar resource_id: The ID of the resource corresponding to this hop. + :vartype resource_id: str + :ivar next_hop_ids: List of next hop identifiers. + :vartype next_hop_ids: list[str] + :ivar previous_hop_ids: List of previous hop identifiers. + :vartype previous_hop_ids: list[str] + :ivar links: List of hop links. + :vartype links: list[~azure.mgmt.network.v2020_08_01.models.HopLink] + :ivar previous_links: List of previous hop links. + :vartype previous_links: list[~azure.mgmt.network.v2020_08_01.models.HopLink] + :ivar issues: List of issues. + :vartype issues: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityIssue] + """ + + _validation = { + 'type': {'readonly': True}, + 'id': {'readonly': True}, + 'address': {'readonly': True}, + 'resource_id': {'readonly': True}, + 'next_hop_ids': {'readonly': True}, + 'previous_hop_ids': {'readonly': True}, + 'links': {'readonly': True}, + 'previous_links': {'readonly': True}, + 'issues': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'address': {'key': 'address', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'next_hop_ids': {'key': 'nextHopIds', 'type': '[str]'}, + 'previous_hop_ids': {'key': 'previousHopIds', 'type': '[str]'}, + 'links': {'key': 'links', 'type': '[HopLink]'}, + 'previous_links': {'key': 'previousLinks', 'type': '[HopLink]'}, + 'issues': {'key': 'issues', 'type': '[ConnectivityIssue]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityHop, self).__init__(**kwargs) + self.type = None + self.id = None + self.address = None + self.resource_id = None + self.next_hop_ids = None + self.previous_hop_ids = None + self.links = None + self.previous_links = None + self.issues = None + + +class ConnectivityInformation(msrest.serialization.Model): + """Information on the connectivity status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar hops: List of hops between the source and the destination. + :vartype hops: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityHop] + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connected", "Disconnected", "Degraded". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.ConnectionStatus + :ivar avg_latency_in_ms: Average latency in milliseconds. + :vartype avg_latency_in_ms: int + :ivar min_latency_in_ms: Minimum latency in milliseconds. + :vartype min_latency_in_ms: int + :ivar max_latency_in_ms: Maximum latency in milliseconds. + :vartype max_latency_in_ms: int + :ivar probes_sent: Total number of probes sent. + :vartype probes_sent: int + :ivar probes_failed: Number of failed probes. + :vartype probes_failed: int + """ + + _validation = { + 'hops': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'avg_latency_in_ms': {'readonly': True}, + 'min_latency_in_ms': {'readonly': True}, + 'max_latency_in_ms': {'readonly': True}, + 'probes_sent': {'readonly': True}, + 'probes_failed': {'readonly': True}, + } + + _attribute_map = { + 'hops': {'key': 'hops', 'type': '[ConnectivityHop]'}, + 'connection_status': {'key': 'connectionStatus', 'type': 'str'}, + 'avg_latency_in_ms': {'key': 'avgLatencyInMs', 'type': 'int'}, + 'min_latency_in_ms': {'key': 'minLatencyInMs', 'type': 'int'}, + 'max_latency_in_ms': {'key': 'maxLatencyInMs', 'type': 'int'}, + 'probes_sent': {'key': 'probesSent', 'type': 'int'}, + 'probes_failed': {'key': 'probesFailed', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityInformation, self).__init__(**kwargs) + self.hops = None + self.connection_status = None + self.avg_latency_in_ms = None + self.min_latency_in_ms = None + self.max_latency_in_ms = None + self.probes_sent = None + self.probes_failed = None + + +class ConnectivityIssue(msrest.serialization.Model): + """Information about an issue encountered in the process of checking for connectivity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar origin: The origin of the issue. Possible values include: "Local", "Inbound", "Outbound". + :vartype origin: str or ~azure.mgmt.network.v2020_08_01.models.Origin + :ivar severity: The severity of the issue. Possible values include: "Error", "Warning". + :vartype severity: str or ~azure.mgmt.network.v2020_08_01.models.Severity + :ivar type: The type of issue. Possible values include: "Unknown", "AgentStopped", + "GuestFirewall", "DnsResolution", "SocketBind", "NetworkSecurityRule", "UserDefinedRoute", + "PortThrottled", "Platform". + :vartype type: str or ~azure.mgmt.network.v2020_08_01.models.IssueType + :ivar context: Provides additional context on the issue. + :vartype context: list[dict[str, str]] + """ + + _validation = { + 'origin': {'readonly': True}, + 'severity': {'readonly': True}, + 'type': {'readonly': True}, + 'context': {'readonly': True}, + } + + _attribute_map = { + 'origin': {'key': 'origin', 'type': 'str'}, + 'severity': {'key': 'severity', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'context': {'key': 'context', 'type': '[{str}]'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectivityIssue, self).__init__(**kwargs) + self.origin = None + self.severity = None + self.type = None + self.context = None + + +class ConnectivityParameters(msrest.serialization.Model): + """Parameters that determine how the connectivity check will be performed. + + All required parameters must be populated in order to send to Azure. + + :param source: Required. The source of the connection. + :type source: ~azure.mgmt.network.v2020_08_01.models.ConnectivitySource + :param destination: Required. The destination of connection. + :type destination: ~azure.mgmt.network.v2020_08_01.models.ConnectivityDestination + :param protocol: Network protocol. Possible values include: "Tcp", "Http", "Https", "Icmp". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.Protocol + :param protocol_configuration: Configuration of the protocol. + :type protocol_configuration: ~azure.mgmt.network.v2020_08_01.models.ProtocolConfiguration + :param preferred_ip_version: Preferred IP version of the connection. Possible values include: + "IPv4", "IPv6". + :type preferred_ip_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + """ + + _validation = { + 'source': {'required': True}, + 'destination': {'required': True}, + } + + _attribute_map = { + 'source': {'key': 'source', 'type': 'ConnectivitySource'}, + 'destination': {'key': 'destination', 'type': 'ConnectivityDestination'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'protocol_configuration': {'key': 'protocolConfiguration', 'type': 'ProtocolConfiguration'}, + 'preferred_ip_version': {'key': 'preferredIPVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + source: "ConnectivitySource", + destination: "ConnectivityDestination", + protocol: Optional[Union[str, "Protocol"]] = None, + protocol_configuration: Optional["ProtocolConfiguration"] = None, + preferred_ip_version: Optional[Union[str, "IPVersion"]] = None, + **kwargs + ): + super(ConnectivityParameters, self).__init__(**kwargs) + self.source = source + self.destination = destination + self.protocol = protocol + self.protocol_configuration = protocol_configuration + self.preferred_ip_version = preferred_ip_version + + +class ConnectivitySource(msrest.serialization.Model): + """Parameters that define the source of the connection. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. The ID of the resource from which a connectivity check will be + initiated. + :type resource_id: str + :param port: The source port from which a connectivity check will be performed. + :type port: int + """ + + _validation = { + 'resource_id': {'required': True}, + 'port': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + resource_id: str, + port: Optional[int] = None, + **kwargs + ): + super(ConnectivitySource, self).__init__(**kwargs) + self.resource_id = resource_id + self.port = port + + +class Container(SubResource): + """Reference to container resource in remote resource provider. + + :param id: Resource ID. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(Container, self).__init__(id=id, **kwargs) + + +class ContainerNetworkInterface(SubResource): + """Container network interface child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar container_network_interface_configuration: Container network interface configuration from + which this container network interface is created. + :vartype container_network_interface_configuration: + ~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceConfiguration + :param container: Reference to the container to which this container network interface is + attached. + :type container: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar ip_configurations: Reference to the ip configuration on this container nic. + :vartype ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceIpConfiguration] + :ivar provisioning_state: The provisioning state of the container network interface resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'container_network_interface_configuration': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'container_network_interface_configuration': {'key': 'properties.containerNetworkInterfaceConfiguration', 'type': 'ContainerNetworkInterfaceConfiguration'}, + 'container': {'key': 'properties.container', 'type': 'SubResource'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[ContainerNetworkInterfaceIpConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + container: Optional["SubResource"] = None, + **kwargs + ): + super(ContainerNetworkInterface, self).__init__(id=id, **kwargs) + self.name = name + self.type = None + self.etag = None + self.container_network_interface_configuration = None + self.container = container + self.ip_configurations = None + self.provisioning_state = None + + +class ContainerNetworkInterfaceConfiguration(SubResource): + """Container network interface configuration child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: A list of ip configurations of the container network interface + configuration. + :type ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationProfile] + :param container_network_interfaces: A list of container network interfaces created from this + container network interface configuration. + :type container_network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the container network interface + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[IPConfigurationProfile]'}, + 'container_network_interfaces': {'key': 'properties.containerNetworkInterfaces', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + ip_configurations: Optional[List["IPConfigurationProfile"]] = None, + container_network_interfaces: Optional[List["SubResource"]] = None, + **kwargs + ): + super(ContainerNetworkInterfaceConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.type = None + self.etag = None + self.ip_configurations = ip_configurations + self.container_network_interfaces = container_network_interfaces + self.provisioning_state = None + + +class ContainerNetworkInterfaceIpConfiguration(msrest.serialization.Model): + """The ip configuration for a container network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the container network interface IP + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + **kwargs + ): + super(ContainerNetworkInterfaceIpConfiguration, self).__init__(**kwargs) + self.name = name + self.type = None + self.etag = None + self.provisioning_state = None + + +class CustomDnsConfigPropertiesFormat(msrest.serialization.Model): + """Contains custom Dns resolution configuration from customer. + + :param fqdn: Fqdn that resolves to private endpoint ip address. + :type fqdn: str + :param ip_addresses: A list of private ip addresses of the private endpoint. + :type ip_addresses: list[str] + """ + + _attribute_map = { + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + } + + def __init__( + self, + *, + fqdn: Optional[str] = None, + ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(CustomDnsConfigPropertiesFormat, self).__init__(**kwargs) + self.fqdn = fqdn + self.ip_addresses = ip_addresses + + +class CustomIpPrefix(Resource): + """Custom IP prefix resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the custom IP prefix. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param cidr: The prefix range in CIDR notation. Should include the start address and the prefix + length. + :type cidr: str + :param commissioned_state: The commissioned state of the Custom IP Prefix. Possible values + include: "Provisioning", "Provisioned", "Commissioning", "Commissioned", "Decommissioning", + "Deprovisioning". + :type commissioned_state: str or ~azure.mgmt.network.v2020_08_01.models.CommissionedState + :ivar public_ip_prefixes: The list of all referenced PublicIpPrefixes. + :vartype public_ip_prefixes: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_guid: The resource GUID property of the custom IP prefix resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the custom IP prefix resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'public_ip_prefixes': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'cidr': {'key': 'properties.cidr', 'type': 'str'}, + 'commissioned_state': {'key': 'properties.commissionedState', 'type': 'str'}, + 'public_ip_prefixes': {'key': 'properties.publicIpPrefixes', 'type': '[SubResource]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + zones: Optional[List[str]] = None, + cidr: Optional[str] = None, + commissioned_state: Optional[Union[str, "CommissionedState"]] = None, + **kwargs + ): + super(CustomIpPrefix, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.etag = None + self.zones = zones + self.cidr = cidr + self.commissioned_state = commissioned_state + self.public_ip_prefixes = None + self.resource_guid = None + self.provisioning_state = None + + +class CustomIpPrefixListResult(msrest.serialization.Model): + """Response for ListCustomIpPrefixes API service call. + + :param value: A list of Custom IP prefixes that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CustomIpPrefix]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["CustomIpPrefix"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(CustomIpPrefixListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class DdosCustomPolicy(Resource): + """A DDoS custom policy in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the DDoS custom policy resource. It uniquely + identifies the resource, even if the user changes its name or migrate the resource across + subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DDoS custom policy resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar public_ip_addresses: The list of public IPs associated with the DDoS custom policy + resource. This list is read-only. + :vartype public_ip_addresses: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param protocol_custom_settings: The protocol-specific DDoS policy customization parameters. + :type protocol_custom_settings: + list[~azure.mgmt.network.v2020_08_01.models.ProtocolCustomSettingsFormat] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'public_ip_addresses': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'public_ip_addresses': {'key': 'properties.publicIPAddresses', 'type': '[SubResource]'}, + 'protocol_custom_settings': {'key': 'properties.protocolCustomSettings', 'type': '[ProtocolCustomSettingsFormat]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + protocol_custom_settings: Optional[List["ProtocolCustomSettingsFormat"]] = None, + **kwargs + ): + super(DdosCustomPolicy, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.resource_guid = None + self.provisioning_state = None + self.public_ip_addresses = None + self.protocol_custom_settings = protocol_custom_settings + + +class DdosProtectionPlan(msrest.serialization.Model): + """A DDoS protection plan in a resource group. + + Variables are only populated by 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar resource_guid: The resource GUID property of the DDoS protection plan resource. It + uniquely identifies the resource, even if the user changes its name or migrate the resource + across subscriptions or resource groups. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DDoS protection plan resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar virtual_networks: The list of virtual networks associated with the DDoS protection plan + resource. This list is read-only. + :vartype virtual_networks: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'virtual_networks': {'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'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(DdosProtectionPlan, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = location + self.tags = tags + self.etag = None + self.resource_guid = None + self.provisioning_state = None + self.virtual_networks = None + + +class DdosProtectionPlanListResult(msrest.serialization.Model): + """A list of DDoS protection plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of DDoS protection plans. + :type value: list[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DdosProtectionPlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["DdosProtectionPlan"]] = None, + **kwargs + ): + super(DdosProtectionPlanListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DdosSettings(msrest.serialization.Model): + """Contains the DDoS protection settings of the public IP. + + :param ddos_custom_policy: The DDoS custom policy associated with the public IP. + :type ddos_custom_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protection_coverage: The DDoS protection policy customizability of the public IP. Only + standard coverage will have the ability to be customized. Possible values include: "Basic", + "Standard". + :type protection_coverage: str or + ~azure.mgmt.network.v2020_08_01.models.DdosSettingsProtectionCoverage + :param protected_ip: Enables DDoS protection on the public IP. + :type protected_ip: bool + """ + + _attribute_map = { + 'ddos_custom_policy': {'key': 'ddosCustomPolicy', 'type': 'SubResource'}, + 'protection_coverage': {'key': 'protectionCoverage', 'type': 'str'}, + 'protected_ip': {'key': 'protectedIP', 'type': 'bool'}, + } + + def __init__( + self, + *, + ddos_custom_policy: Optional["SubResource"] = None, + protection_coverage: Optional[Union[str, "DdosSettingsProtectionCoverage"]] = None, + protected_ip: Optional[bool] = None, + **kwargs + ): + super(DdosSettings, self).__init__(**kwargs) + self.ddos_custom_policy = ddos_custom_policy + self.protection_coverage = protection_coverage + self.protected_ip = protected_ip + + +class Delegation(SubResource): + """Details the service to which the subnet is delegated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a subnet. This name can be used to + access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param service_name: The name of the service to whom the subnet should be delegated (e.g. + Microsoft.Sql/servers). + :type service_name: str + :ivar actions: The actions permitted to the service upon delegation. + :vartype actions: list[str] + :ivar provisioning_state: The provisioning state of the service delegation resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'actions': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'service_name': {'key': 'properties.serviceName', 'type': 'str'}, + 'actions': {'key': 'properties.actions', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + service_name: Optional[str] = None, + **kwargs + ): + super(Delegation, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.service_name = service_name + self.actions = None + self.provisioning_state = None + + +class DeviceProperties(msrest.serialization.Model): + """List of properties of the device. + + :param device_vendor: Name of the device Vendor. + :type device_vendor: str + :param device_model: Model of the device. + :type device_model: str + :param link_speed_in_mbps: Link speed. + :type link_speed_in_mbps: int + """ + + _attribute_map = { + 'device_vendor': {'key': 'deviceVendor', 'type': 'str'}, + 'device_model': {'key': 'deviceModel', 'type': 'str'}, + 'link_speed_in_mbps': {'key': 'linkSpeedInMbps', 'type': 'int'}, + } + + def __init__( + self, + *, + device_vendor: Optional[str] = None, + device_model: Optional[str] = None, + link_speed_in_mbps: Optional[int] = None, + **kwargs + ): + super(DeviceProperties, self).__init__(**kwargs) + self.device_vendor = device_vendor + self.device_model = device_model + self.link_speed_in_mbps = link_speed_in_mbps + + +class DhcpOptions(msrest.serialization.Model): + """DhcpOptions contains an array of DNS servers available to VMs deployed in the virtual network. Standard DHCP option for a subnet overrides VNET DHCP options. + + :param dns_servers: The list of DNS servers IP addresses. + :type dns_servers: list[str] + """ + + _attribute_map = { + 'dns_servers': {'key': 'dnsServers', 'type': '[str]'}, + } + + def __init__( + self, + *, + dns_servers: Optional[List[str]] = None, + **kwargs + ): + super(DhcpOptions, self).__init__(**kwargs) + self.dns_servers = dns_servers + + +class Dimension(msrest.serialization.Model): + """Dimension of the metric. + + :param name: The name of the dimension. + :type name: str + :param display_name: The display name of the dimension. + :type display_name: str + :param internal_name: The internal name of the dimension. + :type internal_name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + internal_name: Optional[str] = None, + **kwargs + ): + super(Dimension, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.internal_name = internal_name + + +class DnsNameAvailabilityResult(msrest.serialization.Model): + """Response for the CheckDnsNameAvailability API service call. + + :param available: Domain availability (True/False). + :type available: bool + """ + + _attribute_map = { + 'available': {'key': 'available', 'type': 'bool'}, + } + + def __init__( + self, + *, + available: Optional[bool] = None, + **kwargs + ): + super(DnsNameAvailabilityResult, self).__init__(**kwargs) + self.available = available + + +class DnsSettings(msrest.serialization.Model): + """DNS Proxy Settings in Firewall Policy. + + :param servers: List of Custom DNS Servers. + :type servers: list[str] + :param enable_proxy: Enable DNS Proxy on Firewalls attached to the Firewall Policy. + :type enable_proxy: bool + :param require_proxy_for_network_rules: FQDNs in Network Rules are supported when set to true. + :type require_proxy_for_network_rules: bool + """ + + _attribute_map = { + 'servers': {'key': 'servers', 'type': '[str]'}, + 'enable_proxy': {'key': 'enableProxy', 'type': 'bool'}, + 'require_proxy_for_network_rules': {'key': 'requireProxyForNetworkRules', 'type': 'bool'}, + } + + def __init__( + self, + *, + servers: Optional[List[str]] = None, + enable_proxy: Optional[bool] = None, + require_proxy_for_network_rules: Optional[bool] = None, + **kwargs + ): + super(DnsSettings, self).__init__(**kwargs) + self.servers = servers + self.enable_proxy = enable_proxy + self.require_proxy_for_network_rules = require_proxy_for_network_rules + + +class DscpConfiguration(Resource): + """DSCP Configuration in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param markings: List of markings to be used in the configuration. + :type markings: list[int] + :param source_ip_ranges: Source IP ranges. + :type source_ip_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosIpRange] + :param destination_ip_ranges: Destination IP ranges. + :type destination_ip_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosIpRange] + :param source_port_ranges: Sources port ranges. + :type source_port_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosPortRange] + :param destination_port_ranges: Destination port ranges. + :type destination_port_ranges: list[~azure.mgmt.network.v2020_08_01.models.QosPortRange] + :param protocol: RNM supported protocol types. Possible values include: "DoNotUse", "Icmp", + "Tcp", "Udp", "Gre", "Esp", "Ah", "Vxlan", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ProtocolType + :ivar qos_collection_id: Qos Collection ID generated by RNM. + :vartype qos_collection_id: str + :ivar associated_network_interfaces: Associated Network Interfaces to the DSCP Configuration. + :vartype associated_network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar resource_guid: The resource GUID property of the DSCP Configuration resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the DSCP Configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'qos_collection_id': {'readonly': True}, + 'associated_network_interfaces': {'readonly': True}, + 'resource_guid': {'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'}, + 'markings': {'key': 'properties.markings', 'type': '[int]'}, + 'source_ip_ranges': {'key': 'properties.sourceIpRanges', 'type': '[QosIpRange]'}, + 'destination_ip_ranges': {'key': 'properties.destinationIpRanges', 'type': '[QosIpRange]'}, + 'source_port_ranges': {'key': 'properties.sourcePortRanges', 'type': '[QosPortRange]'}, + 'destination_port_ranges': {'key': 'properties.destinationPortRanges', 'type': '[QosPortRange]'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'qos_collection_id': {'key': 'properties.qosCollectionId', 'type': 'str'}, + 'associated_network_interfaces': {'key': 'properties.associatedNetworkInterfaces', 'type': '[NetworkInterface]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + markings: Optional[List[int]] = None, + source_ip_ranges: Optional[List["QosIpRange"]] = None, + destination_ip_ranges: Optional[List["QosIpRange"]] = None, + source_port_ranges: Optional[List["QosPortRange"]] = None, + destination_port_ranges: Optional[List["QosPortRange"]] = None, + protocol: Optional[Union[str, "ProtocolType"]] = None, + **kwargs + ): + super(DscpConfiguration, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.markings = markings + self.source_ip_ranges = source_ip_ranges + self.destination_ip_ranges = destination_ip_ranges + self.source_port_ranges = source_port_ranges + self.destination_port_ranges = destination_port_ranges + self.protocol = protocol + self.qos_collection_id = None + self.associated_network_interfaces = None + self.resource_guid = None + self.provisioning_state = None + + +class DscpConfigurationListResult(msrest.serialization.Model): + """Response for the DscpConfigurationList API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of dscp configurations in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.DscpConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DscpConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["DscpConfiguration"]] = None, + **kwargs + ): + super(DscpConfigurationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class EffectiveNetworkSecurityGroup(msrest.serialization.Model): + """Effective network security group. + + :param network_security_group: The ID of network security group that is applied. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param association: Associated resources. + :type association: + ~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroupAssociation + :param effective_security_rules: A collection of effective security rules. + :type effective_security_rules: + list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityRule] + :param tag_map: Mapping of tags to list of IP Addresses included within the tag. + :type tag_map: str + """ + + _attribute_map = { + 'network_security_group': {'key': 'networkSecurityGroup', 'type': 'SubResource'}, + 'association': {'key': 'association', 'type': 'EffectiveNetworkSecurityGroupAssociation'}, + 'effective_security_rules': {'key': 'effectiveSecurityRules', 'type': '[EffectiveNetworkSecurityRule]'}, + 'tag_map': {'key': 'tagMap', 'type': 'str'}, + } + + def __init__( + self, + *, + network_security_group: Optional["SubResource"] = None, + association: Optional["EffectiveNetworkSecurityGroupAssociation"] = None, + effective_security_rules: Optional[List["EffectiveNetworkSecurityRule"]] = None, + tag_map: Optional[str] = None, + **kwargs + ): + super(EffectiveNetworkSecurityGroup, self).__init__(**kwargs) + self.network_security_group = network_security_group + self.association = association + self.effective_security_rules = effective_security_rules + self.tag_map = tag_map + + +class EffectiveNetworkSecurityGroupAssociation(msrest.serialization.Model): + """The effective network security group association. + + :param subnet: The ID of the subnet if assigned. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param network_interface: The ID of the network interface if assigned. + :type network_interface: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'subnet': {'key': 'subnet', 'type': 'SubResource'}, + 'network_interface': {'key': 'networkInterface', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + subnet: Optional["SubResource"] = None, + network_interface: Optional["SubResource"] = None, + **kwargs + ): + super(EffectiveNetworkSecurityGroupAssociation, self).__init__(**kwargs) + self.subnet = subnet + self.network_interface = network_interface + + +class EffectiveNetworkSecurityGroupListResult(msrest.serialization.Model): + """Response for list effective network security groups API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of effective network security groups. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EffectiveNetworkSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["EffectiveNetworkSecurityGroup"]] = None, + **kwargs + ): + super(EffectiveNetworkSecurityGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class EffectiveNetworkSecurityRule(msrest.serialization.Model): + """Effective network security rules. + + :param name: The name of the security rule specified by the user (if created by the user). + :type name: str + :param protocol: The network protocol this rule applies to. Possible values include: "Tcp", + "Udp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveSecurityRuleProtocol + :param source_port_range: The source port or range. + :type source_port_range: str + :param destination_port_range: The destination port or range. + :type destination_port_range: str + :param source_port_ranges: The source port ranges. Expected values include a single integer + between 0 and 65535, a range using '-' as separator (e.g. 100-400), or an asterisk (*). + :type source_port_ranges: list[str] + :param destination_port_ranges: The destination port ranges. Expected values include a single + integer between 0 and 65535, a range using '-' as separator (e.g. 100-400), or an asterisk (*). + :type destination_port_ranges: list[str] + :param source_address_prefix: The source address prefix. + :type source_address_prefix: str + :param destination_address_prefix: The destination address prefix. + :type destination_address_prefix: str + :param source_address_prefixes: The source address prefixes. Expected values include CIDR IP + ranges, Default Tags (VirtualNetwork, AzureLoadBalancer, Internet), System Tags, and the + asterisk (*). + :type source_address_prefixes: list[str] + :param destination_address_prefixes: The destination address prefixes. Expected values include + CIDR IP ranges, Default Tags (VirtualNetwork, AzureLoadBalancer, Internet), System Tags, and + the asterisk (*). + :type destination_address_prefixes: list[str] + :param expanded_source_address_prefix: The expanded source address prefix. + :type expanded_source_address_prefix: list[str] + :param expanded_destination_address_prefix: Expanded destination address prefix. + :type expanded_destination_address_prefix: list[str] + :param access: Whether network traffic is allowed or denied. Possible values include: "Allow", + "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :param priority: The priority of the rule. + :type priority: int + :param direction: The direction of the rule. Possible values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleDirection + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_port_range': {'key': 'sourcePortRange', 'type': 'str'}, + 'destination_port_range': {'key': 'destinationPortRange', 'type': 'str'}, + 'source_port_ranges': {'key': 'sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'destinationPortRanges', 'type': '[str]'}, + 'source_address_prefix': {'key': 'sourceAddressPrefix', 'type': 'str'}, + 'destination_address_prefix': {'key': 'destinationAddressPrefix', 'type': 'str'}, + 'source_address_prefixes': {'key': 'sourceAddressPrefixes', 'type': '[str]'}, + 'destination_address_prefixes': {'key': 'destinationAddressPrefixes', 'type': '[str]'}, + 'expanded_source_address_prefix': {'key': 'expandedSourceAddressPrefix', 'type': '[str]'}, + 'expanded_destination_address_prefix': {'key': 'expandedDestinationAddressPrefix', 'type': '[str]'}, + 'access': {'key': 'access', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'direction': {'key': 'direction', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + protocol: Optional[Union[str, "EffectiveSecurityRuleProtocol"]] = None, + source_port_range: Optional[str] = None, + destination_port_range: Optional[str] = None, + source_port_ranges: Optional[List[str]] = None, + destination_port_ranges: Optional[List[str]] = None, + source_address_prefix: Optional[str] = None, + destination_address_prefix: Optional[str] = None, + source_address_prefixes: Optional[List[str]] = None, + destination_address_prefixes: Optional[List[str]] = None, + expanded_source_address_prefix: Optional[List[str]] = None, + expanded_destination_address_prefix: Optional[List[str]] = None, + access: Optional[Union[str, "SecurityRuleAccess"]] = None, + priority: Optional[int] = None, + direction: Optional[Union[str, "SecurityRuleDirection"]] = None, + **kwargs + ): + super(EffectiveNetworkSecurityRule, self).__init__(**kwargs) + self.name = name + self.protocol = protocol + self.source_port_range = source_port_range + self.destination_port_range = destination_port_range + self.source_port_ranges = source_port_ranges + self.destination_port_ranges = destination_port_ranges + self.source_address_prefix = source_address_prefix + self.destination_address_prefix = destination_address_prefix + self.source_address_prefixes = source_address_prefixes + self.destination_address_prefixes = destination_address_prefixes + self.expanded_source_address_prefix = expanded_source_address_prefix + self.expanded_destination_address_prefix = expanded_destination_address_prefix + self.access = access + self.priority = priority + self.direction = direction + + +class EffectiveRoute(msrest.serialization.Model): + """Effective Route. + + :param name: The name of the user defined route. This is optional. + :type name: str + :param disable_bgp_route_propagation: If true, on-premises routes are not propagated to the + network interfaces in the subnet. + :type disable_bgp_route_propagation: bool + :param source: Who created the route. Possible values include: "Unknown", "User", + "VirtualNetworkGateway", "Default". + :type source: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveRouteSource + :param state: The value of effective route. Possible values include: "Active", "Invalid". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.EffectiveRouteState + :param address_prefix: The address prefixes of the effective routes in CIDR notation. + :type address_prefix: list[str] + :param next_hop_ip_address: The IP address of the next hop of the effective route. + :type next_hop_ip_address: list[str] + :param next_hop_type: The type of Azure hop the packet should be sent to. Possible values + include: "VirtualNetworkGateway", "VnetLocal", "Internet", "VirtualAppliance", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteNextHopType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'disable_bgp_route_propagation': {'key': 'disableBgpRoutePropagation', 'type': 'bool'}, + 'source': {'key': 'source', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + 'address_prefix': {'key': 'addressPrefix', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + disable_bgp_route_propagation: Optional[bool] = None, + source: Optional[Union[str, "EffectiveRouteSource"]] = None, + state: Optional[Union[str, "EffectiveRouteState"]] = None, + address_prefix: Optional[List[str]] = None, + next_hop_ip_address: Optional[List[str]] = None, + next_hop_type: Optional[Union[str, "RouteNextHopType"]] = None, + **kwargs + ): + super(EffectiveRoute, self).__init__(**kwargs) + self.name = name + self.disable_bgp_route_propagation = disable_bgp_route_propagation + self.source = source + self.state = state + self.address_prefix = address_prefix + self.next_hop_ip_address = next_hop_ip_address + self.next_hop_type = next_hop_type + + +class EffectiveRouteListResult(msrest.serialization.Model): + """Response for list effective route API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of effective routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EffectiveRoute] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EffectiveRoute]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["EffectiveRoute"]] = None, + **kwargs + ): + super(EffectiveRouteListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class EffectiveRoutesParameters(msrest.serialization.Model): + """The parameters specifying the resource whose effective routes are being requested. + + :param resource_id: The resource whose effective routes are being requested. + :type resource_id: str + :param virtual_wan_resource_type: The type of the specified resource like RouteTable, + ExpressRouteConnection, HubVirtualNetworkConnection, VpnConnection and P2SConnection. + :type virtual_wan_resource_type: str + """ + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'virtual_wan_resource_type': {'key': 'virtualWanResourceType', 'type': 'str'}, + } + + def __init__( + self, + *, + resource_id: Optional[str] = None, + virtual_wan_resource_type: Optional[str] = None, + **kwargs + ): + super(EffectiveRoutesParameters, self).__init__(**kwargs) + self.resource_id = resource_id + self.virtual_wan_resource_type = virtual_wan_resource_type + + +class EndpointServiceResult(SubResource): + """Endpoint service. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: Name of the endpoint service. + :vartype name: str + :ivar type: Type of the endpoint service. + :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(EndpointServiceResult, self).__init__(id=id, **kwargs) + self.name = None + self.type = None + + +class EndpointServicesListResult(msrest.serialization.Model): + """Response for the ListAvailableEndpointServices API service call. + + :param value: List of available endpoint services in a region. + :type value: list[~azure.mgmt.network.v2020_08_01.models.EndpointServiceResult] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[EndpointServiceResult]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["EndpointServiceResult"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(EndpointServicesListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class Error(msrest.serialization.Model): + """Common error representation. + + :param code: Error code. + :type code: str + :param message: Error message. + :type message: str + :param target: Error target. + :type target: str + :param details: Error details. + :type details: list[~azure.mgmt.network.v2020_08_01.models.ErrorDetails] + :param inner_error: Inner error message. + :type inner_error: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorDetails]'}, + 'inner_error': {'key': 'innerError', 'type': 'str'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + target: Optional[str] = None, + details: Optional[List["ErrorDetails"]] = None, + inner_error: Optional[str] = None, + **kwargs + ): + super(Error, self).__init__(**kwargs) + self.code = code + self.message = message + self.target = target + self.details = details + self.inner_error = inner_error + + +class ErrorDetails(msrest.serialization.Model): + """Common error details representation. + + :param code: Error code. + :type code: str + :param target: Error target. + :type target: str + :param message: Error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + target: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ErrorDetails, self).__init__(**kwargs) + self.code = code + self.target = target + self.message = message + + +class ErrorResponse(msrest.serialization.Model): + """The error object. + + :param error: The error details object. + :type error: ~azure.mgmt.network.v2020_08_01.models.ErrorDetails + """ + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorDetails'}, + } + + def __init__( + self, + *, + error: Optional["ErrorDetails"] = None, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.error = error + + +class EvaluatedNetworkSecurityGroup(msrest.serialization.Model): + """Results of network security group evaluation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param network_security_group_id: Network security group ID. + :type network_security_group_id: str + :param applied_to: Resource ID of nic or subnet to which network security group is applied. + :type applied_to: str + :param matched_rule: Matched network security rule. + :type matched_rule: ~azure.mgmt.network.v2020_08_01.models.MatchedRule + :ivar rules_evaluation_result: List of network security rules evaluation results. + :vartype rules_evaluation_result: + list[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityRulesEvaluationResult] + """ + + _validation = { + 'rules_evaluation_result': {'readonly': True}, + } + + _attribute_map = { + 'network_security_group_id': {'key': 'networkSecurityGroupId', 'type': 'str'}, + 'applied_to': {'key': 'appliedTo', 'type': 'str'}, + 'matched_rule': {'key': 'matchedRule', 'type': 'MatchedRule'}, + 'rules_evaluation_result': {'key': 'rulesEvaluationResult', 'type': '[NetworkSecurityRulesEvaluationResult]'}, + } + + def __init__( + self, + *, + network_security_group_id: Optional[str] = None, + applied_to: Optional[str] = None, + matched_rule: Optional["MatchedRule"] = None, + **kwargs + ): + super(EvaluatedNetworkSecurityGroup, self).__init__(**kwargs) + self.network_security_group_id = network_security_group_id + self.applied_to = applied_to + self.matched_rule = matched_rule + self.rules_evaluation_result = None + + +class ExpressRouteCircuit(Resource): + """ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 sku: The SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param allow_classic_operations: Allow classic operations. + :type allow_classic_operations: bool + :param circuit_provisioning_state: The CircuitProvisioningState state of the resource. + :type circuit_provisioning_state: str + :param service_provider_provisioning_state: The ServiceProviderProvisioningState state of the + resource. Possible values include: "NotProvisioned", "Provisioning", "Provisioned", + "Deprovisioning". + :type service_provider_provisioning_state: str or + ~azure.mgmt.network.v2020_08_01.models.ServiceProviderProvisioningState + :param authorizations: The list of authorizations. + :type authorizations: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :param peerings: The list of peerings. + :type peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :param service_key: The ServiceKey. + :type service_key: str + :param service_provider_notes: The ServiceProviderNotes. + :type service_provider_notes: str + :param service_provider_properties: The ServiceProviderProperties. + :type service_provider_properties: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitServiceProviderProperties + :param express_route_port: The reference to the ExpressRoutePort resource when the circuit is + provisioned on an ExpressRoutePort resource. + :type express_route_port: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param bandwidth_in_gbps: The bandwidth of the circuit when the circuit is provisioned on an + ExpressRoutePort resource. + :type bandwidth_in_gbps: float + :ivar stag: The identifier of the circuit traffic. Outer tag for QinQ encapsulation. + :vartype stag: int + :ivar provisioning_state: The provisioning state of the express route circuit resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :param global_reach_enabled: Flag denoting global reach status. + :type global_reach_enabled: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'stag': {'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}'}, + 'sku': {'key': 'sku', 'type': 'ExpressRouteCircuitSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'allow_classic_operations': {'key': 'properties.allowClassicOperations', 'type': 'bool'}, + 'circuit_provisioning_state': {'key': 'properties.circuitProvisioningState', 'type': 'str'}, + 'service_provider_provisioning_state': {'key': 'properties.serviceProviderProvisioningState', 'type': 'str'}, + 'authorizations': {'key': 'properties.authorizations', 'type': '[ExpressRouteCircuitAuthorization]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'service_key': {'key': 'properties.serviceKey', 'type': 'str'}, + 'service_provider_notes': {'key': 'properties.serviceProviderNotes', 'type': 'str'}, + 'service_provider_properties': {'key': 'properties.serviceProviderProperties', 'type': 'ExpressRouteCircuitServiceProviderProperties'}, + 'express_route_port': {'key': 'properties.expressRoutePort', 'type': 'SubResource'}, + 'bandwidth_in_gbps': {'key': 'properties.bandwidthInGbps', 'type': 'float'}, + 'stag': {'key': 'properties.stag', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'global_reach_enabled': {'key': 'properties.globalReachEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["ExpressRouteCircuitSku"] = None, + allow_classic_operations: Optional[bool] = None, + circuit_provisioning_state: Optional[str] = None, + service_provider_provisioning_state: Optional[Union[str, "ServiceProviderProvisioningState"]] = None, + authorizations: Optional[List["ExpressRouteCircuitAuthorization"]] = None, + peerings: Optional[List["ExpressRouteCircuitPeering"]] = None, + service_key: Optional[str] = None, + service_provider_notes: Optional[str] = None, + service_provider_properties: Optional["ExpressRouteCircuitServiceProviderProperties"] = None, + express_route_port: Optional["SubResource"] = None, + bandwidth_in_gbps: Optional[float] = None, + gateway_manager_etag: Optional[str] = None, + global_reach_enabled: Optional[bool] = None, + **kwargs + ): + super(ExpressRouteCircuit, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.sku = sku + self.etag = None + self.allow_classic_operations = allow_classic_operations + self.circuit_provisioning_state = circuit_provisioning_state + self.service_provider_provisioning_state = service_provider_provisioning_state + self.authorizations = authorizations + self.peerings = peerings + self.service_key = service_key + self.service_provider_notes = service_provider_notes + self.service_provider_properties = service_provider_properties + self.express_route_port = express_route_port + self.bandwidth_in_gbps = bandwidth_in_gbps + self.stag = None + self.provisioning_state = None + self.gateway_manager_etag = gateway_manager_etag + self.global_reach_enabled = global_reach_enabled + + +class ExpressRouteCircuitArpTable(msrest.serialization.Model): + """The ARP table associated with the ExpressRouteCircuit. + + :param age: Entry age in minutes. + :type age: int + :param interface: Interface address. + :type interface: str + :param ip_address: The IP address. + :type ip_address: str + :param mac_address: The MAC address. + :type mac_address: str + """ + + _attribute_map = { + 'age': {'key': 'age', 'type': 'int'}, + 'interface': {'key': 'interface', 'type': 'str'}, + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'mac_address': {'key': 'macAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + age: Optional[int] = None, + interface: Optional[str] = None, + ip_address: Optional[str] = None, + mac_address: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitArpTable, self).__init__(**kwargs) + self.age = age + self.interface = interface + self.ip_address = ip_address + self.mac_address = mac_address + + +class ExpressRouteCircuitAuthorization(SubResource): + """Authorization in an ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param authorization_key: The authorization key. + :type authorization_key: str + :param authorization_use_status: The authorization use status. Possible values include: + "Available", "InUse". + :type authorization_use_status: str or + ~azure.mgmt.network.v2020_08_01.models.AuthorizationUseStatus + :ivar provisioning_state: The provisioning state of the authorization resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'authorization_use_status': {'key': 'properties.authorizationUseStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + authorization_key: Optional[str] = None, + authorization_use_status: Optional[Union[str, "AuthorizationUseStatus"]] = None, + **kwargs + ): + super(ExpressRouteCircuitAuthorization, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.authorization_key = authorization_key + self.authorization_use_status = authorization_use_status + self.provisioning_state = None + + +class ExpressRouteCircuitConnection(SubResource): + """Express Route Circuit Connection in an ExpressRouteCircuitPeering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the circuit initiating connection. + :type express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param peer_express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the peered circuit. + :type peer_express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: /29 IP address space to carve out Customer addresses for tunnels. + :type address_prefix: str + :param authorization_key: The authorization key. + :type authorization_key: str + :param ipv6_circuit_connection_config: IPv6 Address PrefixProperties of the express route + circuit connection. + :type ipv6_circuit_connection_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6CircuitConnectionConfig + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + :ivar provisioning_state: The provisioning state of the express route circuit connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'circuit_connection_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'SubResource'}, + 'peer_express_route_circuit_peering': {'key': 'properties.peerExpressRouteCircuitPeering', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'ipv6_circuit_connection_config': {'key': 'properties.ipv6CircuitConnectionConfig', 'type': 'Ipv6CircuitConnectionConfig'}, + 'circuit_connection_status': {'key': 'properties.circuitConnectionStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + express_route_circuit_peering: Optional["SubResource"] = None, + peer_express_route_circuit_peering: Optional["SubResource"] = None, + address_prefix: Optional[str] = None, + authorization_key: Optional[str] = None, + ipv6_circuit_connection_config: Optional["Ipv6CircuitConnectionConfig"] = None, + **kwargs + ): + super(ExpressRouteCircuitConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.express_route_circuit_peering = express_route_circuit_peering + self.peer_express_route_circuit_peering = peer_express_route_circuit_peering + self.address_prefix = address_prefix + self.authorization_key = authorization_key + self.ipv6_circuit_connection_config = ipv6_circuit_connection_config + self.circuit_connection_status = None + self.provisioning_state = None + + +class ExpressRouteCircuitConnectionListResult(msrest.serialization.Model): + """Response for ListConnections API service call retrieves all global reach connections that belongs to a Private Peering for an ExpressRouteCircuit. + + :param value: The global reach connection associated with Private Peering in an ExpressRoute + Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitListResult(msrest.serialization.Model): + """Response for ListExpressRouteCircuit API service call. + + :param value: A list of ExpressRouteCircuits in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuit]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuit"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitPeering(SubResource): + """Peering in an ExpressRouteCircuit resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param peering_type: The peering type. Possible values include: "AzurePublicPeering", + "AzurePrivatePeering", "MicrosoftPeering". + :type peering_type: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringType + :param state: The peering state. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringState + :param azure_asn: The Azure ASN. + :type azure_asn: int + :param peer_asn: The peer ASN. + :type peer_asn: long + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :param primary_azure_port: The primary port. + :type primary_azure_port: str + :param secondary_azure_port: The secondary port. + :type secondary_azure_port: str + :param shared_key: The shared key. + :type shared_key: str + :param vlan_id: The VLAN ID. + :type vlan_id: int + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :param stats: The peering stats of express route circuit. + :type stats: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :ivar provisioning_state: The provisioning state of the express route circuit peering resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :ivar last_modified_by: Who was the last to modify the peering. + :vartype last_modified_by: str + :param route_filter: The reference to the RouteFilter resource. + :type route_filter: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ipv6_peering_config: The IPv6 peering configuration. + :type ipv6_peering_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6ExpressRouteCircuitPeeringConfig + :param express_route_connection: The ExpressRoute connection. + :type express_route_connection: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnectionId + :param connections: The list of circuit connections associated with Azure Private Peering for + this circuit. + :type connections: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :ivar peered_connections: The list of peered circuit connections associated with Azure Private + Peering for this circuit. + :vartype peered_connections: + list[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'last_modified_by': {'readonly': True}, + 'peered_connections': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peering_type': {'key': 'properties.peeringType', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'azure_asn': {'key': 'properties.azureASN', 'type': 'int'}, + 'peer_asn': {'key': 'properties.peerASN', 'type': 'long'}, + 'primary_peer_address_prefix': {'key': 'properties.primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'properties.secondaryPeerAddressPrefix', 'type': 'str'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'vlan_id': {'key': 'properties.vlanId', 'type': 'int'}, + 'microsoft_peering_config': {'key': 'properties.microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'stats': {'key': 'properties.stats', 'type': 'ExpressRouteCircuitStats'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'last_modified_by': {'key': 'properties.lastModifiedBy', 'type': 'str'}, + 'route_filter': {'key': 'properties.routeFilter', 'type': 'SubResource'}, + 'ipv6_peering_config': {'key': 'properties.ipv6PeeringConfig', 'type': 'Ipv6ExpressRouteCircuitPeeringConfig'}, + 'express_route_connection': {'key': 'properties.expressRouteConnection', 'type': 'ExpressRouteConnectionId'}, + 'connections': {'key': 'properties.connections', 'type': '[ExpressRouteCircuitConnection]'}, + 'peered_connections': {'key': 'properties.peeredConnections', 'type': '[PeerExpressRouteCircuitConnection]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + peering_type: Optional[Union[str, "ExpressRoutePeeringType"]] = None, + state: Optional[Union[str, "ExpressRoutePeeringState"]] = None, + azure_asn: Optional[int] = None, + peer_asn: Optional[int] = None, + primary_peer_address_prefix: Optional[str] = None, + secondary_peer_address_prefix: Optional[str] = None, + primary_azure_port: Optional[str] = None, + secondary_azure_port: Optional[str] = None, + shared_key: Optional[str] = None, + vlan_id: Optional[int] = None, + microsoft_peering_config: Optional["ExpressRouteCircuitPeeringConfig"] = None, + stats: Optional["ExpressRouteCircuitStats"] = None, + gateway_manager_etag: Optional[str] = None, + route_filter: Optional["SubResource"] = None, + ipv6_peering_config: Optional["Ipv6ExpressRouteCircuitPeeringConfig"] = None, + express_route_connection: Optional["ExpressRouteConnectionId"] = None, + connections: Optional[List["ExpressRouteCircuitConnection"]] = None, + **kwargs + ): + super(ExpressRouteCircuitPeering, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.peering_type = peering_type + self.state = state + self.azure_asn = azure_asn + self.peer_asn = peer_asn + self.primary_peer_address_prefix = primary_peer_address_prefix + self.secondary_peer_address_prefix = secondary_peer_address_prefix + self.primary_azure_port = primary_azure_port + self.secondary_azure_port = secondary_azure_port + self.shared_key = shared_key + self.vlan_id = vlan_id + self.microsoft_peering_config = microsoft_peering_config + self.stats = stats + self.provisioning_state = None + self.gateway_manager_etag = gateway_manager_etag + self.last_modified_by = None + self.route_filter = route_filter + self.ipv6_peering_config = ipv6_peering_config + self.express_route_connection = express_route_connection + self.connections = connections + self.peered_connections = None + + +class ExpressRouteCircuitPeeringConfig(msrest.serialization.Model): + """Specifies the peering configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param advertised_public_prefixes: The reference to AdvertisedPublicPrefixes. + :type advertised_public_prefixes: list[str] + :param advertised_communities: The communities of bgp peering. Specified for microsoft peering. + :type advertised_communities: list[str] + :ivar advertised_public_prefixes_state: The advertised public prefix state of the Peering + resource. Possible values include: "NotConfigured", "Configuring", "Configured", + "ValidationNeeded". + :vartype advertised_public_prefixes_state: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringAdvertisedPublicPrefixState + :param legacy_mode: The legacy mode of the peering. + :type legacy_mode: int + :param customer_asn: The CustomerASN of the peering. + :type customer_asn: int + :param routing_registry_name: The RoutingRegistryName of the configuration. + :type routing_registry_name: str + """ + + _validation = { + 'advertised_public_prefixes_state': {'readonly': True}, + } + + _attribute_map = { + 'advertised_public_prefixes': {'key': 'advertisedPublicPrefixes', 'type': '[str]'}, + 'advertised_communities': {'key': 'advertisedCommunities', 'type': '[str]'}, + 'advertised_public_prefixes_state': {'key': 'advertisedPublicPrefixesState', 'type': 'str'}, + 'legacy_mode': {'key': 'legacyMode', 'type': 'int'}, + 'customer_asn': {'key': 'customerASN', 'type': 'int'}, + 'routing_registry_name': {'key': 'routingRegistryName', 'type': 'str'}, + } + + def __init__( + self, + *, + advertised_public_prefixes: Optional[List[str]] = None, + advertised_communities: Optional[List[str]] = None, + legacy_mode: Optional[int] = None, + customer_asn: Optional[int] = None, + routing_registry_name: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitPeeringConfig, self).__init__(**kwargs) + self.advertised_public_prefixes = advertised_public_prefixes + self.advertised_communities = advertised_communities + self.advertised_public_prefixes_state = None + self.legacy_mode = legacy_mode + self.customer_asn = customer_asn + self.routing_registry_name = routing_registry_name + + +class ExpressRouteCircuitPeeringId(msrest.serialization.Model): + """ExpressRoute circuit peering identifier. + + :param id: The ID of the ExpressRoute circuit peering. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitPeeringId, self).__init__(**kwargs) + self.id = id + + +class ExpressRouteCircuitPeeringListResult(msrest.serialization.Model): + """Response for ListPeering API service call retrieves all peerings that belong to an ExpressRouteCircuit. + + :param value: The peerings in an express route circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitPeering"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitPeeringListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitReference(msrest.serialization.Model): + """Reference to an express route circuit. + + :param id: Corresponding Express Route Circuit Id. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitReference, self).__init__(**kwargs) + self.id = id + + +class ExpressRouteCircuitRoutesTable(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param network: IP address of a network entity. + :type network: str + :param next_hop: NextHop address. + :type next_hop: str + :param loc_prf: Local preference value as set with the set local-preference route-map + configuration command. + :type loc_prf: str + :param weight: Route Weight. + :type weight: int + :param path: Autonomous system paths to the destination network. + :type path: str + """ + + _attribute_map = { + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'loc_prf': {'key': 'locPrf', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + 'path': {'key': 'path', 'type': 'str'}, + } + + def __init__( + self, + *, + network: Optional[str] = None, + next_hop: Optional[str] = None, + loc_prf: Optional[str] = None, + weight: Optional[int] = None, + path: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitRoutesTable, self).__init__(**kwargs) + self.network = network + self.next_hop = next_hop + self.loc_prf = loc_prf + self.weight = weight + self.path = path + + +class ExpressRouteCircuitRoutesTableSummary(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param neighbor: IP address of the neighbor. + :type neighbor: str + :param v: BGP version number spoken to the neighbor. + :type v: int + :param as_property: Autonomous system number. + :type as_property: int + :param up_down: The length of time that the BGP session has been in the Established state, or + the current status if not in the Established state. + :type up_down: str + :param state_pfx_rcd: Current state of the BGP session, and the number of prefixes that have + been received from a neighbor or peer group. + :type state_pfx_rcd: str + """ + + _attribute_map = { + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'v': {'key': 'v', 'type': 'int'}, + 'as_property': {'key': 'as', 'type': 'int'}, + 'up_down': {'key': 'upDown', 'type': 'str'}, + 'state_pfx_rcd': {'key': 'statePfxRcd', 'type': 'str'}, + } + + def __init__( + self, + *, + neighbor: Optional[str] = None, + v: Optional[int] = None, + as_property: Optional[int] = None, + up_down: Optional[str] = None, + state_pfx_rcd: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitRoutesTableSummary, self).__init__(**kwargs) + self.neighbor = neighbor + self.v = v + self.as_property = as_property + self.up_down = up_down + self.state_pfx_rcd = state_pfx_rcd + + +class ExpressRouteCircuitsArpTableListResult(msrest.serialization.Model): + """Response for ListArpTable associated with the Express Route Circuits API. + + :param value: A list of the ARP tables. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitArpTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitArpTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitArpTable"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitsArpTableListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitServiceProviderProperties(msrest.serialization.Model): + """Contains ServiceProviderProperties in an ExpressRouteCircuit. + + :param service_provider_name: The serviceProviderName. + :type service_provider_name: str + :param peering_location: The peering location. + :type peering_location: str + :param bandwidth_in_mbps: The BandwidthInMbps. + :type bandwidth_in_mbps: int + """ + + _attribute_map = { + 'service_provider_name': {'key': 'serviceProviderName', 'type': 'str'}, + 'peering_location': {'key': 'peeringLocation', 'type': 'str'}, + 'bandwidth_in_mbps': {'key': 'bandwidthInMbps', 'type': 'int'}, + } + + def __init__( + self, + *, + service_provider_name: Optional[str] = None, + peering_location: Optional[str] = None, + bandwidth_in_mbps: Optional[int] = None, + **kwargs + ): + super(ExpressRouteCircuitServiceProviderProperties, self).__init__(**kwargs) + self.service_provider_name = service_provider_name + self.peering_location = peering_location + self.bandwidth_in_mbps = bandwidth_in_mbps + + +class ExpressRouteCircuitSku(msrest.serialization.Model): + """Contains SKU in an ExpressRouteCircuit. + + :param name: The name of the SKU. + :type name: str + :param tier: The tier of the SKU. Possible values include: "Standard", "Premium", "Basic", + "Local". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSkuTier + :param family: The family of the SKU. Possible values include: "UnlimitedData", "MeteredData". + :type family: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitSkuFamily + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[Union[str, "ExpressRouteCircuitSkuTier"]] = None, + family: Optional[Union[str, "ExpressRouteCircuitSkuFamily"]] = None, + **kwargs + ): + super(ExpressRouteCircuitSku, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.family = family + + +class ExpressRouteCircuitsRoutesTableListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Circuits API. + + :param value: The list of routes table. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitRoutesTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitRoutesTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitRoutesTable"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitsRoutesTableListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitsRoutesTableSummaryListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Circuits API. + + :param value: A list of the routes table. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitRoutesTableSummary] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCircuitRoutesTableSummary]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCircuitRoutesTableSummary"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCircuitsRoutesTableSummaryListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteCircuitStats(msrest.serialization.Model): + """Contains stats associated with the peering. + + :param primarybytes_in: The Primary BytesIn of the peering. + :type primarybytes_in: long + :param primarybytes_out: The primary BytesOut of the peering. + :type primarybytes_out: long + :param secondarybytes_in: The secondary BytesIn of the peering. + :type secondarybytes_in: long + :param secondarybytes_out: The secondary BytesOut of the peering. + :type secondarybytes_out: long + """ + + _attribute_map = { + 'primarybytes_in': {'key': 'primarybytesIn', 'type': 'long'}, + 'primarybytes_out': {'key': 'primarybytesOut', 'type': 'long'}, + 'secondarybytes_in': {'key': 'secondarybytesIn', 'type': 'long'}, + 'secondarybytes_out': {'key': 'secondarybytesOut', 'type': 'long'}, + } + + def __init__( + self, + *, + primarybytes_in: Optional[int] = None, + primarybytes_out: Optional[int] = None, + secondarybytes_in: Optional[int] = None, + secondarybytes_out: Optional[int] = None, + **kwargs + ): + super(ExpressRouteCircuitStats, self).__init__(**kwargs) + self.primarybytes_in = primarybytes_in + self.primarybytes_out = primarybytes_out + self.secondarybytes_in = secondarybytes_in + self.secondarybytes_out = secondarybytes_out + + +class ExpressRouteConnection(SubResource): + """ExpressRouteConnection 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 id: Resource ID. + :type id: str + :param name: Required. The name of the resource. + :type name: str + :ivar provisioning_state: The provisioning state of the express route connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_circuit_peering: The ExpressRoute circuit peering. + :type express_route_circuit_peering: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringId + :param authorization_key: Authorization key to establish the connection. + :type authorization_key: str + :param routing_weight: The routing weight associated to the connection. + :type routing_weight: int + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param express_route_gateway_bypass: Enable FastPath to vWan Firewall hub. + :type express_route_gateway_bypass: bool + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + """ + + _validation = { + 'name': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'ExpressRouteCircuitPeeringId'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + } + + def __init__( + self, + *, + name: str, + id: Optional[str] = None, + express_route_circuit_peering: Optional["ExpressRouteCircuitPeeringId"] = None, + authorization_key: Optional[str] = None, + routing_weight: Optional[int] = None, + enable_internet_security: Optional[bool] = None, + express_route_gateway_bypass: Optional[bool] = None, + routing_configuration: Optional["RoutingConfiguration"] = None, + **kwargs + ): + super(ExpressRouteConnection, self).__init__(id=id, **kwargs) + self.name = name + self.provisioning_state = None + self.express_route_circuit_peering = express_route_circuit_peering + self.authorization_key = authorization_key + self.routing_weight = routing_weight + self.enable_internet_security = enable_internet_security + self.express_route_gateway_bypass = express_route_gateway_bypass + self.routing_configuration = routing_configuration + + +class ExpressRouteConnectionId(msrest.serialization.Model): + """The ID of the ExpressRouteConnection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the ExpressRouteConnection. + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRouteConnectionId, self).__init__(**kwargs) + self.id = None + + +class ExpressRouteConnectionList(msrest.serialization.Model): + """ExpressRouteConnection list. + + :param value: The list of ExpressRoute connections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteConnection]'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteConnection"]] = None, + **kwargs + ): + super(ExpressRouteConnectionList, self).__init__(**kwargs) + self.value = value + + +class ExpressRouteCrossConnection(Resource): + """ExpressRouteCrossConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar primary_azure_port: The name of the primary port. + :vartype primary_azure_port: str + :ivar secondary_azure_port: The name of the secondary port. + :vartype secondary_azure_port: str + :ivar s_tag: The identifier of the circuit traffic. + :vartype s_tag: int + :ivar peering_location: The peering location of the ExpressRoute circuit. + :vartype peering_location: str + :ivar bandwidth_in_mbps: The circuit bandwidth In Mbps. + :vartype bandwidth_in_mbps: int + :param express_route_circuit: The ExpressRouteCircuit. + :type express_route_circuit: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitReference + :param service_provider_provisioning_state: The provisioning state of the circuit in the + connectivity provider system. Possible values include: "NotProvisioned", "Provisioning", + "Provisioned", "Deprovisioning". + :type service_provider_provisioning_state: str or + ~azure.mgmt.network.v2020_08_01.models.ServiceProviderProvisioningState + :param service_provider_notes: Additional read only notes set by the connectivity provider. + :type service_provider_notes: str + :ivar provisioning_state: The provisioning state of the express route cross connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param peerings: The list of peerings. + :type peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'primary_azure_port': {'readonly': True}, + 'secondary_azure_port': {'readonly': True}, + 's_tag': {'readonly': True}, + 'peering_location': {'readonly': True}, + 'bandwidth_in_mbps': {'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'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 's_tag': {'key': 'properties.sTag', 'type': 'int'}, + 'peering_location': {'key': 'properties.peeringLocation', 'type': 'str'}, + 'bandwidth_in_mbps': {'key': 'properties.bandwidthInMbps', 'type': 'int'}, + 'express_route_circuit': {'key': 'properties.expressRouteCircuit', 'type': 'ExpressRouteCircuitReference'}, + 'service_provider_provisioning_state': {'key': 'properties.serviceProviderProvisioningState', 'type': 'str'}, + 'service_provider_notes': {'key': 'properties.serviceProviderNotes', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCrossConnectionPeering]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + express_route_circuit: Optional["ExpressRouteCircuitReference"] = None, + service_provider_provisioning_state: Optional[Union[str, "ServiceProviderProvisioningState"]] = None, + service_provider_notes: Optional[str] = None, + peerings: Optional[List["ExpressRouteCrossConnectionPeering"]] = None, + **kwargs + ): + super(ExpressRouteCrossConnection, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.primary_azure_port = None + self.secondary_azure_port = None + self.s_tag = None + self.peering_location = None + self.bandwidth_in_mbps = None + self.express_route_circuit = express_route_circuit + self.service_provider_provisioning_state = service_provider_provisioning_state + self.service_provider_notes = service_provider_notes + self.provisioning_state = None + self.peerings = peerings + + +class ExpressRouteCrossConnectionListResult(msrest.serialization.Model): + """Response for ListExpressRouteCrossConnection API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ExpressRouteCrossConnection resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCrossConnection"]] = None, + **kwargs + ): + super(ExpressRouteCrossConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ExpressRouteCrossConnectionPeering(SubResource): + """Peering in an ExpressRoute Cross Connection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param peering_type: The peering type. Possible values include: "AzurePublicPeering", + "AzurePrivatePeering", "MicrosoftPeering". + :type peering_type: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringType + :param state: The peering state. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePeeringState + :ivar azure_asn: The Azure ASN. + :vartype azure_asn: int + :param peer_asn: The peer ASN. + :type peer_asn: long + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :ivar primary_azure_port: The primary port. + :vartype primary_azure_port: str + :ivar secondary_azure_port: The secondary port. + :vartype secondary_azure_port: str + :param shared_key: The shared key. + :type shared_key: str + :param vlan_id: The VLAN ID. + :type vlan_id: int + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :ivar provisioning_state: The provisioning state of the express route cross connection peering + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param gateway_manager_etag: The GatewayManager Etag. + :type gateway_manager_etag: str + :ivar last_modified_by: Who was the last to modify the peering. + :vartype last_modified_by: str + :param ipv6_peering_config: The IPv6 peering configuration. + :type ipv6_peering_config: + ~azure.mgmt.network.v2020_08_01.models.Ipv6ExpressRouteCircuitPeeringConfig + """ + + _validation = { + 'etag': {'readonly': True}, + 'azure_asn': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 1}, + 'primary_azure_port': {'readonly': True}, + 'secondary_azure_port': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'last_modified_by': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'peering_type': {'key': 'properties.peeringType', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'azure_asn': {'key': 'properties.azureASN', 'type': 'int'}, + 'peer_asn': {'key': 'properties.peerASN', 'type': 'long'}, + 'primary_peer_address_prefix': {'key': 'properties.primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'properties.secondaryPeerAddressPrefix', 'type': 'str'}, + 'primary_azure_port': {'key': 'properties.primaryAzurePort', 'type': 'str'}, + 'secondary_azure_port': {'key': 'properties.secondaryAzurePort', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'vlan_id': {'key': 'properties.vlanId', 'type': 'int'}, + 'microsoft_peering_config': {'key': 'properties.microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'gateway_manager_etag': {'key': 'properties.gatewayManagerEtag', 'type': 'str'}, + 'last_modified_by': {'key': 'properties.lastModifiedBy', 'type': 'str'}, + 'ipv6_peering_config': {'key': 'properties.ipv6PeeringConfig', 'type': 'Ipv6ExpressRouteCircuitPeeringConfig'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + peering_type: Optional[Union[str, "ExpressRoutePeeringType"]] = None, + state: Optional[Union[str, "ExpressRoutePeeringState"]] = None, + peer_asn: Optional[int] = None, + primary_peer_address_prefix: Optional[str] = None, + secondary_peer_address_prefix: Optional[str] = None, + shared_key: Optional[str] = None, + vlan_id: Optional[int] = None, + microsoft_peering_config: Optional["ExpressRouteCircuitPeeringConfig"] = None, + gateway_manager_etag: Optional[str] = None, + ipv6_peering_config: Optional["Ipv6ExpressRouteCircuitPeeringConfig"] = None, + **kwargs + ): + super(ExpressRouteCrossConnectionPeering, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.peering_type = peering_type + self.state = state + self.azure_asn = None + self.peer_asn = peer_asn + self.primary_peer_address_prefix = primary_peer_address_prefix + self.secondary_peer_address_prefix = secondary_peer_address_prefix + self.primary_azure_port = None + self.secondary_azure_port = None + self.shared_key = shared_key + self.vlan_id = vlan_id + self.microsoft_peering_config = microsoft_peering_config + self.provisioning_state = None + self.gateway_manager_etag = gateway_manager_etag + self.last_modified_by = None + self.ipv6_peering_config = ipv6_peering_config + + +class ExpressRouteCrossConnectionPeeringList(msrest.serialization.Model): + """Response for ListPeering API service call retrieves all peerings that belong to an ExpressRouteCrossConnection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The peerings in an express route cross connection. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnectionPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCrossConnectionPeering"]] = None, + **kwargs + ): + super(ExpressRouteCrossConnectionPeeringList, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ExpressRouteCrossConnectionRoutesTableSummary(msrest.serialization.Model): + """The routes table associated with the ExpressRouteCircuit. + + :param neighbor: IP address of Neighbor router. + :type neighbor: str + :param asn: Autonomous system number. + :type asn: int + :param up_down: The length of time that the BGP session has been in the Established state, or + the current status if not in the Established state. + :type up_down: str + :param state_or_prefixes_received: Current state of the BGP session, and the number of prefixes + that have been received from a neighbor or peer group. + :type state_or_prefixes_received: str + """ + + _attribute_map = { + 'neighbor': {'key': 'neighbor', 'type': 'str'}, + 'asn': {'key': 'asn', 'type': 'int'}, + 'up_down': {'key': 'upDown', 'type': 'str'}, + 'state_or_prefixes_received': {'key': 'stateOrPrefixesReceived', 'type': 'str'}, + } + + def __init__( + self, + *, + neighbor: Optional[str] = None, + asn: Optional[int] = None, + up_down: Optional[str] = None, + state_or_prefixes_received: Optional[str] = None, + **kwargs + ): + super(ExpressRouteCrossConnectionRoutesTableSummary, self).__init__(**kwargs) + self.neighbor = neighbor + self.asn = asn + self.up_down = up_down + self.state_or_prefixes_received = state_or_prefixes_received + + +class ExpressRouteCrossConnectionsRoutesTableSummaryListResult(msrest.serialization.Model): + """Response for ListRoutesTable associated with the Express Route Cross Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of the routes table. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionRoutesTableSummary] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteCrossConnectionRoutesTableSummary]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteCrossConnectionRoutesTableSummary"]] = None, + **kwargs + ): + super(ExpressRouteCrossConnectionsRoutesTableSummaryListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ExpressRouteGateway(Resource): + """ExpressRoute gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param auto_scale_configuration: Configuration for auto scaling. + :type auto_scale_configuration: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayPropertiesAutoScaleConfiguration + :ivar express_route_connections: List of ExpressRoute connections to the ExpressRoute gateway. + :vartype express_route_connections: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + :ivar provisioning_state: The provisioning state of the express route gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param virtual_hub: The Virtual Hub where the ExpressRoute gateway is or will be deployed. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.VirtualHubId + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'express_route_connections': {'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'}, + 'auto_scale_configuration': {'key': 'properties.autoScaleConfiguration', 'type': 'ExpressRouteGatewayPropertiesAutoScaleConfiguration'}, + 'express_route_connections': {'key': 'properties.expressRouteConnections', 'type': '[ExpressRouteConnection]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'VirtualHubId'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + auto_scale_configuration: Optional["ExpressRouteGatewayPropertiesAutoScaleConfiguration"] = None, + virtual_hub: Optional["VirtualHubId"] = None, + **kwargs + ): + super(ExpressRouteGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.auto_scale_configuration = auto_scale_configuration + self.express_route_connections = None + self.provisioning_state = None + self.virtual_hub = virtual_hub + + +class ExpressRouteGatewayList(msrest.serialization.Model): + """List of ExpressRoute gateways. + + :param value: List of ExpressRoute gateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteGateway]'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteGateway"]] = None, + **kwargs + ): + super(ExpressRouteGatewayList, self).__init__(**kwargs) + self.value = value + + +class ExpressRouteGatewayPropertiesAutoScaleConfiguration(msrest.serialization.Model): + """Configuration for auto scaling. + + :param bounds: Minimum and maximum number of scale units to deploy. + :type bounds: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds + """ + + _attribute_map = { + 'bounds': {'key': 'bounds', 'type': 'ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds'}, + } + + def __init__( + self, + *, + bounds: Optional["ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds"] = None, + **kwargs + ): + super(ExpressRouteGatewayPropertiesAutoScaleConfiguration, self).__init__(**kwargs) + self.bounds = bounds + + +class ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds(msrest.serialization.Model): + """Minimum and maximum number of scale units to deploy. + + :param min: Minimum number of scale units deployed for ExpressRoute gateway. + :type min: int + :param max: Maximum number of scale units deployed for ExpressRoute gateway. + :type max: int + """ + + _attribute_map = { + 'min': {'key': 'min', 'type': 'int'}, + 'max': {'key': 'max', 'type': 'int'}, + } + + def __init__( + self, + *, + min: Optional[int] = None, + max: Optional[int] = None, + **kwargs + ): + super(ExpressRouteGatewayPropertiesAutoScaleConfigurationBounds, self).__init__(**kwargs) + self.min = min + self.max = max + + +class ExpressRouteLink(SubResource): + """ExpressRouteLink child resource definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of child port resource that is unique among child port resources of the + parent. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar router_name: Name of Azure router associated with physical port. + :vartype router_name: str + :ivar interface_name: Name of Azure router interface. + :vartype interface_name: str + :ivar patch_panel_id: Mapping between physical port to patch panel port. + :vartype patch_panel_id: str + :ivar rack_id: Mapping of physical patch panel to rack. + :vartype rack_id: str + :ivar connector_type: Physical fiber port type. Possible values include: "LC", "SC". + :vartype connector_type: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkConnectorType + :param admin_state: Administrative state of the physical port. Possible values include: + "Enabled", "Disabled". + :type admin_state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkAdminState + :ivar provisioning_state: The provisioning state of the express route link resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param mac_sec_config: MacSec configuration. + :type mac_sec_config: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecConfig + """ + + _validation = { + 'etag': {'readonly': True}, + 'router_name': {'readonly': True}, + 'interface_name': {'readonly': True}, + 'patch_panel_id': {'readonly': True}, + 'rack_id': {'readonly': True}, + 'connector_type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'router_name': {'key': 'properties.routerName', 'type': 'str'}, + 'interface_name': {'key': 'properties.interfaceName', 'type': 'str'}, + 'patch_panel_id': {'key': 'properties.patchPanelId', 'type': 'str'}, + 'rack_id': {'key': 'properties.rackId', 'type': 'str'}, + 'connector_type': {'key': 'properties.connectorType', 'type': 'str'}, + 'admin_state': {'key': 'properties.adminState', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'mac_sec_config': {'key': 'properties.macSecConfig', 'type': 'ExpressRouteLinkMacSecConfig'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + admin_state: Optional[Union[str, "ExpressRouteLinkAdminState"]] = None, + mac_sec_config: Optional["ExpressRouteLinkMacSecConfig"] = None, + **kwargs + ): + super(ExpressRouteLink, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.router_name = None + self.interface_name = None + self.patch_panel_id = None + self.rack_id = None + self.connector_type = None + self.admin_state = admin_state + self.provisioning_state = None + self.mac_sec_config = mac_sec_config + + +class ExpressRouteLinkListResult(msrest.serialization.Model): + """Response for ListExpressRouteLinks API service call. + + :param value: The list of ExpressRouteLink sub-resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteLink"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteLinkListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteLinkMacSecConfig(msrest.serialization.Model): + """ExpressRouteLink Mac Security Configuration. + + :param ckn_secret_identifier: Keyvault Secret Identifier URL containing Mac security CKN key. + :type ckn_secret_identifier: str + :param cak_secret_identifier: Keyvault Secret Identifier URL containing Mac security CAK key. + :type cak_secret_identifier: str + :param cipher: Mac security cipher. Possible values include: "GcmAes256", "GcmAes128", + "GcmAesXpn128", "GcmAesXpn256". + :type cipher: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecCipher + :param sci_state: Sci mode enabled/disabled. Possible values include: "Disabled", "Enabled". + :type sci_state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkMacSecSciState + """ + + _attribute_map = { + 'ckn_secret_identifier': {'key': 'cknSecretIdentifier', 'type': 'str'}, + 'cak_secret_identifier': {'key': 'cakSecretIdentifier', 'type': 'str'}, + 'cipher': {'key': 'cipher', 'type': 'str'}, + 'sci_state': {'key': 'sciState', 'type': 'str'}, + } + + def __init__( + self, + *, + ckn_secret_identifier: Optional[str] = None, + cak_secret_identifier: Optional[str] = None, + cipher: Optional[Union[str, "ExpressRouteLinkMacSecCipher"]] = None, + sci_state: Optional[Union[str, "ExpressRouteLinkMacSecSciState"]] = None, + **kwargs + ): + super(ExpressRouteLinkMacSecConfig, self).__init__(**kwargs) + self.ckn_secret_identifier = ckn_secret_identifier + self.cak_secret_identifier = cak_secret_identifier + self.cipher = cipher + self.sci_state = sci_state + + +class ExpressRoutePort(Resource): + """ExpressRoutePort resource definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param identity: The identity of ExpressRoutePort, if configured. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :param peering_location: The name of the peering location that the ExpressRoutePort is mapped + to physically. + :type peering_location: str + :param bandwidth_in_gbps: Bandwidth of procured ports in Gbps. + :type bandwidth_in_gbps: int + :ivar provisioned_bandwidth_in_gbps: Aggregate Gbps of associated circuit bandwidths. + :vartype provisioned_bandwidth_in_gbps: float + :ivar mtu: Maximum transmission unit of the physical port pair(s). + :vartype mtu: str + :param encapsulation: Encapsulation method on physical ports. Possible values include: "Dot1Q", + "QinQ". + :type encapsulation: str or + ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsEncapsulation + :ivar ether_type: Ether type of the physical port. + :vartype ether_type: str + :ivar allocation_date: Date of the physical port allocation to be used in Letter of + Authorization. + :vartype allocation_date: str + :param links: The set of physical links of the ExpressRoutePort resource. + :type links: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink] + :ivar circuits: Reference the ExpressRoute circuit(s) that are provisioned on this + ExpressRoutePort resource. + :vartype circuits: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the express route port resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_guid: The resource GUID property of the express route port resource. + :vartype resource_guid: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioned_bandwidth_in_gbps': {'readonly': True}, + 'mtu': {'readonly': True}, + 'ether_type': {'readonly': True}, + 'allocation_date': {'readonly': True}, + 'circuits': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_guid': {'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'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'peering_location': {'key': 'properties.peeringLocation', 'type': 'str'}, + 'bandwidth_in_gbps': {'key': 'properties.bandwidthInGbps', 'type': 'int'}, + 'provisioned_bandwidth_in_gbps': {'key': 'properties.provisionedBandwidthInGbps', 'type': 'float'}, + 'mtu': {'key': 'properties.mtu', 'type': 'str'}, + 'encapsulation': {'key': 'properties.encapsulation', 'type': 'str'}, + 'ether_type': {'key': 'properties.etherType', 'type': 'str'}, + 'allocation_date': {'key': 'properties.allocationDate', 'type': 'str'}, + 'links': {'key': 'properties.links', 'type': '[ExpressRouteLink]'}, + 'circuits': {'key': 'properties.circuits', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + peering_location: Optional[str] = None, + bandwidth_in_gbps: Optional[int] = None, + encapsulation: Optional[Union[str, "ExpressRoutePortsEncapsulation"]] = None, + links: Optional[List["ExpressRouteLink"]] = None, + **kwargs + ): + super(ExpressRoutePort, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.identity = identity + self.peering_location = peering_location + self.bandwidth_in_gbps = bandwidth_in_gbps + self.provisioned_bandwidth_in_gbps = None + self.mtu = None + self.encapsulation = encapsulation + self.ether_type = None + self.allocation_date = None + self.links = links + self.circuits = None + self.provisioning_state = None + self.resource_guid = None + + +class ExpressRoutePortListResult(msrest.serialization.Model): + """Response for ListExpressRoutePorts API service call. + + :param value: A list of ExpressRoutePort resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRoutePort]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRoutePort"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRoutePortListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRoutePortsLocation(Resource): + """Definition of the ExpressRoutePorts peering location resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar address: Address of peering location. + :vartype address: str + :ivar contact: Contact details of peering locations. + :vartype contact: str + :param available_bandwidths: The inventory of available ExpressRoutePort bandwidths. + :type available_bandwidths: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocationBandwidths] + :ivar provisioning_state: The provisioning state of the express route port location resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'address': {'readonly': True}, + 'contact': {'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}'}, + 'address': {'key': 'properties.address', 'type': 'str'}, + 'contact': {'key': 'properties.contact', 'type': 'str'}, + 'available_bandwidths': {'key': 'properties.availableBandwidths', 'type': '[ExpressRoutePortsLocationBandwidths]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + available_bandwidths: Optional[List["ExpressRoutePortsLocationBandwidths"]] = None, + **kwargs + ): + super(ExpressRoutePortsLocation, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.address = None + self.contact = None + self.available_bandwidths = available_bandwidths + self.provisioning_state = None + + +class ExpressRoutePortsLocationBandwidths(msrest.serialization.Model): + """Real-time inventory of available ExpressRoute port bandwidths. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar offer_name: Bandwidth descriptive name. + :vartype offer_name: str + :ivar value_in_gbps: Bandwidth value in Gbps. + :vartype value_in_gbps: int + """ + + _validation = { + 'offer_name': {'readonly': True}, + 'value_in_gbps': {'readonly': True}, + } + + _attribute_map = { + 'offer_name': {'key': 'offerName', 'type': 'str'}, + 'value_in_gbps': {'key': 'valueInGbps', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressRoutePortsLocationBandwidths, self).__init__(**kwargs) + self.offer_name = None + self.value_in_gbps = None + + +class ExpressRoutePortsLocationListResult(msrest.serialization.Model): + """Response for ListExpressRoutePortsLocations API service call. + + :param value: The list of all ExpressRoutePort peering locations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocation] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRoutePortsLocation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRoutePortsLocation"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRoutePortsLocationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExpressRouteServiceProvider(Resource): + """A ExpressRouteResourceProvider object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 peering_locations: A list of peering locations. + :type peering_locations: list[str] + :param bandwidths_offered: A list of bandwidths offered. + :type bandwidths_offered: + list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProviderBandwidthsOffered] + :ivar provisioning_state: The provisioning state of the express route service provider + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'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}'}, + 'peering_locations': {'key': 'properties.peeringLocations', 'type': '[str]'}, + 'bandwidths_offered': {'key': 'properties.bandwidthsOffered', 'type': '[ExpressRouteServiceProviderBandwidthsOffered]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + peering_locations: Optional[List[str]] = None, + bandwidths_offered: Optional[List["ExpressRouteServiceProviderBandwidthsOffered"]] = None, + **kwargs + ): + super(ExpressRouteServiceProvider, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.peering_locations = peering_locations + self.bandwidths_offered = bandwidths_offered + self.provisioning_state = None + + +class ExpressRouteServiceProviderBandwidthsOffered(msrest.serialization.Model): + """Contains bandwidths offered in ExpressRouteServiceProvider resources. + + :param offer_name: The OfferName. + :type offer_name: str + :param value_in_mbps: The ValueInMbps. + :type value_in_mbps: int + """ + + _attribute_map = { + 'offer_name': {'key': 'offerName', 'type': 'str'}, + 'value_in_mbps': {'key': 'valueInMbps', 'type': 'int'}, + } + + def __init__( + self, + *, + offer_name: Optional[str] = None, + value_in_mbps: Optional[int] = None, + **kwargs + ): + super(ExpressRouteServiceProviderBandwidthsOffered, self).__init__(**kwargs) + self.offer_name = offer_name + self.value_in_mbps = value_in_mbps + + +class ExpressRouteServiceProviderListResult(msrest.serialization.Model): + """Response for the ListExpressRouteServiceProvider API service call. + + :param value: A list of ExpressRouteResourceProvider resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProvider] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ExpressRouteServiceProvider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ExpressRouteServiceProvider"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ExpressRouteServiceProviderListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ExtendedLocation(msrest.serialization.Model): + """ExtendedLocation complex type. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the extended location. + :type name: str + :param type: Required. The type of the extended location. Possible values include: "EdgeZone". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ExtendedLocationTypes + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + type: Union[str, "ExtendedLocationTypes"], + **kwargs + ): + super(ExtendedLocation, self).__init__(**kwargs) + self.name = name + self.type = type + + +class FirewallPolicy(Resource): + """FirewallPolicy Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param identity: The identity of the firewall policy. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :ivar rule_collection_groups: List of references to FirewallPolicyRuleCollectionGroups. + :vartype rule_collection_groups: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the firewall policy resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param base_policy: The parent firewall policy from which rules are inherited. + :type base_policy: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar firewalls: List of references to Azure Firewalls that this Firewall Policy is associated + with. + :vartype firewalls: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar child_policies: List of references to Child Firewall Policies. + :vartype child_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param threat_intel_mode: The operation mode for Threat Intelligence. Possible values include: + "Alert", "Deny", "Off". + :type threat_intel_mode: str or + ~azure.mgmt.network.v2020_08_01.models.AzureFirewallThreatIntelMode + :param threat_intel_whitelist: ThreatIntel Whitelist for Firewall Policy. + :type threat_intel_whitelist: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyThreatIntelWhitelist + :param dns_settings: DNS Proxy Settings definition. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.DnsSettings + :param intrusion_detection: The configuration for Intrusion detection. + :type intrusion_detection: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetection + :param transport_security: TLS Configuration definition. + :type transport_security: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyTransportSecurity + :param sku: The Firewall Policy SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicySku + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'rule_collection_groups': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'firewalls': {'readonly': True}, + 'child_policies': {'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'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'rule_collection_groups': {'key': 'properties.ruleCollectionGroups', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'base_policy': {'key': 'properties.basePolicy', 'type': 'SubResource'}, + 'firewalls': {'key': 'properties.firewalls', 'type': '[SubResource]'}, + 'child_policies': {'key': 'properties.childPolicies', 'type': '[SubResource]'}, + 'threat_intel_mode': {'key': 'properties.threatIntelMode', 'type': 'str'}, + 'threat_intel_whitelist': {'key': 'properties.threatIntelWhitelist', 'type': 'FirewallPolicyThreatIntelWhitelist'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'DnsSettings'}, + 'intrusion_detection': {'key': 'properties.intrusionDetection', 'type': 'FirewallPolicyIntrusionDetection'}, + 'transport_security': {'key': 'properties.transportSecurity', 'type': 'FirewallPolicyTransportSecurity'}, + 'sku': {'key': 'properties.sku', 'type': 'FirewallPolicySku'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + base_policy: Optional["SubResource"] = None, + threat_intel_mode: Optional[Union[str, "AzureFirewallThreatIntelMode"]] = None, + threat_intel_whitelist: Optional["FirewallPolicyThreatIntelWhitelist"] = None, + dns_settings: Optional["DnsSettings"] = None, + intrusion_detection: Optional["FirewallPolicyIntrusionDetection"] = None, + transport_security: Optional["FirewallPolicyTransportSecurity"] = None, + sku: Optional["FirewallPolicySku"] = None, + **kwargs + ): + super(FirewallPolicy, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.identity = identity + self.rule_collection_groups = None + self.provisioning_state = None + self.base_policy = base_policy + self.firewalls = None + self.child_policies = None + self.threat_intel_mode = threat_intel_mode + self.threat_intel_whitelist = threat_intel_whitelist + self.dns_settings = dns_settings + self.intrusion_detection = intrusion_detection + self.transport_security = transport_security + self.sku = sku + + +class FirewallPolicyCertificateAuthority(msrest.serialization.Model): + """Trusted Root certificates properties for tls. + + :param key_vault_secret_id: Secret Id of (base-64 encoded unencrypted pfx) 'Secret' or + 'Certificate' object stored in KeyVault. + :type key_vault_secret_id: str + :param name: Name of the CA certificate. + :type name: str + """ + + _attribute_map = { + 'key_vault_secret_id': {'key': 'keyVaultSecretId', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + key_vault_secret_id: Optional[str] = None, + name: Optional[str] = None, + **kwargs + ): + super(FirewallPolicyCertificateAuthority, self).__init__(**kwargs) + self.key_vault_secret_id = key_vault_secret_id + self.name = name + + +class FirewallPolicyRuleCollection(msrest.serialization.Model): + """Properties of the rule collection. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: FirewallPolicyFilterRuleCollection, FirewallPolicyNatRuleCollection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + } + + _subtype_map = { + 'rule_collection_type': {'FirewallPolicyFilterRuleCollection': 'FirewallPolicyFilterRuleCollection', 'FirewallPolicyNatRuleCollection': 'FirewallPolicyNatRuleCollection'} + } + + def __init__( + self, + *, + name: Optional[str] = None, + priority: Optional[int] = None, + **kwargs + ): + super(FirewallPolicyRuleCollection, self).__init__(**kwargs) + self.rule_collection_type = None # type: Optional[str] + self.name = name + self.priority = priority + + +class FirewallPolicyFilterRuleCollection(FirewallPolicyRuleCollection): + """Firewall Policy Filter Rule Collection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + :param action: The action type of a Filter rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyFilterRuleCollectionAction + :param rules: List of rules included in a rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRule] + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'FirewallPolicyFilterRuleCollectionAction'}, + 'rules': {'key': 'rules', 'type': '[FirewallPolicyRule]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + priority: Optional[int] = None, + action: Optional["FirewallPolicyFilterRuleCollectionAction"] = None, + rules: Optional[List["FirewallPolicyRule"]] = None, + **kwargs + ): + super(FirewallPolicyFilterRuleCollection, self).__init__(name=name, priority=priority, **kwargs) + self.rule_collection_type = 'FirewallPolicyFilterRuleCollection' # type: str + self.action = action + self.rules = rules + + +class FirewallPolicyFilterRuleCollectionAction(msrest.serialization.Model): + """Properties of the FirewallPolicyFilterRuleCollectionAction. + + :param type: The type of action. Possible values include: "Allow", "Deny". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyFilterRuleCollectionActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "FirewallPolicyFilterRuleCollectionActionType"]] = None, + **kwargs + ): + super(FirewallPolicyFilterRuleCollectionAction, self).__init__(**kwargs) + self.type = type + + +class FirewallPolicyIntrusionDetection(msrest.serialization.Model): + """Configuration for intrusion detection mode and rules. + + :param mode: Intrusion detection general state. Possible values include: "Off", "Alert", + "Deny". + :type mode: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionStateType + :param configuration: Intrusion detection configuration properties. + :type configuration: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionConfiguration + """ + + _attribute_map = { + 'mode': {'key': 'mode', 'type': 'str'}, + 'configuration': {'key': 'configuration', 'type': 'FirewallPolicyIntrusionDetectionConfiguration'}, + } + + def __init__( + self, + *, + mode: Optional[Union[str, "FirewallPolicyIntrusionDetectionStateType"]] = None, + configuration: Optional["FirewallPolicyIntrusionDetectionConfiguration"] = None, + **kwargs + ): + super(FirewallPolicyIntrusionDetection, self).__init__(**kwargs) + self.mode = mode + self.configuration = configuration + + +class FirewallPolicyIntrusionDetectionBypassTrafficSpecifications(msrest.serialization.Model): + """Intrusion detection bypass traffic specification. + + :param name: Name of the bypass traffic rule. + :type name: str + :param description: Description of the bypass traffic rule. + :type description: str + :param protocol: The rule bypass protocol. Possible values include: "TCP", "UDP", "ICMP", + "ANY". + :type protocol: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionProtocol + :param source_addresses: List of source IP addresses or ranges for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or ranges for this rule. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports or ranges. + :type destination_ports: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + protocol: Optional[Union[str, "FirewallPolicyIntrusionDetectionProtocol"]] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + destination_ports: Optional[List[str]] = None, + source_ip_groups: Optional[List[str]] = None, + destination_ip_groups: Optional[List[str]] = None, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionBypassTrafficSpecifications, self).__init__(**kwargs) + self.name = name + self.description = description + self.protocol = protocol + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.destination_ports = destination_ports + self.source_ip_groups = source_ip_groups + self.destination_ip_groups = destination_ip_groups + + +class FirewallPolicyIntrusionDetectionConfiguration(msrest.serialization.Model): + """The operation for configuring intrusion detection. + + :param signature_overrides: List of specific signatures states. + :type signature_overrides: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionSignatureSpecification] + :param bypass_traffic_settings: List of rules for traffic to bypass. + :type bypass_traffic_settings: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionBypassTrafficSpecifications] + """ + + _attribute_map = { + 'signature_overrides': {'key': 'signatureOverrides', 'type': '[FirewallPolicyIntrusionDetectionSignatureSpecification]'}, + 'bypass_traffic_settings': {'key': 'bypassTrafficSettings', 'type': '[FirewallPolicyIntrusionDetectionBypassTrafficSpecifications]'}, + } + + def __init__( + self, + *, + signature_overrides: Optional[List["FirewallPolicyIntrusionDetectionSignatureSpecification"]] = None, + bypass_traffic_settings: Optional[List["FirewallPolicyIntrusionDetectionBypassTrafficSpecifications"]] = None, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionConfiguration, self).__init__(**kwargs) + self.signature_overrides = signature_overrides + self.bypass_traffic_settings = bypass_traffic_settings + + +class FirewallPolicyIntrusionDetectionSignatureSpecification(msrest.serialization.Model): + """Intrusion detection signatures specification states. + + :param id: Signature id. + :type id: str + :param mode: The signature state. Possible values include: "Off", "Alert", "Deny". + :type mode: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyIntrusionDetectionStateType + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'mode': {'key': 'mode', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + mode: Optional[Union[str, "FirewallPolicyIntrusionDetectionStateType"]] = None, + **kwargs + ): + super(FirewallPolicyIntrusionDetectionSignatureSpecification, self).__init__(**kwargs) + self.id = id + self.mode = mode + + +class FirewallPolicyListResult(msrest.serialization.Model): + """Response for ListFirewallPolicies API service call. + + :param value: List of Firewall Policies in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicy] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FirewallPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["FirewallPolicy"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(FirewallPolicyListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class FirewallPolicyNatRuleCollection(FirewallPolicyRuleCollection): + """Firewall Policy NAT Rule Collection. + + All required parameters must be populated in order to send to Azure. + + :param rule_collection_type: Required. The type of the rule collection.Constant filled by + server. Possible values include: "FirewallPolicyNatRuleCollection", + "FirewallPolicyFilterRuleCollection". + :type rule_collection_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionType + :param name: The name of the rule collection. + :type name: str + :param priority: Priority of the Firewall Policy Rule Collection resource. + :type priority: int + :param action: The action type of a Nat rule collection. + :type action: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyNatRuleCollectionAction + :param rules: List of rules included in a rule collection. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRule] + """ + + _validation = { + 'rule_collection_type': {'required': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + } + + _attribute_map = { + 'rule_collection_type': {'key': 'ruleCollectionType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'FirewallPolicyNatRuleCollectionAction'}, + 'rules': {'key': 'rules', 'type': '[FirewallPolicyRule]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + priority: Optional[int] = None, + action: Optional["FirewallPolicyNatRuleCollectionAction"] = None, + rules: Optional[List["FirewallPolicyRule"]] = None, + **kwargs + ): + super(FirewallPolicyNatRuleCollection, self).__init__(name=name, priority=priority, **kwargs) + self.rule_collection_type = 'FirewallPolicyNatRuleCollection' # type: str + self.action = action + self.rules = rules + + +class FirewallPolicyNatRuleCollectionAction(msrest.serialization.Model): + """Properties of the FirewallPolicyNatRuleCollectionAction. + + :param type: The type of action. Possible values include: "DNAT". + :type type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyNatRuleCollectionActionType + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "FirewallPolicyNatRuleCollectionActionType"]] = None, + **kwargs + ): + super(FirewallPolicyNatRuleCollectionAction, self).__init__(**kwargs) + self.type = type + + +class FirewallPolicyRuleApplicationProtocol(msrest.serialization.Model): + """Properties of the application rule protocol. + + :param protocol_type: Protocol type. Possible values include: "Http", "Https". + :type protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleApplicationProtocolType + :param port: Port number for the protocol, cannot be greater than 64000. + :type port: int + """ + + _validation = { + 'port': {'maximum': 64000, 'minimum': 0}, + } + + _attribute_map = { + 'protocol_type': {'key': 'protocolType', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + } + + def __init__( + self, + *, + protocol_type: Optional[Union[str, "FirewallPolicyRuleApplicationProtocolType"]] = None, + port: Optional[int] = None, + **kwargs + ): + super(FirewallPolicyRuleApplicationProtocol, self).__init__(**kwargs) + self.protocol_type = protocol_type + self.port = port + + +class FirewallPolicyRuleCollectionGroup(SubResource): + """Rule Collection Group resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Rule Group type. + :vartype type: str + :param priority: Priority of the Firewall Policy Rule Collection Group resource. + :type priority: int + :param rule_collections: Group of Firewall Policy rule collections. + :type rule_collections: + list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollection] + :ivar provisioning_state: The provisioning state of the firewall policy rule collection group + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'priority': {'maximum': 65000, 'minimum': 100}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'rule_collections': {'key': 'properties.ruleCollections', 'type': '[FirewallPolicyRuleCollection]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + priority: Optional[int] = None, + rule_collections: Optional[List["FirewallPolicyRuleCollection"]] = None, + **kwargs + ): + super(FirewallPolicyRuleCollectionGroup, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.priority = priority + self.rule_collections = rule_collections + self.provisioning_state = None + + +class FirewallPolicyRuleCollectionGroupListResult(msrest.serialization.Model): + """Response for ListFirewallPolicyRuleCollectionGroups API service call. + + :param value: List of FirewallPolicyRuleCollectionGroups in a FirewallPolicy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FirewallPolicyRuleCollectionGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["FirewallPolicyRuleCollectionGroup"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(FirewallPolicyRuleCollectionGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class FirewallPolicySku(msrest.serialization.Model): + """SKU of Firewall policy. + + :param tier: Tier of Firewall Policy. Possible values include: "Standard", "Premium". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicySkuTier + """ + + _attribute_map = { + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + *, + tier: Optional[Union[str, "FirewallPolicySkuTier"]] = None, + **kwargs + ): + super(FirewallPolicySku, self).__init__(**kwargs) + self.tier = tier + + +class FirewallPolicyThreatIntelWhitelist(msrest.serialization.Model): + """ThreatIntel Whitelist for Firewall Policy. + + :param ip_addresses: List of IP addresses for the ThreatIntel Whitelist. + :type ip_addresses: list[str] + :param fqdns: List of FQDNs for the ThreatIntel Whitelist. + :type fqdns: list[str] + """ + + _attribute_map = { + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + 'fqdns': {'key': 'fqdns', 'type': '[str]'}, + } + + def __init__( + self, + *, + ip_addresses: Optional[List[str]] = None, + fqdns: Optional[List[str]] = None, + **kwargs + ): + super(FirewallPolicyThreatIntelWhitelist, self).__init__(**kwargs) + self.ip_addresses = ip_addresses + self.fqdns = fqdns + + +class FirewallPolicyTransportSecurity(msrest.serialization.Model): + """Configuration needed to perform TLS termination & initiation. + + :param certificate_authority: The CA used for intermediate CA generation. + :type certificate_authority: + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyCertificateAuthority + """ + + _attribute_map = { + 'certificate_authority': {'key': 'certificateAuthority', 'type': 'FirewallPolicyCertificateAuthority'}, + } + + def __init__( + self, + *, + certificate_authority: Optional["FirewallPolicyCertificateAuthority"] = None, + **kwargs + ): + super(FirewallPolicyTransportSecurity, self).__init__(**kwargs) + self.certificate_authority = certificate_authority + + +class FlowLog(Resource): + """A flow log resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param target_resource_id: ID of network security group to which flow log will be applied. + :type target_resource_id: str + :ivar target_resource_guid: Guid of network security group to which flow log will be applied. + :vartype target_resource_guid: str + :param storage_id: ID of the storage account which is used to store the flow log. + :type storage_id: str + :param enabled: Flag to enable/disable flow logging. + :type enabled: bool + :param retention_policy: Parameters that define the retention policy for flow log. + :type retention_policy: ~azure.mgmt.network.v2020_08_01.models.RetentionPolicyParameters + :param format: Parameters that define the flow log format. + :type format: ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatParameters + :param flow_analytics_configuration: Parameters that define the configuration of traffic + analytics. + :type flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsProperties + :ivar provisioning_state: The provisioning state of the flow log. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'target_resource_guid': {'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'}, + 'target_resource_id': {'key': 'properties.targetResourceId', 'type': 'str'}, + 'target_resource_guid': {'key': 'properties.targetResourceGuid', 'type': 'str'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'retention_policy': {'key': 'properties.retentionPolicy', 'type': 'RetentionPolicyParameters'}, + 'format': {'key': 'properties.format', 'type': 'FlowLogFormatParameters'}, + 'flow_analytics_configuration': {'key': 'properties.flowAnalyticsConfiguration', 'type': 'TrafficAnalyticsProperties'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + target_resource_id: Optional[str] = None, + storage_id: Optional[str] = None, + enabled: Optional[bool] = None, + retention_policy: Optional["RetentionPolicyParameters"] = None, + format: Optional["FlowLogFormatParameters"] = None, + flow_analytics_configuration: Optional["TrafficAnalyticsProperties"] = None, + **kwargs + ): + super(FlowLog, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.target_resource_id = target_resource_id + self.target_resource_guid = None + self.storage_id = storage_id + self.enabled = enabled + self.retention_policy = retention_policy + self.format = format + self.flow_analytics_configuration = flow_analytics_configuration + self.provisioning_state = None + + +class FlowLogFormatParameters(msrest.serialization.Model): + """Parameters that define the flow log format. + + :param type: The file type of flow log. Possible values include: "JSON". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatType + :param version: The version (revision) of the flow log. + :type version: int + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'version': {'key': 'version', 'type': 'int'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "FlowLogFormatType"]] = None, + version: Optional[int] = 0, + **kwargs + ): + super(FlowLogFormatParameters, self).__init__(**kwargs) + self.type = type + self.version = version + + +class FlowLogInformation(msrest.serialization.Model): + """Information on the configuration of flow log and traffic analytics (optional) . + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the resource to configure for flow log and + traffic analytics (optional) . + :type target_resource_id: str + :param flow_analytics_configuration: Parameters that define the configuration of traffic + analytics. + :type flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsProperties + :param storage_id: Required. ID of the storage account which is used to store the flow log. + :type storage_id: str + :param enabled: Required. Flag to enable/disable flow logging. + :type enabled: bool + :param retention_policy: Parameters that define the retention policy for flow log. + :type retention_policy: ~azure.mgmt.network.v2020_08_01.models.RetentionPolicyParameters + :param format: Parameters that define the flow log format. + :type format: ~azure.mgmt.network.v2020_08_01.models.FlowLogFormatParameters + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'storage_id': {'required': True}, + 'enabled': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'flow_analytics_configuration': {'key': 'flowAnalyticsConfiguration', 'type': 'TrafficAnalyticsProperties'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'retention_policy': {'key': 'properties.retentionPolicy', 'type': 'RetentionPolicyParameters'}, + 'format': {'key': 'properties.format', 'type': 'FlowLogFormatParameters'}, + } + + def __init__( + self, + *, + target_resource_id: str, + storage_id: str, + enabled: bool, + flow_analytics_configuration: Optional["TrafficAnalyticsProperties"] = None, + retention_policy: Optional["RetentionPolicyParameters"] = None, + format: Optional["FlowLogFormatParameters"] = None, + **kwargs + ): + super(FlowLogInformation, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + self.flow_analytics_configuration = flow_analytics_configuration + self.storage_id = storage_id + self.enabled = enabled + self.retention_policy = retention_policy + self.format = format + + +class FlowLogListResult(msrest.serialization.Model): + """List of flow logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: Information about flow log resource. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FlowLog]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["FlowLog"]] = None, + **kwargs + ): + super(FlowLogListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class FlowLogStatusParameters(msrest.serialization.Model): + """Parameters that define a resource to query flow log and traffic analytics (optional) status. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource where getting the flow log and traffic + analytics (optional) status. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + **kwargs + ): + super(FlowLogStatusParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + + +class FrontendIPConfiguration(SubResource): + """Frontend IP address of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of frontend IP + configurations used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :ivar inbound_nat_rules: An array of references to inbound rules that use this frontend IP. + :vartype inbound_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar inbound_nat_pools: An array of references to inbound pools that use this frontend IP. + :vartype inbound_nat_pools: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar outbound_rules: An array of references to outbound rules that use this frontend IP. + :vartype outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar load_balancing_rules: An array of references to load balancing rules that use this + frontend IP. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The Private IP allocation method. Possible values include: + "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param private_ip_address_version: Whether the specific ipconfiguration is IPv4 or IPv6. + Default is taken as IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the Public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :param public_ip_prefix: The reference to the Public IP Prefix resource. + :type public_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the frontend IP configuration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'inbound_nat_rules': {'readonly': True}, + 'inbound_nat_pools': {'readonly': True}, + 'outbound_rules': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'inbound_nat_rules': {'key': 'properties.inboundNatRules', 'type': '[SubResource]'}, + 'inbound_nat_pools': {'key': 'properties.inboundNatPools', 'type': '[SubResource]'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[SubResource]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'public_ip_prefix': {'key': 'properties.publicIPPrefix', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + zones: Optional[List[str]] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + private_ip_address_version: Optional[Union[str, "IPVersion"]] = None, + subnet: Optional["Subnet"] = None, + public_ip_address: Optional["PublicIPAddress"] = None, + public_ip_prefix: Optional["SubResource"] = None, + **kwargs + ): + super(FrontendIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.zones = zones + self.inbound_nat_rules = None + self.inbound_nat_pools = None + self.outbound_rules = None + self.load_balancing_rules = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.private_ip_address_version = private_ip_address_version + self.subnet = subnet + self.public_ip_address = public_ip_address + self.public_ip_prefix = public_ip_prefix + self.provisioning_state = None + + +class GatewayRoute(msrest.serialization.Model): + """Gateway routing details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The gateway's local address. + :vartype local_address: str + :ivar network: The route's network prefix. + :vartype network: str + :ivar next_hop: The route's next hop. + :vartype next_hop: str + :ivar source_peer: The peer this route was learned from. + :vartype source_peer: str + :ivar origin: The source this route was learned from. + :vartype origin: str + :ivar as_path: The route's AS path sequence. + :vartype as_path: str + :ivar weight: The route's weight. + :vartype weight: int + """ + + _validation = { + 'local_address': {'readonly': True}, + 'network': {'readonly': True}, + 'next_hop': {'readonly': True}, + 'source_peer': {'readonly': True}, + 'origin': {'readonly': True}, + 'as_path': {'readonly': True}, + 'weight': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'source_peer': {'key': 'sourcePeer', 'type': 'str'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(GatewayRoute, self).__init__(**kwargs) + self.local_address = None + self.network = None + self.next_hop = None + self.source_peer = None + self.origin = None + self.as_path = None + self.weight = None + + +class GatewayRouteListResult(msrest.serialization.Model): + """List of virtual network gateway routes. + + :param value: List of gateway routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.GatewayRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GatewayRoute]'}, + } + + def __init__( + self, + *, + value: Optional[List["GatewayRoute"]] = None, + **kwargs + ): + super(GatewayRouteListResult, self).__init__(**kwargs) + self.value = value + + +class GenerateExpressRoutePortsLOARequest(msrest.serialization.Model): + """The customer name to be printed on a letter of authorization. + + All required parameters must be populated in order to send to Azure. + + :param customer_name: Required. The customer name. + :type customer_name: str + """ + + _validation = { + 'customer_name': {'required': True}, + } + + _attribute_map = { + 'customer_name': {'key': 'customerName', 'type': 'str'}, + } + + def __init__( + self, + *, + customer_name: str, + **kwargs + ): + super(GenerateExpressRoutePortsLOARequest, self).__init__(**kwargs) + self.customer_name = customer_name + + +class GenerateExpressRoutePortsLOAResult(msrest.serialization.Model): + """Response for GenerateExpressRoutePortsLOA API service call. + + :param encoded_content: The content as a base64 encoded string. + :type encoded_content: str + """ + + _attribute_map = { + 'encoded_content': {'key': 'encodedContent', 'type': 'str'}, + } + + def __init__( + self, + *, + encoded_content: Optional[str] = None, + **kwargs + ): + super(GenerateExpressRoutePortsLOAResult, self).__init__(**kwargs) + self.encoded_content = encoded_content + + +class GetVpnSitesConfigurationRequest(msrest.serialization.Model): + """List of Vpn-Sites. + + All required parameters must be populated in order to send to Azure. + + :param vpn_sites: List of resource-ids of the vpn-sites for which config is to be downloaded. + :type vpn_sites: list[str] + :param output_blob_sas_url: Required. The sas-url to download the configurations for vpn-sites. + :type output_blob_sas_url: str + """ + + _validation = { + 'output_blob_sas_url': {'required': True}, + } + + _attribute_map = { + 'vpn_sites': {'key': 'vpnSites', 'type': '[str]'}, + 'output_blob_sas_url': {'key': 'outputBlobSasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + output_blob_sas_url: str, + vpn_sites: Optional[List[str]] = None, + **kwargs + ): + super(GetVpnSitesConfigurationRequest, self).__init__(**kwargs) + self.vpn_sites = vpn_sites + self.output_blob_sas_url = output_blob_sas_url + + +class HopLink(msrest.serialization.Model): + """Hop link. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar next_hop_id: The ID of the next hop. + :vartype next_hop_id: str + :ivar link_type: Link type. + :vartype link_type: str + :ivar issues: List of issues. + :vartype issues: list[~azure.mgmt.network.v2020_08_01.models.ConnectivityIssue] + :ivar context: Provides additional context on links. + :vartype context: dict[str, str] + :ivar resource_id: Resource ID. + :vartype resource_id: str + :ivar round_trip_time_min: Minimum roundtrip time in milliseconds. + :vartype round_trip_time_min: long + :ivar round_trip_time_avg: Average roundtrip time in milliseconds. + :vartype round_trip_time_avg: long + :ivar round_trip_time_max: Maximum roundtrip time in milliseconds. + :vartype round_trip_time_max: long + """ + + _validation = { + 'next_hop_id': {'readonly': True}, + 'link_type': {'readonly': True}, + 'issues': {'readonly': True}, + 'context': {'readonly': True}, + 'resource_id': {'readonly': True}, + 'round_trip_time_min': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'round_trip_time_avg': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + 'round_trip_time_max': {'readonly': True, 'maximum': 4294967295, 'minimum': 0}, + } + + _attribute_map = { + 'next_hop_id': {'key': 'nextHopId', 'type': 'str'}, + 'link_type': {'key': 'linkType', 'type': 'str'}, + 'issues': {'key': 'issues', 'type': '[ConnectivityIssue]'}, + 'context': {'key': 'context', 'type': '{str}'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'round_trip_time_min': {'key': 'properties.roundTripTimeMin', 'type': 'long'}, + 'round_trip_time_avg': {'key': 'properties.roundTripTimeAvg', 'type': 'long'}, + 'round_trip_time_max': {'key': 'properties.roundTripTimeMax', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(HopLink, self).__init__(**kwargs) + self.next_hop_id = None + self.link_type = None + self.issues = None + self.context = None + self.resource_id = None + self.round_trip_time_min = None + self.round_trip_time_avg = None + self.round_trip_time_max = None + + +class HTTPConfiguration(msrest.serialization.Model): + """HTTP configuration of the connectivity check. + + :param method: HTTP method. Possible values include: "Get". + :type method: str or ~azure.mgmt.network.v2020_08_01.models.HTTPMethod + :param headers: List of HTTP headers. + :type headers: list[~azure.mgmt.network.v2020_08_01.models.HTTPHeader] + :param valid_status_codes: Valid status codes. + :type valid_status_codes: list[int] + """ + + _attribute_map = { + 'method': {'key': 'method', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '[HTTPHeader]'}, + 'valid_status_codes': {'key': 'validStatusCodes', 'type': '[int]'}, + } + + def __init__( + self, + *, + method: Optional[Union[str, "HTTPMethod"]] = None, + headers: Optional[List["HTTPHeader"]] = None, + valid_status_codes: Optional[List[int]] = None, + **kwargs + ): + super(HTTPConfiguration, self).__init__(**kwargs) + self.method = method + self.headers = headers + self.valid_status_codes = valid_status_codes + + +class HTTPHeader(msrest.serialization.Model): + """The HTTP header. + + :param name: The name in HTTP header. + :type name: str + :param value: The value in HTTP header. + :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(HTTPHeader, self).__init__(**kwargs) + self.name = name + self.value = value + + +class HubIPAddresses(msrest.serialization.Model): + """IP addresses associated with azure firewall. + + :param public_i_ps: Public IP addresses associated with azure firewall. + :type public_i_ps: ~azure.mgmt.network.v2020_08_01.models.HubPublicIPAddresses + :param private_ip_address: Private IP Address associated with azure firewall. + :type private_ip_address: str + """ + + _attribute_map = { + 'public_i_ps': {'key': 'publicIPs', 'type': 'HubPublicIPAddresses'}, + 'private_ip_address': {'key': 'privateIPAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + public_i_ps: Optional["HubPublicIPAddresses"] = None, + private_ip_address: Optional[str] = None, + **kwargs + ): + super(HubIPAddresses, self).__init__(**kwargs) + self.public_i_ps = public_i_ps + self.private_ip_address = private_ip_address + + +class HubIpConfiguration(SubResource): + """IpConfigurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the Ip Configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Ipconfiguration type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :ivar provisioning_state: The provisioning state of the IP configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["Subnet"] = None, + public_ip_address: Optional["PublicIPAddress"] = None, + **kwargs + ): + super(HubIpConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.public_ip_address = public_ip_address + self.provisioning_state = None + + +class HubPublicIPAddresses(msrest.serialization.Model): + """Public IP addresses associated with azure firewall. + + :param addresses: The list of Public IP addresses associated with azure firewall or IP + addresses to be retained. + :type addresses: list[~azure.mgmt.network.v2020_08_01.models.AzureFirewallPublicIPAddress] + :param count: The number of Public IP addresses associated with azure firewall. + :type count: int + """ + + _attribute_map = { + 'addresses': {'key': 'addresses', 'type': '[AzureFirewallPublicIPAddress]'}, + 'count': {'key': 'count', 'type': 'int'}, + } + + def __init__( + self, + *, + addresses: Optional[List["AzureFirewallPublicIPAddress"]] = None, + count: Optional[int] = None, + **kwargs + ): + super(HubPublicIPAddresses, self).__init__(**kwargs) + self.addresses = addresses + self.count = count + + +class HubRoute(msrest.serialization.Model): + """RouteTable route. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the Route that is unique within a RouteTable. This name can + be used to access this route. + :type name: str + :param destination_type: Required. The type of destinations (eg: CIDR, ResourceId, Service). + :type destination_type: str + :param destinations: Required. List of all destinations. + :type destinations: list[str] + :param next_hop_type: Required. The type of next hop (eg: ResourceId). + :type next_hop_type: str + :param next_hop: Required. NextHop resource ID. + :type next_hop: str + """ + + _validation = { + 'name': {'required': True}, + 'destination_type': {'required': True}, + 'destinations': {'required': True}, + 'next_hop_type': {'required': True}, + 'next_hop': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'destination_type': {'key': 'destinationType', 'type': 'str'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + destination_type: str, + destinations: List[str], + next_hop_type: str, + next_hop: str, + **kwargs + ): + super(HubRoute, self).__init__(**kwargs) + self.name = name + self.destination_type = destination_type + self.destinations = destinations + self.next_hop_type = next_hop_type + self.next_hop = next_hop + + +class HubRouteTable(SubResource): + """RouteTable resource in a virtual hub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.HubRoute] + :param labels: List of labels associated with this route table. + :type labels: list[str] + :ivar associated_connections: List of all connections associated with this route table. + :vartype associated_connections: list[str] + :ivar propagating_connections: List of all connections that advertise to this route table. + :vartype propagating_connections: list[str] + :ivar provisioning_state: The provisioning state of the RouteTable resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'associated_connections': {'readonly': True}, + 'propagating_connections': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[HubRoute]'}, + 'labels': {'key': 'properties.labels', 'type': '[str]'}, + 'associated_connections': {'key': 'properties.associatedConnections', 'type': '[str]'}, + 'propagating_connections': {'key': 'properties.propagatingConnections', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + routes: Optional[List["HubRoute"]] = None, + labels: Optional[List[str]] = None, + **kwargs + ): + super(HubRouteTable, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.routes = routes + self.labels = labels + self.associated_connections = None + self.propagating_connections = None + self.provisioning_state = None + + +class HubVirtualNetworkConnection(SubResource): + """HubVirtualNetworkConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param remote_virtual_network: Reference to the remote virtual network. + :type remote_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param allow_hub_to_remote_vnet_transit: Deprecated: VirtualHub to RemoteVnet transit to + enabled or not. + :type allow_hub_to_remote_vnet_transit: bool + :param allow_remote_vnet_to_use_hub_vnet_gateways: Deprecated: Allow RemoteVnet to use Virtual + Hub's gateways. + :type allow_remote_vnet_to_use_hub_vnet_gateways: bool + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + :ivar provisioning_state: The provisioning state of the hub virtual network connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'remote_virtual_network': {'key': 'properties.remoteVirtualNetwork', 'type': 'SubResource'}, + 'allow_hub_to_remote_vnet_transit': {'key': 'properties.allowHubToRemoteVnetTransit', 'type': 'bool'}, + 'allow_remote_vnet_to_use_hub_vnet_gateways': {'key': 'properties.allowRemoteVnetToUseHubVnetGateways', 'type': 'bool'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + remote_virtual_network: Optional["SubResource"] = None, + allow_hub_to_remote_vnet_transit: Optional[bool] = None, + allow_remote_vnet_to_use_hub_vnet_gateways: Optional[bool] = None, + enable_internet_security: Optional[bool] = None, + routing_configuration: Optional["RoutingConfiguration"] = None, + **kwargs + ): + super(HubVirtualNetworkConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.remote_virtual_network = remote_virtual_network + self.allow_hub_to_remote_vnet_transit = allow_hub_to_remote_vnet_transit + self.allow_remote_vnet_to_use_hub_vnet_gateways = allow_remote_vnet_to_use_hub_vnet_gateways + self.enable_internet_security = enable_internet_security + self.routing_configuration = routing_configuration + self.provisioning_state = None + + +class InboundNatPool(SubResource): + """Inbound NAT pool of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of inbound NAT pools used + by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: The reference to the transport protocol used by the inbound NAT pool. Possible + values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param frontend_port_range_start: The first port number in the range of external ports that + will be used to provide Inbound Nat to NICs associated with a load balancer. Acceptable values + range between 1 and 65534. + :type frontend_port_range_start: int + :param frontend_port_range_end: The last port number in the range of external ports that will + be used to provide Inbound Nat to NICs associated with a load balancer. Acceptable values range + between 1 and 65535. + :type frontend_port_range_end: int + :param backend_port: The port used for internal connections on the endpoint. Acceptable values + are between 1 and 65535. + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :ivar provisioning_state: The provisioning state of the inbound NAT pool resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'frontend_port_range_start': {'key': 'properties.frontendPortRangeStart', 'type': 'int'}, + 'frontend_port_range_end': {'key': 'properties.frontendPortRangeEnd', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + frontend_ip_configuration: Optional["SubResource"] = None, + protocol: Optional[Union[str, "TransportProtocol"]] = None, + frontend_port_range_start: Optional[int] = None, + frontend_port_range_end: Optional[int] = None, + backend_port: Optional[int] = None, + idle_timeout_in_minutes: Optional[int] = None, + enable_floating_ip: Optional[bool] = None, + enable_tcp_reset: Optional[bool] = None, + **kwargs + ): + super(InboundNatPool, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.frontend_ip_configuration = frontend_ip_configuration + self.protocol = protocol + self.frontend_port_range_start = frontend_port_range_start + self.frontend_port_range_end = frontend_port_range_end + self.backend_port = backend_port + self.idle_timeout_in_minutes = idle_timeout_in_minutes + self.enable_floating_ip = enable_floating_ip + self.enable_tcp_reset = enable_tcp_reset + self.provisioning_state = None + + +class InboundNatRule(SubResource): + """Inbound NAT rule of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of inbound NAT rules used + by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar backend_ip_configuration: A reference to a private IP address defined on a network + interface of a VM. Traffic sent to the frontend port of each of the frontend IP configurations + is forwarded to the backend IP. + :vartype backend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param protocol: The reference to the transport protocol used by the load balancing rule. + Possible values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param frontend_port: The port for the external endpoint. Port numbers for each rule must be + unique within the Load Balancer. Acceptable values range from 1 to 65534. + :type frontend_port: int + :param backend_port: The port used for the internal endpoint. Acceptable values range from 1 to + 65535. + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :ivar provisioning_state: The provisioning state of the inbound NAT rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'backend_ip_configuration': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'backend_ip_configuration': {'key': 'properties.backendIPConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + frontend_ip_configuration: Optional["SubResource"] = None, + protocol: Optional[Union[str, "TransportProtocol"]] = None, + frontend_port: Optional[int] = None, + backend_port: Optional[int] = None, + idle_timeout_in_minutes: Optional[int] = None, + enable_floating_ip: Optional[bool] = None, + enable_tcp_reset: Optional[bool] = None, + **kwargs + ): + super(InboundNatRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.frontend_ip_configuration = frontend_ip_configuration + self.backend_ip_configuration = None + self.protocol = protocol + self.frontend_port = frontend_port + self.backend_port = backend_port + self.idle_timeout_in_minutes = idle_timeout_in_minutes + self.enable_floating_ip = enable_floating_ip + self.enable_tcp_reset = enable_tcp_reset + self.provisioning_state = None + + +class InboundNatRuleListResult(msrest.serialization.Model): + """Response for ListInboundNatRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of inbound nat rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundNatRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["InboundNatRule"]] = None, + **kwargs + ): + super(InboundNatRuleListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class InboundSecurityRule(SubResource): + """NVA Inbound Security Rule resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of security rule collection. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: NVA inbound security rule type. + :vartype type: str + :param rules: List of allowed rules. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.InboundSecurityRules] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'rules': {'key': 'properties.rules', 'type': '[InboundSecurityRules]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + rules: Optional[List["InboundSecurityRules"]] = None, + **kwargs + ): + super(InboundSecurityRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.rules = rules + self.provisioning_state = None + + +class InboundSecurityRules(msrest.serialization.Model): + """Properties of the Inbound Security Rules resource. + + :param protocol: Protocol. This should be either TCP or UDP. Possible values include: "TCP", + "UDP". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.InboundSecurityRulesProtocol + :param source_address_prefix: The CIDR or source IP range. Only /30, /31 and /32 Ip ranges are + allowed. + :type source_address_prefix: str + :param destination_port_range: NVA port ranges to be opened up. One needs to provide specific + ports. + :type destination_port_range: int + """ + + _validation = { + 'destination_port_range': {'maximum': 65535, 'minimum': 0}, + } + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_address_prefix': {'key': 'sourceAddressPrefix', 'type': 'str'}, + 'destination_port_range': {'key': 'destinationPortRange', 'type': 'int'}, + } + + def __init__( + self, + *, + protocol: Optional[Union[str, "InboundSecurityRulesProtocol"]] = None, + source_address_prefix: Optional[str] = None, + destination_port_range: Optional[int] = None, + **kwargs + ): + super(InboundSecurityRules, self).__init__(**kwargs) + self.protocol = protocol + self.source_address_prefix = source_address_prefix + self.destination_port_range = destination_port_range + + +class IPAddressAvailabilityResult(msrest.serialization.Model): + """Response for CheckIPAddressAvailability API service call. + + :param available: Private IP address availability. + :type available: bool + :param available_ip_addresses: Contains other available private IP addresses if the asked for + address is taken. + :type available_ip_addresses: list[str] + """ + + _attribute_map = { + 'available': {'key': 'available', 'type': 'bool'}, + 'available_ip_addresses': {'key': 'availableIPAddresses', 'type': '[str]'}, + } + + def __init__( + self, + *, + available: Optional[bool] = None, + available_ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(IPAddressAvailabilityResult, self).__init__(**kwargs) + self.available = available + self.available_ip_addresses = available_ip_addresses + + +class IpAllocation(Resource): + """IpAllocation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar subnet: The Subnet that using the prefix of this IpAllocation resource. + :vartype subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar virtual_network: The VirtualNetwork that using the prefix of this IpAllocation resource. + :vartype virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param type_properties_type: The type for the IpAllocation. Possible values include: + "Undefined", "Hypernet". + :type type_properties_type: str or ~azure.mgmt.network.v2020_08_01.models.IpAllocationType + :param prefix: The address prefix for the IpAllocation. + :type prefix: str + :param prefix_length: The address prefix length for the IpAllocation. + :type prefix_length: int + :param prefix_type: The address prefix Type for the IpAllocation. Possible values include: + "IPv4", "IPv6". + :type prefix_type: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param ipam_allocation_id: The IPAM allocation ID. + :type ipam_allocation_id: str + :param allocation_tags: IpAllocation tags. + :type allocation_tags: dict[str, str] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnet': {'readonly': True}, + 'virtual_network': {'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'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'SubResource'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + 'prefix': {'key': 'properties.prefix', 'type': 'str'}, + 'prefix_length': {'key': 'properties.prefixLength', 'type': 'int'}, + 'prefix_type': {'key': 'properties.prefixType', 'type': 'str'}, + 'ipam_allocation_id': {'key': 'properties.ipamAllocationId', 'type': 'str'}, + 'allocation_tags': {'key': 'properties.allocationTags', 'type': '{str}'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + type_properties_type: Optional[Union[str, "IpAllocationType"]] = None, + prefix: Optional[str] = None, + prefix_length: Optional[int] = 0, + prefix_type: Optional[Union[str, "IPVersion"]] = None, + ipam_allocation_id: Optional[str] = None, + allocation_tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(IpAllocation, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.subnet = None + self.virtual_network = None + self.type_properties_type = type_properties_type + self.prefix = prefix + self.prefix_length = prefix_length + self.prefix_type = prefix_type + self.ipam_allocation_id = ipam_allocation_id + self.allocation_tags = allocation_tags + + +class IpAllocationListResult(msrest.serialization.Model): + """Response for the ListIpAllocations API service call. + + :param value: A list of IpAllocation resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.IpAllocation] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[IpAllocation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["IpAllocation"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(IpAllocationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class IPConfiguration(SubResource): + """IP configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :ivar provisioning_state: The provisioning state of the IP configuration resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["Subnet"] = None, + public_ip_address: Optional["PublicIPAddress"] = None, + **kwargs + ): + super(IPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.public_ip_address = public_ip_address + self.provisioning_state = None + + +class IPConfigurationBgpPeeringAddress(msrest.serialization.Model): + """Properties of IPConfigurationBgpPeeringAddress. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param ipconfiguration_id: The ID of IP configuration which belongs to gateway. + :type ipconfiguration_id: str + :ivar default_bgp_ip_addresses: The list of default BGP peering addresses which belong to IP + configuration. + :vartype default_bgp_ip_addresses: list[str] + :param custom_bgp_ip_addresses: The list of custom BGP peering addresses which belong to IP + configuration. + :type custom_bgp_ip_addresses: list[str] + :ivar tunnel_ip_addresses: The list of tunnel public IP addresses which belong to IP + configuration. + :vartype tunnel_ip_addresses: list[str] + """ + + _validation = { + 'default_bgp_ip_addresses': {'readonly': True}, + 'tunnel_ip_addresses': {'readonly': True}, + } + + _attribute_map = { + 'ipconfiguration_id': {'key': 'ipconfigurationId', 'type': 'str'}, + 'default_bgp_ip_addresses': {'key': 'defaultBgpIpAddresses', 'type': '[str]'}, + 'custom_bgp_ip_addresses': {'key': 'customBgpIpAddresses', 'type': '[str]'}, + 'tunnel_ip_addresses': {'key': 'tunnelIpAddresses', 'type': '[str]'}, + } + + def __init__( + self, + *, + ipconfiguration_id: Optional[str] = None, + custom_bgp_ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(IPConfigurationBgpPeeringAddress, self).__init__(**kwargs) + self.ipconfiguration_id = ipconfiguration_id + self.default_bgp_ip_addresses = None + self.custom_bgp_ip_addresses = custom_bgp_ip_addresses + self.tunnel_ip_addresses = None + + +class IPConfigurationProfile(SubResource): + """IP configuration profile child resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource. This name can be used to access the resource. + :type name: str + :ivar type: Sub Resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param subnet: The reference to the subnet resource to create a container network interface ip + configuration. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :ivar provisioning_state: The provisioning state of the IP configuration profile resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + subnet: Optional["Subnet"] = None, + **kwargs + ): + super(IPConfigurationProfile, self).__init__(id=id, **kwargs) + self.name = name + self.type = None + self.etag = None + self.subnet = subnet + self.provisioning_state = None + + +class IpGroup(Resource): + """The IpGroups resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the IpGroups resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ip_addresses: IpAddresses/IpAddressPrefixes in the IpGroups resource. + :type ip_addresses: list[str] + :ivar firewalls: List of references to Firewall resources that this IpGroups is associated + with. + :vartype firewalls: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar firewall_policies: List of references to Firewall Policies resources that this IpGroups + is associated with. + :vartype firewall_policies: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'firewalls': {'readonly': True}, + 'firewall_policies': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'ip_addresses': {'key': 'properties.ipAddresses', 'type': '[str]'}, + 'firewalls': {'key': 'properties.firewalls', 'type': '[SubResource]'}, + 'firewall_policies': {'key': 'properties.firewallPolicies', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(IpGroup, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.provisioning_state = None + self.ip_addresses = ip_addresses + self.firewalls = None + self.firewall_policies = None + + +class IpGroupListResult(msrest.serialization.Model): + """Response for the ListIpGroups API service call. + + :param value: The list of IpGroups information resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.IpGroup] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[IpGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["IpGroup"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(IpGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class IpsecPolicy(msrest.serialization.Model): + """An IPSec Policy configuration for a virtual network gateway connection. + + All required parameters must be populated in order to send to Azure. + + :param sa_life_time_seconds: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) lifetime in seconds for a site to site VPN tunnel. + :type sa_life_time_seconds: int + :param sa_data_size_kilobytes: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) payload size in KB for a site to site VPN tunnel. + :type sa_data_size_kilobytes: int + :param ipsec_encryption: Required. The IPSec encryption algorithm (IKE phase 1). Possible + values include: "None", "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES128", "GCMAES192", + "GCMAES256". + :type ipsec_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IpsecEncryption + :param ipsec_integrity: Required. The IPSec integrity algorithm (IKE phase 1). Possible values + include: "MD5", "SHA1", "SHA256", "GCMAES128", "GCMAES192", "GCMAES256". + :type ipsec_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IpsecIntegrity + :param ike_encryption: Required. The IKE encryption algorithm (IKE phase 2). Possible values + include: "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES256", "GCMAES128". + :type ike_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IkeEncryption + :param ike_integrity: Required. The IKE integrity algorithm (IKE phase 2). Possible values + include: "MD5", "SHA1", "SHA256", "SHA384", "GCMAES256", "GCMAES128". + :type ike_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IkeIntegrity + :param dh_group: Required. The DH Group used in IKE Phase 1 for initial SA. Possible values + include: "None", "DHGroup1", "DHGroup2", "DHGroup14", "DHGroup2048", "ECP256", "ECP384", + "DHGroup24". + :type dh_group: str or ~azure.mgmt.network.v2020_08_01.models.DhGroup + :param pfs_group: Required. The Pfs Group used in IKE Phase 2 for new child SA. Possible values + include: "None", "PFS1", "PFS2", "PFS2048", "ECP256", "ECP384", "PFS24", "PFS14", "PFSMM". + :type pfs_group: str or ~azure.mgmt.network.v2020_08_01.models.PfsGroup + """ + + _validation = { + 'sa_life_time_seconds': {'required': True}, + 'sa_data_size_kilobytes': {'required': True}, + 'ipsec_encryption': {'required': True}, + 'ipsec_integrity': {'required': True}, + 'ike_encryption': {'required': True}, + 'ike_integrity': {'required': True}, + 'dh_group': {'required': True}, + 'pfs_group': {'required': True}, + } + + _attribute_map = { + 'sa_life_time_seconds': {'key': 'saLifeTimeSeconds', 'type': 'int'}, + 'sa_data_size_kilobytes': {'key': 'saDataSizeKilobytes', 'type': 'int'}, + 'ipsec_encryption': {'key': 'ipsecEncryption', 'type': 'str'}, + 'ipsec_integrity': {'key': 'ipsecIntegrity', 'type': 'str'}, + 'ike_encryption': {'key': 'ikeEncryption', 'type': 'str'}, + 'ike_integrity': {'key': 'ikeIntegrity', 'type': 'str'}, + 'dh_group': {'key': 'dhGroup', 'type': 'str'}, + 'pfs_group': {'key': 'pfsGroup', 'type': 'str'}, + } + + def __init__( + self, + *, + sa_life_time_seconds: int, + sa_data_size_kilobytes: int, + ipsec_encryption: Union[str, "IpsecEncryption"], + ipsec_integrity: Union[str, "IpsecIntegrity"], + ike_encryption: Union[str, "IkeEncryption"], + ike_integrity: Union[str, "IkeIntegrity"], + dh_group: Union[str, "DhGroup"], + pfs_group: Union[str, "PfsGroup"], + **kwargs + ): + super(IpsecPolicy, self).__init__(**kwargs) + self.sa_life_time_seconds = sa_life_time_seconds + self.sa_data_size_kilobytes = sa_data_size_kilobytes + self.ipsec_encryption = ipsec_encryption + self.ipsec_integrity = ipsec_integrity + self.ike_encryption = ike_encryption + self.ike_integrity = ike_integrity + self.dh_group = dh_group + self.pfs_group = pfs_group + + +class IpTag(msrest.serialization.Model): + """Contains the IpTag associated with the object. + + :param ip_tag_type: The IP tag type. Example: FirstPartyUsage. + :type ip_tag_type: str + :param tag: The value of the IP tag associated with the public IP. Example: SQL. + :type tag: str + """ + + _attribute_map = { + 'ip_tag_type': {'key': 'ipTagType', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + } + + def __init__( + self, + *, + ip_tag_type: Optional[str] = None, + tag: Optional[str] = None, + **kwargs + ): + super(IpTag, self).__init__(**kwargs) + self.ip_tag_type = ip_tag_type + self.tag = tag + + +class Ipv6CircuitConnectionConfig(msrest.serialization.Model): + """IPv6 Circuit Connection properties for global reach. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param address_prefix: /125 IP address space to carve out customer addresses for global reach. + :type address_prefix: str + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + """ + + _validation = { + 'circuit_connection_status': {'readonly': True}, + } + + _attribute_map = { + 'address_prefix': {'key': 'addressPrefix', 'type': 'str'}, + 'circuit_connection_status': {'key': 'circuitConnectionStatus', 'type': 'str'}, + } + + def __init__( + self, + *, + address_prefix: Optional[str] = None, + **kwargs + ): + super(Ipv6CircuitConnectionConfig, self).__init__(**kwargs) + self.address_prefix = address_prefix + self.circuit_connection_status = None + + +class Ipv6ExpressRouteCircuitPeeringConfig(msrest.serialization.Model): + """Contains IPv6 peering config. + + :param primary_peer_address_prefix: The primary address prefix. + :type primary_peer_address_prefix: str + :param secondary_peer_address_prefix: The secondary address prefix. + :type secondary_peer_address_prefix: str + :param microsoft_peering_config: The Microsoft peering configuration. + :type microsoft_peering_config: + ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringConfig + :param route_filter: The reference to the RouteFilter resource. + :type route_filter: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param state: The state of peering. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringState + """ + + _attribute_map = { + 'primary_peer_address_prefix': {'key': 'primaryPeerAddressPrefix', 'type': 'str'}, + 'secondary_peer_address_prefix': {'key': 'secondaryPeerAddressPrefix', 'type': 'str'}, + 'microsoft_peering_config': {'key': 'microsoftPeeringConfig', 'type': 'ExpressRouteCircuitPeeringConfig'}, + 'route_filter': {'key': 'routeFilter', 'type': 'SubResource'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + primary_peer_address_prefix: Optional[str] = None, + secondary_peer_address_prefix: Optional[str] = None, + microsoft_peering_config: Optional["ExpressRouteCircuitPeeringConfig"] = None, + route_filter: Optional["SubResource"] = None, + state: Optional[Union[str, "ExpressRouteCircuitPeeringState"]] = None, + **kwargs + ): + super(Ipv6ExpressRouteCircuitPeeringConfig, self).__init__(**kwargs) + self.primary_peer_address_prefix = primary_peer_address_prefix + self.secondary_peer_address_prefix = secondary_peer_address_prefix + self.microsoft_peering_config = microsoft_peering_config + self.route_filter = route_filter + self.state = state + + +class ListHubRouteTablesResult(msrest.serialization.Model): + """List of RouteTables and a URL nextLink to get the next set of results. + + :param value: List of RouteTables. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubRouteTable] + :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': '[HubRouteTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["HubRouteTable"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListHubRouteTablesResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListHubVirtualNetworkConnectionsResult(msrest.serialization.Model): + """List of HubVirtualNetworkConnections and a URL nextLink to get the next set of results. + + :param value: List of HubVirtualNetworkConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection] + :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': '[HubVirtualNetworkConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["HubVirtualNetworkConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListHubVirtualNetworkConnectionsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListP2SVpnGatewaysResult(msrest.serialization.Model): + """Result of the request to list P2SVpnGateways. It contains a list of P2SVpnGateways and a URL nextLink to get the next set of results. + + :param value: List of P2SVpnGateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :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': '[P2SVpnGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["P2SVpnGateway"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListP2SVpnGatewaysResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVirtualHubBgpConnectionResults(msrest.serialization.Model): + """VirtualHubBgpConnections list. + + :param value: The list of VirtualHubBgpConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BgpConnection] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BgpConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BgpConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVirtualHubBgpConnectionResults, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVirtualHubIpConfigurationResults(msrest.serialization.Model): + """VirtualHubIpConfigurations list. + + :param value: The list of VirtualHubIpConfigurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HubIpConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["HubIpConfiguration"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVirtualHubIpConfigurationResults, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVirtualHubRouteTableV2SResult(msrest.serialization.Model): + """List of VirtualHubRouteTableV2s and a URL nextLink to get the next set of results. + + :param value: List of VirtualHubRouteTableV2s. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :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': '[VirtualHubRouteTableV2]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualHubRouteTableV2"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVirtualHubRouteTableV2SResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVirtualHubsResult(msrest.serialization.Model): + """Result of the request to list VirtualHubs. It contains a list of VirtualHubs and a URL nextLink to get the next set of results. + + :param value: List of VirtualHubs. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHub] + :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': '[VirtualHub]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualHub"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVirtualHubsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVirtualWANsResult(msrest.serialization.Model): + """Result of the request to list VirtualWANs. It contains a list of VirtualWANs and a URL nextLink to get the next set of results. + + :param value: List of VirtualWANs. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualWAN] + :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': '[VirtualWAN]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualWAN"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVirtualWANsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnConnectionsResult(msrest.serialization.Model): + """Result of the request to list all vpn connections to a virtual wan vpn gateway. It contains a list of Vpn Connections and a URL nextLink to get the next set of results. + + :param value: List of Vpn Connections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :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': '[VpnConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnConnectionsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnGatewayNatRulesResult(msrest.serialization.Model): + """Result of the request to list all nat rules to a virtual wan vpn gateway. It contains a list of Nat rules and a URL nextLink to get the next set of results. + + :param value: List of Nat Rules. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + :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': '[VpnGatewayNatRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnGatewayNatRule"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnGatewayNatRulesResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnGatewaysResult(msrest.serialization.Model): + """Result of the request to list VpnGateways. It contains a list of VpnGateways and a URL nextLink to get the next set of results. + + :param value: List of VpnGateways. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :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': '[VpnGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnGateway"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnGatewaysResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnServerConfigurationsResult(msrest.serialization.Model): + """Result of the request to list all VpnServerConfigurations. It contains a list of VpnServerConfigurations and a URL nextLink to get the next set of results. + + :param value: List of VpnServerConfigurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration] + :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': '[VpnServerConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnServerConfiguration"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnServerConfigurationsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnSiteLinkConnectionsResult(msrest.serialization.Model): + """Result of the request to list all vpn connections to a virtual wan vpn gateway. It contains a list of Vpn Connections and a URL nextLink to get the next set of results. + + :param value: List of VpnSiteLinkConnections. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection] + :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': '[VpnSiteLinkConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnSiteLinkConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnSiteLinkConnectionsResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnSiteLinksResult(msrest.serialization.Model): + """Result of the request to list VpnSiteLinks. It contains a list of VpnSiteLinks and a URL nextLink to get the next set of results. + + :param value: List of VpnSitesLinks. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLink] + :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': '[VpnSiteLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnSiteLink"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnSiteLinksResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ListVpnSitesResult(msrest.serialization.Model): + """Result of the request to list VpnSites. It contains a list of VpnSites and a URL nextLink to get the next set of results. + + :param value: List of VpnSites. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnSite] + :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': '[VpnSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnSite"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ListVpnSitesResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class LoadBalancer(Resource): + """LoadBalancer resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The load balancer SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param frontend_ip_configurations: Object representing the frontend IPs to be used for the load + balancer. + :type frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :param backend_address_pools: Collection of backend address pools used by a load balancer. + :type backend_address_pools: list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :param load_balancing_rules: Object collection representing the load balancing rules Gets the + provisioning. + :type load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule] + :param probes: Collection of probe objects used in the load balancer. + :type probes: list[~azure.mgmt.network.v2020_08_01.models.Probe] + :param inbound_nat_rules: Collection of inbound NAT Rules used by a load balancer. Defining + inbound NAT rules on your load balancer is mutually exclusive with defining an inbound NAT + pool. Inbound NAT pools are referenced from virtual machine scale sets. NICs that are + associated with individual virtual machines cannot reference an Inbound NAT pool. They have to + reference individual inbound NAT rules. + :type inbound_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :param inbound_nat_pools: Defines an external port range for inbound NAT to a single backend + port on NICs associated with a load balancer. Inbound NAT rules are created automatically for + each NIC associated with the Load Balancer using an external port from this range. Defining an + Inbound NAT pool on your Load Balancer is mutually exclusive with defining inbound Nat rules. + Inbound NAT pools are referenced from virtual machine scale sets. NICs that are associated with + individual virtual machines cannot reference an inbound NAT pool. They have to reference + individual inbound NAT rules. + :type inbound_nat_pools: list[~azure.mgmt.network.v2020_08_01.models.InboundNatPool] + :param outbound_rules: The outbound rules. + :type outbound_rules: list[~azure.mgmt.network.v2020_08_01.models.OutboundRule] + :ivar resource_guid: The resource GUID property of the load balancer resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the load balancer resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'LoadBalancerSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[FrontendIPConfiguration]'}, + 'backend_address_pools': {'key': 'properties.backendAddressPools', 'type': '[BackendAddressPool]'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[LoadBalancingRule]'}, + 'probes': {'key': 'properties.probes', 'type': '[Probe]'}, + 'inbound_nat_rules': {'key': 'properties.inboundNatRules', 'type': '[InboundNatRule]'}, + 'inbound_nat_pools': {'key': 'properties.inboundNatPools', 'type': '[InboundNatPool]'}, + 'outbound_rules': {'key': 'properties.outboundRules', 'type': '[OutboundRule]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + sku: Optional["LoadBalancerSku"] = None, + frontend_ip_configurations: Optional[List["FrontendIPConfiguration"]] = None, + backend_address_pools: Optional[List["BackendAddressPool"]] = None, + load_balancing_rules: Optional[List["LoadBalancingRule"]] = None, + probes: Optional[List["Probe"]] = None, + inbound_nat_rules: Optional[List["InboundNatRule"]] = None, + inbound_nat_pools: Optional[List["InboundNatPool"]] = None, + outbound_rules: Optional[List["OutboundRule"]] = None, + **kwargs + ): + super(LoadBalancer, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.sku = sku + self.etag = None + self.frontend_ip_configurations = frontend_ip_configurations + self.backend_address_pools = backend_address_pools + self.load_balancing_rules = load_balancing_rules + self.probes = probes + self.inbound_nat_rules = inbound_nat_rules + self.inbound_nat_pools = inbound_nat_pools + self.outbound_rules = outbound_rules + self.resource_guid = None + self.provisioning_state = None + + +class LoadBalancerBackendAddress(msrest.serialization.Model): + """Load balancer backend addresses. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the backend address. + :type name: str + :param virtual_network: Reference to an existing virtual network. + :type virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param ip_address: IP Address belonging to the referenced virtual network. + :type ip_address: str + :ivar network_interface_ip_configuration: Reference to IP address defined in network + interfaces. + :vartype network_interface_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param load_balancer_frontend_ip_configuration: Reference to the frontend ip address + configuration defined in regional loadbalancer. + :type load_balancer_frontend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'network_interface_ip_configuration': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'SubResource'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'network_interface_ip_configuration': {'key': 'properties.networkInterfaceIPConfiguration', 'type': 'SubResource'}, + 'load_balancer_frontend_ip_configuration': {'key': 'properties.loadBalancerFrontendIPConfiguration', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + virtual_network: Optional["SubResource"] = None, + ip_address: Optional[str] = None, + load_balancer_frontend_ip_configuration: Optional["SubResource"] = None, + **kwargs + ): + super(LoadBalancerBackendAddress, self).__init__(**kwargs) + self.name = name + self.virtual_network = virtual_network + self.ip_address = ip_address + self.network_interface_ip_configuration = None + self.load_balancer_frontend_ip_configuration = load_balancer_frontend_ip_configuration + + +class LoadBalancerBackendAddressPoolListResult(msrest.serialization.Model): + """Response for ListBackendAddressPool API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of backend address pools in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackendAddressPool]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["BackendAddressPool"]] = None, + **kwargs + ): + super(LoadBalancerBackendAddressPoolListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerFrontendIPConfigurationListResult(msrest.serialization.Model): + """Response for ListFrontendIPConfiguration API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of frontend IP configurations in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FrontendIPConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["FrontendIPConfiguration"]] = None, + **kwargs + ): + super(LoadBalancerFrontendIPConfigurationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerListResult(msrest.serialization.Model): + """Response for ListLoadBalancers API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancers in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["LoadBalancer"]] = None, + **kwargs + ): + super(LoadBalancerListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerLoadBalancingRuleListResult(msrest.serialization.Model): + """Response for ListLoadBalancingRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancing rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancingRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["LoadBalancingRule"]] = None, + **kwargs + ): + super(LoadBalancerLoadBalancingRuleListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerOutboundRuleListResult(msrest.serialization.Model): + """Response for ListOutboundRule API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of outbound rules in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.OutboundRule] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["OutboundRule"]] = None, + **kwargs + ): + super(LoadBalancerOutboundRuleListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerProbeListResult(msrest.serialization.Model): + """Response for ListProbe API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of probes in a load balancer. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Probe] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Probe]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Probe"]] = None, + **kwargs + ): + super(LoadBalancerProbeListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LoadBalancerSku(msrest.serialization.Model): + """SKU of a load balancer. + + :param name: Name of a load balancer SKU. Possible values include: "Basic", "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSkuName + :param tier: Tier of a load balancer SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "LoadBalancerSkuName"]] = None, + tier: Optional[Union[str, "LoadBalancerSkuTier"]] = None, + **kwargs + ): + super(LoadBalancerSku, self).__init__(**kwargs) + self.name = name + self.tier = tier + + +class LoadBalancingRule(SubResource): + """A load balancing rule for a load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of load balancing rules + used by the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param frontend_ip_configuration: A reference to frontend IP addresses. + :type frontend_ip_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param backend_address_pool: A reference to a pool of DIPs. Inbound traffic is randomly load + balanced across IPs in the backend IPs. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param probe: The reference to the load balancer probe used by the load balancing rule. + :type probe: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param protocol: The reference to the transport protocol used by the load balancing rule. + Possible values include: "Udp", "Tcp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.TransportProtocol + :param load_distribution: The load distribution policy for this rule. Possible values include: + "Default", "SourceIP", "SourceIPProtocol". + :type load_distribution: str or ~azure.mgmt.network.v2020_08_01.models.LoadDistribution + :param frontend_port: The port for the external endpoint. Port numbers for each rule must be + unique within the Load Balancer. Acceptable values are between 0 and 65534. Note that value 0 + enables "Any Port". + :type frontend_port: int + :param backend_port: The port used for internal connections on the endpoint. Acceptable values + are between 0 and 65535. Note that value 0 enables "Any Port". + :type backend_port: int + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. The value can be set + between 4 and 30 minutes. The default value is 4 minutes. This element is only used when the + protocol is set to TCP. + :type idle_timeout_in_minutes: int + :param enable_floating_ip: Configures a virtual machine's endpoint for the floating IP + capability required to configure a SQL AlwaysOn Availability Group. This setting is required + when using the SQL AlwaysOn Availability Groups in SQL server. This setting can't be changed + after you create the endpoint. + :type enable_floating_ip: bool + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :param disable_outbound_snat: Configures SNAT for the VMs in the backend pool to use the + publicIP address specified in the frontend of the load balancing rule. + :type disable_outbound_snat: bool + :ivar provisioning_state: The provisioning state of the load balancing rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'frontend_ip_configuration': {'key': 'properties.frontendIPConfiguration', 'type': 'SubResource'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'probe': {'key': 'properties.probe', 'type': 'SubResource'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'load_distribution': {'key': 'properties.loadDistribution', 'type': 'str'}, + 'frontend_port': {'key': 'properties.frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'properties.backendPort', 'type': 'int'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'enable_floating_ip': {'key': 'properties.enableFloatingIP', 'type': 'bool'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'disable_outbound_snat': {'key': 'properties.disableOutboundSnat', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + frontend_ip_configuration: Optional["SubResource"] = None, + backend_address_pool: Optional["SubResource"] = None, + probe: Optional["SubResource"] = None, + protocol: Optional[Union[str, "TransportProtocol"]] = None, + load_distribution: Optional[Union[str, "LoadDistribution"]] = None, + frontend_port: Optional[int] = None, + backend_port: Optional[int] = None, + idle_timeout_in_minutes: Optional[int] = None, + enable_floating_ip: Optional[bool] = None, + enable_tcp_reset: Optional[bool] = None, + disable_outbound_snat: Optional[bool] = None, + **kwargs + ): + super(LoadBalancingRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.frontend_ip_configuration = frontend_ip_configuration + self.backend_address_pool = backend_address_pool + self.probe = probe + self.protocol = protocol + self.load_distribution = load_distribution + self.frontend_port = frontend_port + self.backend_port = backend_port + self.idle_timeout_in_minutes = idle_timeout_in_minutes + self.enable_floating_ip = enable_floating_ip + self.enable_tcp_reset = enable_tcp_reset + self.disable_outbound_snat = disable_outbound_snat + self.provisioning_state = None + + +class LocalNetworkGateway(Resource): + """A common class for general resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param local_network_address_space: Local network site address space. + :type local_network_address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param gateway_ip_address: IP address of local network gateway. + :type gateway_ip_address: str + :param fqdn: FQDN of local network gateway. + :type fqdn: str + :param bgp_settings: Local network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar resource_guid: The resource GUID property of the local network gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the local network gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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'}, + 'local_network_address_space': {'key': 'properties.localNetworkAddressSpace', 'type': 'AddressSpace'}, + 'gateway_ip_address': {'key': 'properties.gatewayIpAddress', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + local_network_address_space: Optional["AddressSpace"] = None, + gateway_ip_address: Optional[str] = None, + fqdn: Optional[str] = None, + bgp_settings: Optional["BgpSettings"] = None, + **kwargs + ): + super(LocalNetworkGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.local_network_address_space = local_network_address_space + self.gateway_ip_address = gateway_ip_address + self.fqdn = fqdn + self.bgp_settings = bgp_settings + self.resource_guid = None + self.provisioning_state = None + + +class LocalNetworkGatewayListResult(msrest.serialization.Model): + """Response for ListLocalNetworkGateways API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of local network gateways that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LocalNetworkGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["LocalNetworkGateway"]] = None, + **kwargs + ): + super(LocalNetworkGatewayListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class LogSpecification(msrest.serialization.Model): + """Description of logging specification. + + :param name: The name of the specification. + :type name: str + :param display_name: The display name of the specification. + :type display_name: str + :param blob_duration: Duration of the blob. + :type blob_duration: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + blob_duration: Optional[str] = None, + **kwargs + ): + super(LogSpecification, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.blob_duration = blob_duration + + +class ManagedRuleGroupOverride(msrest.serialization.Model): + """Defines a managed rule group override setting. + + All required parameters must be populated in order to send to Azure. + + :param rule_group_name: Required. The managed rule group to override. + :type rule_group_name: str + :param rules: List of rules that will be disabled. If none specified, all rules in the group + will be disabled. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleOverride] + """ + + _validation = { + 'rule_group_name': {'required': True}, + } + + _attribute_map = { + 'rule_group_name': {'key': 'ruleGroupName', 'type': 'str'}, + 'rules': {'key': 'rules', 'type': '[ManagedRuleOverride]'}, + } + + def __init__( + self, + *, + rule_group_name: str, + rules: Optional[List["ManagedRuleOverride"]] = None, + **kwargs + ): + super(ManagedRuleGroupOverride, self).__init__(**kwargs) + self.rule_group_name = rule_group_name + self.rules = rules + + +class ManagedRuleOverride(msrest.serialization.Model): + """Defines a managed rule group override setting. + + All required parameters must be populated in order to send to Azure. + + :param rule_id: Required. Identifier for the managed rule. + :type rule_id: str + :param state: The state of the managed rule. Defaults to Disabled if not specified. Possible + values include: "Disabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.ManagedRuleEnabledState + """ + + _validation = { + 'rule_id': {'required': True}, + } + + _attribute_map = { + 'rule_id': {'key': 'ruleId', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + rule_id: str, + state: Optional[Union[str, "ManagedRuleEnabledState"]] = None, + **kwargs + ): + super(ManagedRuleOverride, self).__init__(**kwargs) + self.rule_id = rule_id + self.state = state + + +class ManagedRulesDefinition(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param exclusions: The Exclusions that are applied on the policy. + :type exclusions: list[~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntry] + :param managed_rule_sets: Required. The managed rule sets that are associated with the policy. + :type managed_rule_sets: list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleSet] + """ + + _validation = { + 'managed_rule_sets': {'required': True}, + } + + _attribute_map = { + 'exclusions': {'key': 'exclusions', 'type': '[OwaspCrsExclusionEntry]'}, + 'managed_rule_sets': {'key': 'managedRuleSets', 'type': '[ManagedRuleSet]'}, + } + + def __init__( + self, + *, + managed_rule_sets: List["ManagedRuleSet"], + exclusions: Optional[List["OwaspCrsExclusionEntry"]] = None, + **kwargs + ): + super(ManagedRulesDefinition, self).__init__(**kwargs) + self.exclusions = exclusions + self.managed_rule_sets = managed_rule_sets + + +class ManagedRuleSet(msrest.serialization.Model): + """Defines a managed rule set. + + All required parameters must be populated in order to send to Azure. + + :param rule_set_type: Required. Defines the rule set type to use. + :type rule_set_type: str + :param rule_set_version: Required. Defines the version of the rule set to use. + :type rule_set_version: str + :param rule_group_overrides: Defines the rule group overrides to apply to the rule set. + :type rule_group_overrides: + list[~azure.mgmt.network.v2020_08_01.models.ManagedRuleGroupOverride] + """ + + _validation = { + 'rule_set_type': {'required': True}, + 'rule_set_version': {'required': True}, + } + + _attribute_map = { + 'rule_set_type': {'key': 'ruleSetType', 'type': 'str'}, + 'rule_set_version': {'key': 'ruleSetVersion', 'type': 'str'}, + 'rule_group_overrides': {'key': 'ruleGroupOverrides', 'type': '[ManagedRuleGroupOverride]'}, + } + + def __init__( + self, + *, + rule_set_type: str, + rule_set_version: str, + rule_group_overrides: Optional[List["ManagedRuleGroupOverride"]] = None, + **kwargs + ): + super(ManagedRuleSet, self).__init__(**kwargs) + self.rule_set_type = rule_set_type + self.rule_set_version = rule_set_version + self.rule_group_overrides = rule_group_overrides + + +class ManagedServiceIdentity(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 system assigned identity. This property will only + be provided for a system assigned identity. + :vartype principal_id: str + :ivar tenant_id: The tenant id of the system assigned identity. This property will only be + provided for a system assigned identity. + :vartype tenant_id: str + :param type: The type of identity used for the resource. The type 'SystemAssigned, + UserAssigned' includes both an implicitly created identity and a set of user assigned + identities. The type 'None' will remove any identities from the virtual machine. Possible + values include: "SystemAssigned", "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.network.v2020_08_01.models.ResourceIdentityType + :param user_assigned_identities: The list of user identities associated with 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.network.v2020_08_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _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': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ResourceIdentityType"]] = None, + user_assigned_identities: Optional[Dict[str, "Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties"]] = None, + **kwargs + ): + super(ManagedServiceIdentity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = type + self.user_assigned_identities = user_assigned_identities + + +class MatchCondition(msrest.serialization.Model): + """Define match conditions. + + All required parameters must be populated in order to send to Azure. + + :param match_variables: Required. List of match variables. + :type match_variables: list[~azure.mgmt.network.v2020_08_01.models.MatchVariable] + :param operator: Required. The operator to be matched. Possible values include: "IPMatch", + "Equal", "Contains", "LessThan", "GreaterThan", "LessThanOrEqual", "GreaterThanOrEqual", + "BeginsWith", "EndsWith", "Regex", "GeoMatch". + :type operator: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallOperator + :param negation_conditon: Whether this is negate condition or not. + :type negation_conditon: bool + :param match_values: Required. Match value. + :type match_values: list[str] + :param transforms: List of transforms. + :type transforms: list[str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallTransform] + """ + + _validation = { + 'match_variables': {'required': True}, + 'operator': {'required': True}, + 'match_values': {'required': True}, + } + + _attribute_map = { + 'match_variables': {'key': 'matchVariables', 'type': '[MatchVariable]'}, + 'operator': {'key': 'operator', 'type': 'str'}, + 'negation_conditon': {'key': 'negationConditon', 'type': 'bool'}, + 'match_values': {'key': 'matchValues', 'type': '[str]'}, + 'transforms': {'key': 'transforms', 'type': '[str]'}, + } + + def __init__( + self, + *, + match_variables: List["MatchVariable"], + operator: Union[str, "WebApplicationFirewallOperator"], + match_values: List[str], + negation_conditon: Optional[bool] = None, + transforms: Optional[List[Union[str, "WebApplicationFirewallTransform"]]] = None, + **kwargs + ): + super(MatchCondition, self).__init__(**kwargs) + self.match_variables = match_variables + self.operator = operator + self.negation_conditon = negation_conditon + self.match_values = match_values + self.transforms = transforms + + +class MatchedRule(msrest.serialization.Model): + """Matched rule. + + :param rule_name: Name of the matched network security rule. + :type rule_name: str + :param action: The network traffic is allowed or denied. Possible values are 'Allow' and + 'Deny'. + :type action: str + """ + + _attribute_map = { + 'rule_name': {'key': 'ruleName', 'type': 'str'}, + 'action': {'key': 'action', 'type': 'str'}, + } + + def __init__( + self, + *, + rule_name: Optional[str] = None, + action: Optional[str] = None, + **kwargs + ): + super(MatchedRule, self).__init__(**kwargs) + self.rule_name = rule_name + self.action = action + + +class MatchVariable(msrest.serialization.Model): + """Define match variables. + + All required parameters must be populated in order to send to Azure. + + :param variable_name: Required. Match Variable. Possible values include: "RemoteAddr", + "RequestMethod", "QueryString", "PostArgs", "RequestUri", "RequestHeaders", "RequestBody", + "RequestCookies". + :type variable_name: str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallMatchVariable + :param selector: The selector of match variable. + :type selector: str + """ + + _validation = { + 'variable_name': {'required': True}, + } + + _attribute_map = { + 'variable_name': {'key': 'variableName', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + *, + variable_name: Union[str, "WebApplicationFirewallMatchVariable"], + selector: Optional[str] = None, + **kwargs + ): + super(MatchVariable, self).__init__(**kwargs) + self.variable_name = variable_name + self.selector = selector + + +class MetricSpecification(msrest.serialization.Model): + """Description of metrics specification. + + :param name: The name of the metric. + :type name: str + :param display_name: The display name of the metric. + :type display_name: str + :param display_description: The description of the metric. + :type display_description: str + :param unit: Units the metric to be displayed in. + :type unit: str + :param aggregation_type: The aggregation type. + :type aggregation_type: str + :param availabilities: List of availability. + :type availabilities: list[~azure.mgmt.network.v2020_08_01.models.Availability] + :param enable_regional_mdm_account: Whether regional MDM account enabled. + :type enable_regional_mdm_account: bool + :param fill_gap_with_zero: Whether gaps would be filled with zeros. + :type fill_gap_with_zero: bool + :param metric_filter_pattern: Pattern for the filter of the metric. + :type metric_filter_pattern: str + :param dimensions: List of dimensions. + :type dimensions: list[~azure.mgmt.network.v2020_08_01.models.Dimension] + :param is_internal: Whether the metric is internal. + :type is_internal: bool + :param source_mdm_account: The source MDM account. + :type source_mdm_account: str + :param source_mdm_namespace: The source MDM namespace. + :type source_mdm_namespace: str + :param resource_id_dimension_name_override: The resource Id dimension name override. + :type resource_id_dimension_name_override: 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'}, + 'availabilities': {'key': 'availabilities', 'type': '[Availability]'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'resource_id_dimension_name_override': {'key': 'resourceIdDimensionNameOverride', '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, + availabilities: Optional[List["Availability"]] = None, + enable_regional_mdm_account: Optional[bool] = None, + fill_gap_with_zero: Optional[bool] = None, + metric_filter_pattern: Optional[str] = None, + dimensions: Optional[List["Dimension"]] = None, + is_internal: Optional[bool] = None, + source_mdm_account: Optional[str] = None, + source_mdm_namespace: Optional[str] = None, + resource_id_dimension_name_override: Optional[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.availabilities = availabilities + self.enable_regional_mdm_account = enable_regional_mdm_account + self.fill_gap_with_zero = fill_gap_with_zero + self.metric_filter_pattern = metric_filter_pattern + self.dimensions = dimensions + self.is_internal = is_internal + self.source_mdm_account = source_mdm_account + self.source_mdm_namespace = source_mdm_namespace + self.resource_id_dimension_name_override = resource_id_dimension_name_override + + +class NatGateway(Resource): + """Nat Gateway resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 sku: The nat gateway SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.NatGatewaySku + :param zones: A list of availability zones denoting the zone in which Nat Gateway should be + deployed. + :type zones: list[str] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param idle_timeout_in_minutes: The idle timeout of the nat gateway. + :type idle_timeout_in_minutes: int + :param public_ip_addresses: An array of public ip addresses associated with the nat gateway + resource. + :type public_ip_addresses: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param public_ip_prefixes: An array of public ip prefixes associated with the nat gateway + resource. + :type public_ip_prefixes: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar subnets: An array of references to the subnets using this nat gateway resource. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_guid: The resource GUID property of the NAT gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the NAT gateway resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'resource_guid': {'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}'}, + 'sku': {'key': 'sku', 'type': 'NatGatewaySku'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'public_ip_addresses': {'key': 'properties.publicIpAddresses', 'type': '[SubResource]'}, + 'public_ip_prefixes': {'key': 'properties.publicIpPrefixes', 'type': '[SubResource]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[SubResource]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["NatGatewaySku"] = None, + zones: Optional[List[str]] = None, + idle_timeout_in_minutes: Optional[int] = None, + public_ip_addresses: Optional[List["SubResource"]] = None, + public_ip_prefixes: Optional[List["SubResource"]] = None, + **kwargs + ): + super(NatGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.sku = sku + self.zones = zones + self.etag = None + self.idle_timeout_in_minutes = idle_timeout_in_minutes + self.public_ip_addresses = public_ip_addresses + self.public_ip_prefixes = public_ip_prefixes + self.subnets = None + self.resource_guid = None + self.provisioning_state = None + + +class NatGatewayListResult(msrest.serialization.Model): + """Response for ListNatGateways API service call. + + :param value: A list of Nat Gateways that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NatGateway] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NatGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NatGateway"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NatGatewayListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NatGatewaySku(msrest.serialization.Model): + """SKU of nat gateway. + + :param name: Name of Nat Gateway SKU. Possible values include: "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.NatGatewaySkuName + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "NatGatewaySkuName"]] = None, + **kwargs + ): + super(NatGatewaySku, self).__init__(**kwargs) + self.name = name + + +class NatRule(FirewallPolicyRule): + """Rule of type nat. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param ip_protocols: Array of FirewallPolicyRuleNetworkProtocols. + :type ip_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleNetworkProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param translated_address: The translated address for this NAT rule. + :type translated_address: str + :param translated_port: The translated port for this NAT rule. + :type translated_port: str + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param translated_fqdn: The translated FQDN for this NAT rule. + :type translated_fqdn: str + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'ip_protocols': {'key': 'ipProtocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'translated_address': {'key': 'translatedAddress', 'type': 'str'}, + 'translated_port': {'key': 'translatedPort', 'type': 'str'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'translated_fqdn': {'key': 'translatedFqdn', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + ip_protocols: Optional[List[Union[str, "FirewallPolicyRuleNetworkProtocol"]]] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + destination_ports: Optional[List[str]] = None, + translated_address: Optional[str] = None, + translated_port: Optional[str] = None, + source_ip_groups: Optional[List[str]] = None, + translated_fqdn: Optional[str] = None, + **kwargs + ): + super(NatRule, self).__init__(name=name, description=description, **kwargs) + self.rule_type = 'NatRule' # type: str + self.ip_protocols = ip_protocols + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.destination_ports = destination_ports + self.translated_address = translated_address + self.translated_port = translated_port + self.source_ip_groups = source_ip_groups + self.translated_fqdn = translated_fqdn + + +class NetworkConfigurationDiagnosticParameters(msrest.serialization.Model): + """Parameters to get network configuration diagnostic. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the target resource to perform network + configuration diagnostic. Valid options are VM, NetworkInterface, VMSS/NetworkInterface and + Application Gateway. + :type target_resource_id: str + :param verbosity_level: Verbosity level. Possible values include: "Normal", "Minimum", "Full". + :type verbosity_level: str or ~azure.mgmt.network.v2020_08_01.models.VerbosityLevel + :param profiles: Required. List of network configuration diagnostic profiles. + :type profiles: + list[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticProfile] + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'profiles': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'verbosity_level': {'key': 'verbosityLevel', 'type': 'str'}, + 'profiles': {'key': 'profiles', 'type': '[NetworkConfigurationDiagnosticProfile]'}, + } + + def __init__( + self, + *, + target_resource_id: str, + profiles: List["NetworkConfigurationDiagnosticProfile"], + verbosity_level: Optional[Union[str, "VerbosityLevel"]] = None, + **kwargs + ): + super(NetworkConfigurationDiagnosticParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + self.verbosity_level = verbosity_level + self.profiles = profiles + + +class NetworkConfigurationDiagnosticProfile(msrest.serialization.Model): + """Parameters to compare with network configuration. + + All required parameters must be populated in order to send to Azure. + + :param direction: Required. The direction of the traffic. Possible values include: "Inbound", + "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.Direction + :param protocol: Required. Protocol to be verified on. Accepted values are '*', TCP, UDP. + :type protocol: str + :param source: Required. Traffic source. Accepted values are '*', IP Address/CIDR, Service Tag. + :type source: str + :param destination: Required. Traffic destination. Accepted values are: '*', IP Address/CIDR, + Service Tag. + :type destination: str + :param destination_port: Required. Traffic destination port. Accepted values are '*' and a + single port in the range (0 - 65535). + :type destination_port: str + """ + + _validation = { + 'direction': {'required': True}, + 'protocol': {'required': True}, + 'source': {'required': True}, + 'destination': {'required': True}, + 'destination_port': {'required': True}, + } + + _attribute_map = { + 'direction': {'key': 'direction', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'destination': {'key': 'destination', 'type': 'str'}, + 'destination_port': {'key': 'destinationPort', 'type': 'str'}, + } + + def __init__( + self, + *, + direction: Union[str, "Direction"], + protocol: str, + source: str, + destination: str, + destination_port: str, + **kwargs + ): + super(NetworkConfigurationDiagnosticProfile, self).__init__(**kwargs) + self.direction = direction + self.protocol = protocol + self.source = source + self.destination = destination + self.destination_port = destination_port + + +class NetworkConfigurationDiagnosticResponse(msrest.serialization.Model): + """Results of network configuration diagnostic on the target resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar results: List of network configuration diagnostic results. + :vartype results: + list[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticResult] + """ + + _validation = { + 'results': {'readonly': True}, + } + + _attribute_map = { + 'results': {'key': 'results', 'type': '[NetworkConfigurationDiagnosticResult]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkConfigurationDiagnosticResponse, self).__init__(**kwargs) + self.results = None + + +class NetworkConfigurationDiagnosticResult(msrest.serialization.Model): + """Network configuration diagnostic result corresponded to provided traffic query. + + :param profile: Network configuration diagnostic profile. + :type profile: ~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticProfile + :param network_security_group_result: Network security group result. + :type network_security_group_result: + ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupResult + """ + + _attribute_map = { + 'profile': {'key': 'profile', 'type': 'NetworkConfigurationDiagnosticProfile'}, + 'network_security_group_result': {'key': 'networkSecurityGroupResult', 'type': 'NetworkSecurityGroupResult'}, + } + + def __init__( + self, + *, + profile: Optional["NetworkConfigurationDiagnosticProfile"] = None, + network_security_group_result: Optional["NetworkSecurityGroupResult"] = None, + **kwargs + ): + super(NetworkConfigurationDiagnosticResult, self).__init__(**kwargs) + self.profile = profile + self.network_security_group_result = network_security_group_result + + +class NetworkIntentPolicy(Resource): + """Network Intent Policy resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(NetworkIntentPolicy, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + + +class NetworkIntentPolicyConfiguration(msrest.serialization.Model): + """Details of NetworkIntentPolicyConfiguration for PrepareNetworkPoliciesRequest. + + :param network_intent_policy_name: The name of the Network Intent Policy for storing in target + subscription. + :type network_intent_policy_name: str + :param source_network_intent_policy: Source network intent policy. + :type source_network_intent_policy: ~azure.mgmt.network.v2020_08_01.models.NetworkIntentPolicy + """ + + _attribute_map = { + 'network_intent_policy_name': {'key': 'networkIntentPolicyName', 'type': 'str'}, + 'source_network_intent_policy': {'key': 'sourceNetworkIntentPolicy', 'type': 'NetworkIntentPolicy'}, + } + + def __init__( + self, + *, + network_intent_policy_name: Optional[str] = None, + source_network_intent_policy: Optional["NetworkIntentPolicy"] = None, + **kwargs + ): + super(NetworkIntentPolicyConfiguration, self).__init__(**kwargs) + self.network_intent_policy_name = network_intent_policy_name + self.source_network_intent_policy = source_network_intent_policy + + +class NetworkInterface(Resource): + """A network interface in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the network interface. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar virtual_machine: The reference to a virtual machine. + :vartype virtual_machine: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param network_security_group: The reference to the NetworkSecurityGroup resource. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :ivar private_endpoint: A reference to the private endpoint to which the network interface is + linked. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param ip_configurations: A list of IPConfigurations of the network interface. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar tap_configurations: A list of TapConfigurations of the network interface. + :vartype tap_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :param dns_settings: The DNS settings in network interface. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceDnsSettings + :ivar mac_address: The MAC address of the network interface. + :vartype mac_address: str + :ivar primary: Whether this is a primary network interface on a virtual machine. + :vartype primary: bool + :param enable_accelerated_networking: If the network interface is accelerated networking + enabled. + :type enable_accelerated_networking: bool + :param enable_ip_forwarding: Indicates whether IP forwarding is enabled on this network + interface. + :type enable_ip_forwarding: bool + :ivar hosted_workloads: A list of references to linked BareMetal resources. + :vartype hosted_workloads: list[str] + :ivar dscp_configuration: A reference to the dscp configuration to which the network interface + is linked. + :vartype dscp_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar resource_guid: The resource GUID property of the network interface resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network interface resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_machine': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'tap_configurations': {'readonly': True}, + 'mac_address': {'readonly': True}, + 'primary': {'readonly': True}, + 'hosted_workloads': {'readonly': True}, + 'dscp_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'virtual_machine': {'key': 'properties.virtualMachine', 'type': 'SubResource'}, + 'network_security_group': {'key': 'properties.networkSecurityGroup', 'type': 'NetworkSecurityGroup'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'tap_configurations': {'key': 'properties.tapConfigurations', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'NetworkInterfaceDnsSettings'}, + 'mac_address': {'key': 'properties.macAddress', 'type': 'str'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'enable_accelerated_networking': {'key': 'properties.enableAcceleratedNetworking', 'type': 'bool'}, + 'enable_ip_forwarding': {'key': 'properties.enableIPForwarding', 'type': 'bool'}, + 'hosted_workloads': {'key': 'properties.hostedWorkloads', 'type': '[str]'}, + 'dscp_configuration': {'key': 'properties.dscpConfiguration', 'type': 'SubResource'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + network_security_group: Optional["NetworkSecurityGroup"] = None, + ip_configurations: Optional[List["NetworkInterfaceIPConfiguration"]] = None, + dns_settings: Optional["NetworkInterfaceDnsSettings"] = None, + enable_accelerated_networking: Optional[bool] = None, + enable_ip_forwarding: Optional[bool] = None, + **kwargs + ): + super(NetworkInterface, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.etag = None + self.virtual_machine = None + self.network_security_group = network_security_group + self.private_endpoint = None + self.ip_configurations = ip_configurations + self.tap_configurations = None + self.dns_settings = dns_settings + self.mac_address = None + self.primary = None + self.enable_accelerated_networking = enable_accelerated_networking + self.enable_ip_forwarding = enable_ip_forwarding + self.hosted_workloads = None + self.dscp_configuration = None + self.resource_guid = None + self.provisioning_state = None + + +class NetworkInterfaceAssociation(msrest.serialization.Model): + """Network interface and its custom security rules. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Network interface ID. + :vartype id: str + :param security_rules: Collection of custom security rules. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rules': {'key': 'securityRules', 'type': '[SecurityRule]'}, + } + + def __init__( + self, + *, + security_rules: Optional[List["SecurityRule"]] = None, + **kwargs + ): + super(NetworkInterfaceAssociation, self).__init__(**kwargs) + self.id = None + self.security_rules = security_rules + + +class NetworkInterfaceDnsSettings(msrest.serialization.Model): + """DNS settings of a network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param dns_servers: List of DNS servers IP addresses. Use 'AzureProvidedDNS' to switch to azure + provided DNS resolution. 'AzureProvidedDNS' value cannot be combined with other IPs, it must be + the only value in dnsServers collection. + :type dns_servers: list[str] + :ivar applied_dns_servers: If the VM that uses this NIC is part of an Availability Set, then + this list will have the union of all DNS servers from all NICs that are part of the + Availability Set. This property is what is configured on each of those VMs. + :vartype applied_dns_servers: list[str] + :param internal_dns_name_label: Relative DNS name for this NIC used for internal communications + between VMs in the same virtual network. + :type internal_dns_name_label: str + :ivar internal_fqdn: Fully qualified DNS name supporting internal communications between VMs in + the same virtual network. + :vartype internal_fqdn: str + :ivar internal_domain_name_suffix: Even if internalDnsNameLabel is not specified, a DNS entry + is created for the primary NIC of the VM. This DNS name can be constructed by concatenating the + VM name with the value of internalDomainNameSuffix. + :vartype internal_domain_name_suffix: str + """ + + _validation = { + 'applied_dns_servers': {'readonly': True}, + 'internal_fqdn': {'readonly': True}, + 'internal_domain_name_suffix': {'readonly': True}, + } + + _attribute_map = { + 'dns_servers': {'key': 'dnsServers', 'type': '[str]'}, + 'applied_dns_servers': {'key': 'appliedDnsServers', 'type': '[str]'}, + 'internal_dns_name_label': {'key': 'internalDnsNameLabel', 'type': 'str'}, + 'internal_fqdn': {'key': 'internalFqdn', 'type': 'str'}, + 'internal_domain_name_suffix': {'key': 'internalDomainNameSuffix', 'type': 'str'}, + } + + def __init__( + self, + *, + dns_servers: Optional[List[str]] = None, + internal_dns_name_label: Optional[str] = None, + **kwargs + ): + super(NetworkInterfaceDnsSettings, self).__init__(**kwargs) + self.dns_servers = dns_servers + self.applied_dns_servers = None + self.internal_dns_name_label = internal_dns_name_label + self.internal_fqdn = None + self.internal_domain_name_suffix = None + + +class NetworkInterfaceIPConfiguration(SubResource): + """IPConfiguration in a network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_network_taps: The reference to Virtual Network Taps. + :type virtual_network_taps: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :param application_gateway_backend_address_pools: The reference to + ApplicationGatewayBackendAddressPool resource. + :type application_gateway_backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendAddressPool] + :param load_balancer_backend_address_pools: The reference to LoadBalancerBackendAddressPool + resource. + :type load_balancer_backend_address_pools: + list[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :param load_balancer_inbound_nat_rules: A list of references of LoadBalancerInboundNatRules. + :type load_balancer_inbound_nat_rules: + list[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :param private_ip_address: Private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param private_ip_address_version: Whether the specific IP configuration is IPv4 or IPv6. + Default is IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param subnet: Subnet bound to the IP configuration. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param primary: Whether this is a primary customer address on the network interface. + :type primary: bool + :param public_ip_address: Public IP address bound to the IP configuration. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :param application_security_groups: Application security groups in which the IP configuration + is included. + :type application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :ivar provisioning_state: The provisioning state of the network interface IP configuration. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar private_link_connection_properties: PrivateLinkConnection properties for the network + interface. + :vartype private_link_connection_properties: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'private_link_connection_properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'virtual_network_taps': {'key': 'properties.virtualNetworkTaps', 'type': '[VirtualNetworkTap]'}, + 'application_gateway_backend_address_pools': {'key': 'properties.applicationGatewayBackendAddressPools', 'type': '[ApplicationGatewayBackendAddressPool]'}, + 'load_balancer_backend_address_pools': {'key': 'properties.loadBalancerBackendAddressPools', 'type': '[BackendAddressPool]'}, + 'load_balancer_inbound_nat_rules': {'key': 'properties.loadBalancerInboundNatRules', 'type': '[InboundNatRule]'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'PublicIPAddress'}, + 'application_security_groups': {'key': 'properties.applicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_connection_properties': {'key': 'properties.privateLinkConnectionProperties', 'type': 'NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + virtual_network_taps: Optional[List["VirtualNetworkTap"]] = None, + application_gateway_backend_address_pools: Optional[List["ApplicationGatewayBackendAddressPool"]] = None, + load_balancer_backend_address_pools: Optional[List["BackendAddressPool"]] = None, + load_balancer_inbound_nat_rules: Optional[List["InboundNatRule"]] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + private_ip_address_version: Optional[Union[str, "IPVersion"]] = None, + subnet: Optional["Subnet"] = None, + primary: Optional[bool] = None, + public_ip_address: Optional["PublicIPAddress"] = None, + application_security_groups: Optional[List["ApplicationSecurityGroup"]] = None, + **kwargs + ): + super(NetworkInterfaceIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.virtual_network_taps = virtual_network_taps + self.application_gateway_backend_address_pools = application_gateway_backend_address_pools + self.load_balancer_backend_address_pools = load_balancer_backend_address_pools + self.load_balancer_inbound_nat_rules = load_balancer_inbound_nat_rules + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.private_ip_address_version = private_ip_address_version + self.subnet = subnet + self.primary = primary + self.public_ip_address = public_ip_address + self.application_security_groups = application_security_groups + self.provisioning_state = None + self.private_link_connection_properties = None + + +class NetworkInterfaceIPConfigurationListResult(msrest.serialization.Model): + """Response for list ip configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ip configurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterfaceIPConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkInterfaceIPConfiguration"]] = None, + **kwargs + ): + super(NetworkInterfaceIPConfigurationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties(msrest.serialization.Model): + """PrivateLinkConnection properties for the network interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: The group ID for current private link connection. + :vartype group_id: str + :ivar required_member_name: The required member name for current private link connection. + :vartype required_member_name: str + :ivar fqdns: List of FQDNs for current private link connection. + :vartype fqdns: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_member_name': {'readonly': True}, + 'fqdns': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_member_name': {'key': 'requiredMemberName', 'type': 'str'}, + 'fqdns': {'key': 'fqdns', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkInterfaceIPConfigurationPrivateLinkConnectionProperties, self).__init__(**kwargs) + self.group_id = None + self.required_member_name = None + self.fqdns = None + + +class NetworkInterfaceListResult(msrest.serialization.Model): + """Response for the ListNetworkInterface API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of network interfaces in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterface]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkInterface"]] = None, + **kwargs + ): + super(NetworkInterfaceListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NetworkInterfaceLoadBalancerListResult(msrest.serialization.Model): + """Response for list ip configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of load balancers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[LoadBalancer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["LoadBalancer"]] = None, + **kwargs + ): + super(NetworkInterfaceLoadBalancerListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NetworkInterfaceTapConfiguration(SubResource): + """Tap configuration in a Network Interface. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Sub Resource type. + :vartype type: str + :param virtual_network_tap: The reference to the Virtual Network Tap resource. + :type virtual_network_tap: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :ivar provisioning_state: The provisioning state of the network interface tap configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'virtual_network_tap': {'key': 'properties.virtualNetworkTap', 'type': 'VirtualNetworkTap'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + virtual_network_tap: Optional["VirtualNetworkTap"] = None, + **kwargs + ): + super(NetworkInterfaceTapConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.virtual_network_tap = virtual_network_tap + self.provisioning_state = None + + +class NetworkInterfaceTapConfigurationListResult(msrest.serialization.Model): + """Response for list tap configurations API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of tap configurations. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkInterfaceTapConfiguration"]] = None, + **kwargs + ): + super(NetworkInterfaceTapConfigurationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NetworkProfile(Resource): + """Network profile resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar container_network_interfaces: List of child container network interfaces. + :vartype container_network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterface] + :param container_network_interface_configurations: List of chid container network interface + configurations. + :type container_network_interface_configurations: + list[~azure.mgmt.network.v2020_08_01.models.ContainerNetworkInterfaceConfiguration] + :ivar resource_guid: The resource GUID property of the network profile resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network profile resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'container_network_interfaces': {'readonly': True}, + 'resource_guid': {'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'}, + 'container_network_interfaces': {'key': 'properties.containerNetworkInterfaces', 'type': '[ContainerNetworkInterface]'}, + 'container_network_interface_configurations': {'key': 'properties.containerNetworkInterfaceConfigurations', 'type': '[ContainerNetworkInterfaceConfiguration]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + container_network_interface_configurations: Optional[List["ContainerNetworkInterfaceConfiguration"]] = None, + **kwargs + ): + super(NetworkProfile, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.container_network_interfaces = None + self.container_network_interface_configurations = container_network_interface_configurations + self.resource_guid = None + self.provisioning_state = None + + +class NetworkProfileListResult(msrest.serialization.Model): + """Response for ListNetworkProfiles API service call. + + :param value: A list of network profiles that exist in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkProfile] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkProfile]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkProfile"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NetworkProfileListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NetworkRule(FirewallPolicyRule): + """Rule of type network. + + All required parameters must be populated in order to send to Azure. + + :param name: Name of the rule. + :type name: str + :param description: Description of the rule. + :type description: str + :param rule_type: Required. Rule Type.Constant filled by server. Possible values include: + "ApplicationRule", "NetworkRule", "NatRule". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleType + :param ip_protocols: Array of FirewallPolicyRuleNetworkProtocols. + :type ip_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleNetworkProtocol] + :param source_addresses: List of source IP addresses for this rule. + :type source_addresses: list[str] + :param destination_addresses: List of destination IP addresses or Service Tags. + :type destination_addresses: list[str] + :param destination_ports: List of destination ports. + :type destination_ports: list[str] + :param source_ip_groups: List of source IpGroups for this rule. + :type source_ip_groups: list[str] + :param destination_ip_groups: List of destination IpGroups for this rule. + :type destination_ip_groups: list[str] + :param destination_fqdns: List of destination FQDNs. + :type destination_fqdns: list[str] + """ + + _validation = { + 'rule_type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'ip_protocols': {'key': 'ipProtocols', 'type': '[str]'}, + 'source_addresses': {'key': 'sourceAddresses', 'type': '[str]'}, + 'destination_addresses': {'key': 'destinationAddresses', 'type': '[str]'}, + 'destination_ports': {'key': 'destinationPorts', 'type': '[str]'}, + 'source_ip_groups': {'key': 'sourceIpGroups', 'type': '[str]'}, + 'destination_ip_groups': {'key': 'destinationIpGroups', 'type': '[str]'}, + 'destination_fqdns': {'key': 'destinationFqdns', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + ip_protocols: Optional[List[Union[str, "FirewallPolicyRuleNetworkProtocol"]]] = None, + source_addresses: Optional[List[str]] = None, + destination_addresses: Optional[List[str]] = None, + destination_ports: Optional[List[str]] = None, + source_ip_groups: Optional[List[str]] = None, + destination_ip_groups: Optional[List[str]] = None, + destination_fqdns: Optional[List[str]] = None, + **kwargs + ): + super(NetworkRule, self).__init__(name=name, description=description, **kwargs) + self.rule_type = 'NetworkRule' # type: str + self.ip_protocols = ip_protocols + self.source_addresses = source_addresses + self.destination_addresses = destination_addresses + self.destination_ports = destination_ports + self.source_ip_groups = source_ip_groups + self.destination_ip_groups = destination_ip_groups + self.destination_fqdns = destination_fqdns + + +class NetworkSecurityGroup(Resource): + """NetworkSecurityGroup resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param security_rules: A collection of security rules of the network security group. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :ivar default_security_rules: The default security rules of network security group. + :vartype default_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :ivar network_interfaces: A collection of references to network interfaces. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :ivar flow_logs: A collection of references to flow log resources. + :vartype flow_logs: list[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :ivar resource_guid: The resource GUID property of the network security group resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the network security group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'default_security_rules': {'readonly': True}, + 'network_interfaces': {'readonly': True}, + 'subnets': {'readonly': True}, + 'flow_logs': {'readonly': True}, + 'resource_guid': {'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'}, + 'security_rules': {'key': 'properties.securityRules', 'type': '[SecurityRule]'}, + 'default_security_rules': {'key': 'properties.defaultSecurityRules', 'type': '[SecurityRule]'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'flow_logs': {'key': 'properties.flowLogs', 'type': '[FlowLog]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + security_rules: Optional[List["SecurityRule"]] = None, + **kwargs + ): + super(NetworkSecurityGroup, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.security_rules = security_rules + self.default_security_rules = None + self.network_interfaces = None + self.subnets = None + self.flow_logs = None + self.resource_guid = None + self.provisioning_state = None + + +class NetworkSecurityGroupListResult(msrest.serialization.Model): + """Response for ListNetworkSecurityGroups API service call. + + :param value: A list of NetworkSecurityGroup resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkSecurityGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkSecurityGroup"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NetworkSecurityGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NetworkSecurityGroupResult(msrest.serialization.Model): + """Network configuration diagnostic result corresponded provided traffic query. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param security_rule_access_result: The network traffic is allowed or denied. Possible values + include: "Allow", "Deny". + :type security_rule_access_result: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :ivar evaluated_network_security_groups: List of results network security groups diagnostic. + :vartype evaluated_network_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.EvaluatedNetworkSecurityGroup] + """ + + _validation = { + 'evaluated_network_security_groups': {'readonly': True}, + } + + _attribute_map = { + 'security_rule_access_result': {'key': 'securityRuleAccessResult', 'type': 'str'}, + 'evaluated_network_security_groups': {'key': 'evaluatedNetworkSecurityGroups', 'type': '[EvaluatedNetworkSecurityGroup]'}, + } + + def __init__( + self, + *, + security_rule_access_result: Optional[Union[str, "SecurityRuleAccess"]] = None, + **kwargs + ): + super(NetworkSecurityGroupResult, self).__init__(**kwargs) + self.security_rule_access_result = security_rule_access_result + self.evaluated_network_security_groups = None + + +class NetworkSecurityRulesEvaluationResult(msrest.serialization.Model): + """Network security rules evaluation result. + + :param name: Name of the network security rule. + :type name: str + :param protocol_matched: Value indicating whether protocol is matched. + :type protocol_matched: bool + :param source_matched: Value indicating whether source is matched. + :type source_matched: bool + :param source_port_matched: Value indicating whether source port is matched. + :type source_port_matched: bool + :param destination_matched: Value indicating whether destination is matched. + :type destination_matched: bool + :param destination_port_matched: Value indicating whether destination port is matched. + :type destination_port_matched: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'protocol_matched': {'key': 'protocolMatched', 'type': 'bool'}, + 'source_matched': {'key': 'sourceMatched', 'type': 'bool'}, + 'source_port_matched': {'key': 'sourcePortMatched', 'type': 'bool'}, + 'destination_matched': {'key': 'destinationMatched', 'type': 'bool'}, + 'destination_port_matched': {'key': 'destinationPortMatched', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + protocol_matched: Optional[bool] = None, + source_matched: Optional[bool] = None, + source_port_matched: Optional[bool] = None, + destination_matched: Optional[bool] = None, + destination_port_matched: Optional[bool] = None, + **kwargs + ): + super(NetworkSecurityRulesEvaluationResult, self).__init__(**kwargs) + self.name = name + self.protocol_matched = protocol_matched + self.source_matched = source_matched + self.source_port_matched = source_port_matched + self.destination_matched = destination_matched + self.destination_port_matched = destination_port_matched + + +class NetworkVirtualAppliance(Resource): + """NetworkVirtualAppliance Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 identity: The service principal that has read access to cloud-init and config blob. + :type identity: ~azure.mgmt.network.v2020_08_01.models.ManagedServiceIdentity + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param nva_sku: Network Virtual Appliance SKU. + :type nva_sku: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSkuProperties + :ivar address_prefix: Address Prefix. + :vartype address_prefix: str + :param boot_strap_configuration_blobs: BootStrapConfigurationBlobs storage URLs. + :type boot_strap_configuration_blobs: list[str] + :param virtual_hub: The Virtual Hub where Network Virtual Appliance is being deployed. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param cloud_init_configuration_blobs: CloudInitConfigurationBlob storage URLs. + :type cloud_init_configuration_blobs: list[str] + :param cloud_init_configuration: CloudInitConfiguration string in plain text. + :type cloud_init_configuration: str + :param virtual_appliance_asn: VirtualAppliance ASN. + :type virtual_appliance_asn: long + :ivar virtual_appliance_nics: List of Virtual Appliance Network Interfaces. + :vartype virtual_appliance_nics: + list[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceNicProperties] + :ivar virtual_appliance_sites: List of references to VirtualApplianceSite. + :vartype virtual_appliance_sites: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar inbound_security_rules: List of references to InboundSecurityRules. + :vartype inbound_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'address_prefix': {'readonly': True}, + 'virtual_appliance_asn': {'maximum': 4294967295, 'minimum': 0}, + 'virtual_appliance_nics': {'readonly': True}, + 'virtual_appliance_sites': {'readonly': True}, + 'inbound_security_rules': {'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}'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'nva_sku': {'key': 'properties.nvaSku', 'type': 'VirtualApplianceSkuProperties'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'boot_strap_configuration_blobs': {'key': 'properties.bootStrapConfigurationBlobs', 'type': '[str]'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'cloud_init_configuration_blobs': {'key': 'properties.cloudInitConfigurationBlobs', 'type': '[str]'}, + 'cloud_init_configuration': {'key': 'properties.cloudInitConfiguration', 'type': 'str'}, + 'virtual_appliance_asn': {'key': 'properties.virtualApplianceAsn', 'type': 'long'}, + 'virtual_appliance_nics': {'key': 'properties.virtualApplianceNics', 'type': '[VirtualApplianceNicProperties]'}, + 'virtual_appliance_sites': {'key': 'properties.virtualApplianceSites', 'type': '[SubResource]'}, + 'inbound_security_rules': {'key': 'properties.inboundSecurityRules', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + nva_sku: Optional["VirtualApplianceSkuProperties"] = None, + boot_strap_configuration_blobs: Optional[List[str]] = None, + virtual_hub: Optional["SubResource"] = None, + cloud_init_configuration_blobs: Optional[List[str]] = None, + cloud_init_configuration: Optional[str] = None, + virtual_appliance_asn: Optional[int] = None, + **kwargs + ): + super(NetworkVirtualAppliance, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.identity = identity + self.etag = None + self.nva_sku = nva_sku + self.address_prefix = None + self.boot_strap_configuration_blobs = boot_strap_configuration_blobs + self.virtual_hub = virtual_hub + self.cloud_init_configuration_blobs = cloud_init_configuration_blobs + self.cloud_init_configuration = cloud_init_configuration + self.virtual_appliance_asn = virtual_appliance_asn + self.virtual_appliance_nics = None + self.virtual_appliance_sites = None + self.inbound_security_rules = None + self.provisioning_state = None + + +class NetworkVirtualApplianceListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualAppliances API service call. + + :param value: List of Network Virtual Appliances. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkVirtualAppliance]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkVirtualAppliance"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NetworkVirtualApplianceListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NetworkVirtualApplianceSiteListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualApplianceSites API service call. + + :param value: List of Network Virtual Appliance sites. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualApplianceSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualApplianceSite"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NetworkVirtualApplianceSiteListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NetworkVirtualApplianceSku(Resource): + """Definition of the NetworkVirtualApplianceSkus resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar vendor: Network Virtual Appliance Sku vendor. + :vartype vendor: str + :ivar available_versions: Available Network Virtual Appliance versions. + :vartype available_versions: list[str] + :param available_scale_units: The list of scale units available. + :type available_scale_units: + list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSkuInstances] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'vendor': {'readonly': True}, + 'available_versions': {'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'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'available_versions': {'key': 'properties.availableVersions', 'type': '[str]'}, + 'available_scale_units': {'key': 'properties.availableScaleUnits', 'type': '[NetworkVirtualApplianceSkuInstances]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + available_scale_units: Optional[List["NetworkVirtualApplianceSkuInstances"]] = None, + **kwargs + ): + super(NetworkVirtualApplianceSku, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.vendor = None + self.available_versions = None + self.available_scale_units = available_scale_units + + +class NetworkVirtualApplianceSkuInstances(msrest.serialization.Model): + """List of available Sku and instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar scale_unit: Scale Unit. + :vartype scale_unit: str + :ivar instance_count: Instance Count. + :vartype instance_count: int + """ + + _validation = { + 'scale_unit': {'readonly': True}, + 'instance_count': {'readonly': True}, + } + + _attribute_map = { + 'scale_unit': {'key': 'scaleUnit', 'type': 'str'}, + 'instance_count': {'key': 'instanceCount', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkVirtualApplianceSkuInstances, self).__init__(**kwargs) + self.scale_unit = None + self.instance_count = None + + +class NetworkVirtualApplianceSkuListResult(msrest.serialization.Model): + """Response for ListNetworkVirtualApplianceSkus API service call. + + :param value: List of Network Virtual Appliance Skus that are available. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSku] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkVirtualApplianceSku]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkVirtualApplianceSku"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NetworkVirtualApplianceSkuListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NetworkWatcher(Resource): + """Network watcher in a resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the network watcher resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(NetworkWatcher, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.provisioning_state = None + + +class NetworkWatcherListResult(msrest.serialization.Model): + """Response for ListNetworkWatchers API service call. + + :param value: List of network watcher resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.NetworkWatcher] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NetworkWatcher]'}, + } + + def __init__( + self, + *, + value: Optional[List["NetworkWatcher"]] = None, + **kwargs + ): + super(NetworkWatcherListResult, self).__init__(**kwargs) + self.value = value + + +class NextHopParameters(msrest.serialization.Model): + """Parameters that define the source and destination endpoint. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The resource identifier of the target resource against + which the action is to be performed. + :type target_resource_id: str + :param source_ip_address: Required. The source IP address. + :type source_ip_address: str + :param destination_ip_address: Required. The destination IP address. + :type destination_ip_address: str + :param target_nic_resource_id: The NIC ID. (If VM has multiple NICs and IP forwarding is + enabled on any of the nics, then this parameter must be specified. Otherwise optional). + :type target_nic_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'source_ip_address': {'required': True}, + 'destination_ip_address': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'source_ip_address': {'key': 'sourceIPAddress', 'type': 'str'}, + 'destination_ip_address': {'key': 'destinationIPAddress', 'type': 'str'}, + 'target_nic_resource_id': {'key': 'targetNicResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + source_ip_address: str, + destination_ip_address: str, + target_nic_resource_id: Optional[str] = None, + **kwargs + ): + super(NextHopParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + self.source_ip_address = source_ip_address + self.destination_ip_address = destination_ip_address + self.target_nic_resource_id = target_nic_resource_id + + +class NextHopResult(msrest.serialization.Model): + """The information about next hop from the specified VM. + + :param next_hop_type: Next hop type. Possible values include: "Internet", "VirtualAppliance", + "VirtualNetworkGateway", "VnetLocal", "HyperNetGateway", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.NextHopType + :param next_hop_ip_address: Next hop IP Address. + :type next_hop_ip_address: str + :param route_table_id: The resource identifier for the route table associated with the route + being returned. If the route being returned does not correspond to any user created routes then + this field will be the string 'System Route'. + :type route_table_id: str + """ + + _attribute_map = { + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + 'route_table_id': {'key': 'routeTableId', 'type': 'str'}, + } + + def __init__( + self, + *, + next_hop_type: Optional[Union[str, "NextHopType"]] = None, + next_hop_ip_address: Optional[str] = None, + route_table_id: Optional[str] = None, + **kwargs + ): + super(NextHopResult, self).__init__(**kwargs) + self.next_hop_type = next_hop_type + self.next_hop_ip_address = next_hop_ip_address + self.route_table_id = route_table_id + + +class O365BreakOutCategoryPolicies(msrest.serialization.Model): + """Office365 breakout categories. + + :param allow: Flag to control allow category. + :type allow: bool + :param optimize: Flag to control optimize category. + :type optimize: bool + :param default: Flag to control default category. + :type default: bool + """ + + _attribute_map = { + 'allow': {'key': 'allow', 'type': 'bool'}, + 'optimize': {'key': 'optimize', 'type': 'bool'}, + 'default': {'key': 'default', 'type': 'bool'}, + } + + def __init__( + self, + *, + allow: Optional[bool] = None, + optimize: Optional[bool] = None, + default: Optional[bool] = None, + **kwargs + ): + super(O365BreakOutCategoryPolicies, self).__init__(**kwargs) + self.allow = allow + self.optimize = optimize + self.default = default + + +class O365PolicyProperties(msrest.serialization.Model): + """The Office365 breakout policy. + + :param break_out_categories: Office365 breakout categories. + :type break_out_categories: ~azure.mgmt.network.v2020_08_01.models.O365BreakOutCategoryPolicies + """ + + _attribute_map = { + 'break_out_categories': {'key': 'breakOutCategories', 'type': 'O365BreakOutCategoryPolicies'}, + } + + def __init__( + self, + *, + break_out_categories: Optional["O365BreakOutCategoryPolicies"] = None, + **kwargs + ): + super(O365PolicyProperties, self).__init__(**kwargs) + self.break_out_categories = break_out_categories + + +class Office365PolicyProperties(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param break_out_categories: Office 365 breakout categories. + :type break_out_categories: ~azure.mgmt.network.v2020_08_01.models.BreakOutCategoryPolicies + """ + + _attribute_map = { + 'break_out_categories': {'key': 'breakOutCategories', 'type': 'BreakOutCategoryPolicies'}, + } + + def __init__( + self, + *, + break_out_categories: Optional["BreakOutCategoryPolicies"] = None, + **kwargs + ): + super(Office365PolicyProperties, self).__init__(**kwargs) + self.break_out_categories = break_out_categories + + +class Operation(msrest.serialization.Model): + """Network REST API operation definition. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: Display metadata associated with the operation. + :type display: ~azure.mgmt.network.v2020_08_01.models.OperationDisplay + :param origin: Origin of the operation. + :type origin: str + :param service_specification: Specification of the service. + :type service_specification: + ~azure.mgmt.network.v2020_08_01.models.OperationPropertiesFormatServiceSpecification + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'service_specification': {'key': 'properties.serviceSpecification', 'type': 'OperationPropertiesFormatServiceSpecification'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional["OperationDisplay"] = None, + origin: Optional[str] = None, + service_specification: Optional["OperationPropertiesFormatServiceSpecification"] = None, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = name + self.display = display + self.origin = origin + self.service_specification = service_specification + + +class OperationDisplay(msrest.serialization.Model): + """Display metadata associated with the operation. + + :param provider: Service provider: Microsoft Network. + :type provider: str + :param resource: Resource on which the operation is performed. + :type resource: str + :param operation: Type of the operation: get, read, 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 Network operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Network operations supported by the Network resource provider. + :type value: list[~azure.mgmt.network.v2020_08_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 OperationPropertiesFormatServiceSpecification(msrest.serialization.Model): + """Specification of the service. + + :param metric_specifications: Operation service specification. + :type metric_specifications: list[~azure.mgmt.network.v2020_08_01.models.MetricSpecification] + :param log_specifications: Operation log specification. + :type log_specifications: list[~azure.mgmt.network.v2020_08_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(OperationPropertiesFormatServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = metric_specifications + self.log_specifications = log_specifications + + +class OutboundRule(SubResource): + """Outbound rule of the load balancer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of outbound rules used by + the load balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param allocated_outbound_ports: The number of outbound ports to be used for NAT. + :type allocated_outbound_ports: int + :param frontend_ip_configurations: The Frontend IP addresses of the load balancer. + :type frontend_ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param backend_address_pool: A reference to a pool of DIPs. Outbound traffic is randomly load + balanced across IPs in the backend IPs. + :type backend_address_pool: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar provisioning_state: The provisioning state of the outbound rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param protocol: The protocol for the outbound rule in load balancer. Possible values include: + "Tcp", "Udp", "All". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.LoadBalancerOutboundRuleProtocol + :param enable_tcp_reset: Receive bidirectional TCP Reset on TCP flow idle timeout or unexpected + connection termination. This element is only used when the protocol is set to TCP. + :type enable_tcp_reset: bool + :param idle_timeout_in_minutes: The timeout for the TCP idle connection. + :type idle_timeout_in_minutes: int + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allocated_outbound_ports': {'key': 'properties.allocatedOutboundPorts', 'type': 'int'}, + 'frontend_ip_configurations': {'key': 'properties.frontendIPConfigurations', 'type': '[SubResource]'}, + 'backend_address_pool': {'key': 'properties.backendAddressPool', 'type': 'SubResource'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'enable_tcp_reset': {'key': 'properties.enableTcpReset', 'type': 'bool'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + allocated_outbound_ports: Optional[int] = None, + frontend_ip_configurations: Optional[List["SubResource"]] = None, + backend_address_pool: Optional["SubResource"] = None, + protocol: Optional[Union[str, "LoadBalancerOutboundRuleProtocol"]] = None, + enable_tcp_reset: Optional[bool] = None, + idle_timeout_in_minutes: Optional[int] = None, + **kwargs + ): + super(OutboundRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.allocated_outbound_ports = allocated_outbound_ports + self.frontend_ip_configurations = frontend_ip_configurations + self.backend_address_pool = backend_address_pool + self.provisioning_state = None + self.protocol = protocol + self.enable_tcp_reset = enable_tcp_reset + self.idle_timeout_in_minutes = idle_timeout_in_minutes + + +class OwaspCrsExclusionEntry(msrest.serialization.Model): + """Allow to exclude some variable satisfy the condition for the WAF check. + + All required parameters must be populated in order to send to Azure. + + :param match_variable: Required. The variable to be excluded. Possible values include: + "RequestHeaderNames", "RequestCookieNames", "RequestArgNames". + :type match_variable: str or + ~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntryMatchVariable + :param selector_match_operator: Required. When matchVariable is a collection, operate on the + selector to specify which elements in the collection this exclusion applies to. Possible values + include: "Equals", "Contains", "StartsWith", "EndsWith", "EqualsAny". + :type selector_match_operator: str or + ~azure.mgmt.network.v2020_08_01.models.OwaspCrsExclusionEntrySelectorMatchOperator + :param selector: Required. When matchVariable is a collection, operator used to specify which + elements in the collection this exclusion applies to. + :type selector: str + """ + + _validation = { + 'match_variable': {'required': True}, + 'selector_match_operator': {'required': True}, + 'selector': {'required': True}, + } + + _attribute_map = { + 'match_variable': {'key': 'matchVariable', 'type': 'str'}, + 'selector_match_operator': {'key': 'selectorMatchOperator', 'type': 'str'}, + 'selector': {'key': 'selector', 'type': 'str'}, + } + + def __init__( + self, + *, + match_variable: Union[str, "OwaspCrsExclusionEntryMatchVariable"], + selector_match_operator: Union[str, "OwaspCrsExclusionEntrySelectorMatchOperator"], + selector: str, + **kwargs + ): + super(OwaspCrsExclusionEntry, self).__init__(**kwargs) + self.match_variable = match_variable + self.selector_match_operator = selector_match_operator + self.selector = selector + + +class P2SConnectionConfiguration(SubResource): + """P2SConnectionConfiguration Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param vpn_client_address_pool: The reference to the address space resource which represents + Address space for P2S VpnClient. + :type vpn_client_address_pool: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + :param enable_internet_security: Flag indicating whether the enable internet security flag is + turned on for the P2S Connections or not. + :type enable_internet_security: bool + :ivar provisioning_state: The provisioning state of the P2SConnectionConfiguration resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'vpn_client_address_pool': {'key': 'properties.vpnClientAddressPool', 'type': 'AddressSpace'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + vpn_client_address_pool: Optional["AddressSpace"] = None, + routing_configuration: Optional["RoutingConfiguration"] = None, + enable_internet_security: Optional[bool] = None, + **kwargs + ): + super(P2SConnectionConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.vpn_client_address_pool = vpn_client_address_pool + self.routing_configuration = routing_configuration + self.enable_internet_security = enable_internet_security + self.provisioning_state = None + + +class P2SVpnConnectionHealth(msrest.serialization.Model): + """P2S Vpn connection detailed health written to sas url. + + :param sas_url: Returned sas url of the blob to which the p2s vpn connection detailed health + will be written. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + **kwargs + ): + super(P2SVpnConnectionHealth, self).__init__(**kwargs) + self.sas_url = sas_url + + +class P2SVpnConnectionHealthRequest(msrest.serialization.Model): + """List of P2S Vpn connection health request. + + :param vpn_user_names_filter: The list of p2s vpn user names whose p2s vpn connection detailed + health to retrieve for. + :type vpn_user_names_filter: list[str] + :param output_blob_sas_url: The sas-url to download the P2S Vpn connection health detail. + :type output_blob_sas_url: str + """ + + _attribute_map = { + 'vpn_user_names_filter': {'key': 'vpnUserNamesFilter', 'type': '[str]'}, + 'output_blob_sas_url': {'key': 'outputBlobSasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + vpn_user_names_filter: Optional[List[str]] = None, + output_blob_sas_url: Optional[str] = None, + **kwargs + ): + super(P2SVpnConnectionHealthRequest, self).__init__(**kwargs) + self.vpn_user_names_filter = vpn_user_names_filter + self.output_blob_sas_url = output_blob_sas_url + + +class P2SVpnConnectionRequest(msrest.serialization.Model): + """List of p2s vpn connections to be disconnected. + + :param vpn_connection_ids: List of p2s vpn connection Ids. + :type vpn_connection_ids: list[str] + """ + + _attribute_map = { + 'vpn_connection_ids': {'key': 'vpnConnectionIds', 'type': '[str]'}, + } + + def __init__( + self, + *, + vpn_connection_ids: Optional[List[str]] = None, + **kwargs + ): + super(P2SVpnConnectionRequest, self).__init__(**kwargs) + self.vpn_connection_ids = vpn_connection_ids + + +class P2SVpnGateway(Resource): + """P2SVpnGateway Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_hub: The VirtualHub to which the gateway belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param p2_s_connection_configurations: List of all p2s connection configurations of the + gateway. + :type p2_s_connection_configurations: + list[~azure.mgmt.network.v2020_08_01.models.P2SConnectionConfiguration] + :ivar provisioning_state: The provisioning state of the P2S VPN gateway resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_gateway_scale_unit: The scale unit for this p2s vpn gateway. + :type vpn_gateway_scale_unit: int + :param vpn_server_configuration: The VpnServerConfiguration to which the p2sVpnGateway is + attached to. + :type vpn_server_configuration: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar vpn_client_connection_health: All P2S VPN clients' connection health status. + :vartype vpn_client_connection_health: + ~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealth + :param custom_dns_servers: List of all customer specified DNS servers IP addresses. + :type custom_dns_servers: list[str] + :param is_routing_preference_internet: Enable Routing Preference property for the Public IP + Interface of the P2SVpnGateway. + :type is_routing_preference_internet: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'vpn_client_connection_health': {'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'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'p2_s_connection_configurations': {'key': 'properties.p2SConnectionConfigurations', 'type': '[P2SConnectionConfiguration]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_gateway_scale_unit': {'key': 'properties.vpnGatewayScaleUnit', 'type': 'int'}, + 'vpn_server_configuration': {'key': 'properties.vpnServerConfiguration', 'type': 'SubResource'}, + 'vpn_client_connection_health': {'key': 'properties.vpnClientConnectionHealth', 'type': 'VpnClientConnectionHealth'}, + 'custom_dns_servers': {'key': 'properties.customDnsServers', 'type': '[str]'}, + 'is_routing_preference_internet': {'key': 'properties.isRoutingPreferenceInternet', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + virtual_hub: Optional["SubResource"] = None, + p2_s_connection_configurations: Optional[List["P2SConnectionConfiguration"]] = None, + vpn_gateway_scale_unit: Optional[int] = None, + vpn_server_configuration: Optional["SubResource"] = None, + custom_dns_servers: Optional[List[str]] = None, + is_routing_preference_internet: Optional[bool] = None, + **kwargs + ): + super(P2SVpnGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.virtual_hub = virtual_hub + self.p2_s_connection_configurations = p2_s_connection_configurations + self.provisioning_state = None + self.vpn_gateway_scale_unit = vpn_gateway_scale_unit + self.vpn_server_configuration = vpn_server_configuration + self.vpn_client_connection_health = None + self.custom_dns_servers = custom_dns_servers + self.is_routing_preference_internet = is_routing_preference_internet + + +class P2SVpnProfileParameters(msrest.serialization.Model): + """Vpn Client Parameters for package generation. + + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + """ + + _attribute_map = { + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + } + + def __init__( + self, + *, + authentication_method: Optional[Union[str, "AuthenticationMethod"]] = None, + **kwargs + ): + super(P2SVpnProfileParameters, self).__init__(**kwargs) + self.authentication_method = authentication_method + + +class PacketCapture(msrest.serialization.Model): + """Parameters that define the create packet capture operation. + + All required parameters must be populated in order to send to Azure. + + :param target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + } + + _attribute_map = { + 'target': {'key': 'properties.target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'properties.bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'properties.totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'properties.timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'properties.storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'properties.filters', 'type': '[PacketCaptureFilter]'}, + } + + def __init__( + self, + *, + target: str, + storage_location: "PacketCaptureStorageLocation", + bytes_to_capture_per_packet: Optional[int] = 0, + total_bytes_per_session: Optional[int] = 1073741824, + time_limit_in_seconds: Optional[int] = 18000, + filters: Optional[List["PacketCaptureFilter"]] = None, + **kwargs + ): + super(PacketCapture, self).__init__(**kwargs) + self.target = target + self.bytes_to_capture_per_packet = bytes_to_capture_per_packet + self.total_bytes_per_session = total_bytes_per_session + self.time_limit_in_seconds = time_limit_in_seconds + self.storage_location = storage_location + self.filters = filters + + +class PacketCaptureFilter(msrest.serialization.Model): + """Filter that is applied to packet capture request. Multiple filters can be applied. + + :param protocol: Protocol to be filtered on. Possible values include: "TCP", "UDP", "Any". + Default value: "Any". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.PcProtocol + :param local_ip_address: Local IP Address to be filtered on. Notation: "127.0.0.1" for single + address entry. "127.0.0.1-127.0.0.255" for range. "127.0.0.1;127.0.0.5"? for multiple entries. + Multiple ranges not currently supported. Mixing ranges with multiple entries not currently + supported. Default = null. + :type local_ip_address: str + :param remote_ip_address: Local IP Address to be filtered on. Notation: "127.0.0.1" for single + address entry. "127.0.0.1-127.0.0.255" for range. "127.0.0.1;127.0.0.5;" for multiple entries. + Multiple ranges not currently supported. Mixing ranges with multiple entries not currently + supported. Default = null. + :type remote_ip_address: str + :param local_port: Local port to be filtered on. Notation: "80" for single port entry."80-85" + for range. "80;443;" for multiple entries. Multiple ranges not currently supported. Mixing + ranges with multiple entries not currently supported. Default = null. + :type local_port: str + :param remote_port: Remote port to be filtered on. Notation: "80" for single port entry."80-85" + for range. "80;443;" for multiple entries. Multiple ranges not currently supported. Mixing + ranges with multiple entries not currently supported. Default = null. + :type remote_port: str + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'local_ip_address': {'key': 'localIPAddress', 'type': 'str'}, + 'remote_ip_address': {'key': 'remoteIPAddress', 'type': 'str'}, + 'local_port': {'key': 'localPort', 'type': 'str'}, + 'remote_port': {'key': 'remotePort', 'type': 'str'}, + } + + def __init__( + self, + *, + protocol: Optional[Union[str, "PcProtocol"]] = "Any", + local_ip_address: Optional[str] = None, + remote_ip_address: Optional[str] = None, + local_port: Optional[str] = None, + remote_port: Optional[str] = None, + **kwargs + ): + super(PacketCaptureFilter, self).__init__(**kwargs) + self.protocol = protocol + self.local_ip_address = local_ip_address + self.remote_ip_address = remote_ip_address + self.local_port = local_port + self.remote_port = remote_port + + +class PacketCaptureListResult(msrest.serialization.Model): + """List of packet capture sessions. + + :param value: Information about packet capture sessions. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PacketCaptureResult]'}, + } + + def __init__( + self, + *, + value: Optional[List["PacketCaptureResult"]] = None, + **kwargs + ): + super(PacketCaptureListResult, self).__init__(**kwargs) + self.value = value + + +class PacketCaptureParameters(msrest.serialization.Model): + """Parameters that define the create packet capture operation. + + All required parameters must be populated in order to send to Azure. + + :param target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + } + + _attribute_map = { + 'target': {'key': 'target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'filters', 'type': '[PacketCaptureFilter]'}, + } + + def __init__( + self, + *, + target: str, + storage_location: "PacketCaptureStorageLocation", + bytes_to_capture_per_packet: Optional[int] = 0, + total_bytes_per_session: Optional[int] = 1073741824, + time_limit_in_seconds: Optional[int] = 18000, + filters: Optional[List["PacketCaptureFilter"]] = None, + **kwargs + ): + super(PacketCaptureParameters, self).__init__(**kwargs) + self.target = target + self.bytes_to_capture_per_packet = bytes_to_capture_per_packet + self.total_bytes_per_session = total_bytes_per_session + self.time_limit_in_seconds = time_limit_in_seconds + self.storage_location = storage_location + self.filters = filters + + +class PacketCaptureQueryStatusResult(msrest.serialization.Model): + """Status of packet capture session. + + :param name: The name of the packet capture resource. + :type name: str + :param id: The ID of the packet capture resource. + :type id: str + :param capture_start_time: The start time of the packet capture session. + :type capture_start_time: ~datetime.datetime + :param packet_capture_status: The status of the packet capture session. Possible values + include: "NotStarted", "Running", "Stopped", "Error", "Unknown". + :type packet_capture_status: str or ~azure.mgmt.network.v2020_08_01.models.PcStatus + :param stop_reason: The reason the current packet capture session was stopped. + :type stop_reason: str + :param packet_capture_error: List of errors of packet capture session. + :type packet_capture_error: list[str or ~azure.mgmt.network.v2020_08_01.models.PcError] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'capture_start_time': {'key': 'captureStartTime', 'type': 'iso-8601'}, + 'packet_capture_status': {'key': 'packetCaptureStatus', 'type': 'str'}, + 'stop_reason': {'key': 'stopReason', 'type': 'str'}, + 'packet_capture_error': {'key': 'packetCaptureError', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + id: Optional[str] = None, + capture_start_time: Optional[datetime.datetime] = None, + packet_capture_status: Optional[Union[str, "PcStatus"]] = None, + stop_reason: Optional[str] = None, + packet_capture_error: Optional[List[Union[str, "PcError"]]] = None, + **kwargs + ): + super(PacketCaptureQueryStatusResult, self).__init__(**kwargs) + self.name = name + self.id = id + self.capture_start_time = capture_start_time + self.packet_capture_status = packet_capture_status + self.stop_reason = stop_reason + self.packet_capture_error = packet_capture_error + + +class PacketCaptureResult(msrest.serialization.Model): + """Information about packet capture session. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: Name of the packet capture session. + :vartype name: str + :ivar id: ID of the packet capture operation. + :vartype id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param target: The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + :ivar provisioning_state: The provisioning state of the packet capture session. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'etag': {'readonly': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'target': {'key': 'properties.target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'properties.bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'properties.totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'properties.timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'properties.storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'properties.filters', 'type': '[PacketCaptureFilter]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + target: Optional[str] = None, + bytes_to_capture_per_packet: Optional[int] = 0, + total_bytes_per_session: Optional[int] = 1073741824, + time_limit_in_seconds: Optional[int] = 18000, + storage_location: Optional["PacketCaptureStorageLocation"] = None, + filters: Optional[List["PacketCaptureFilter"]] = None, + **kwargs + ): + super(PacketCaptureResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.etag = None + self.target = target + self.bytes_to_capture_per_packet = bytes_to_capture_per_packet + self.total_bytes_per_session = total_bytes_per_session + self.time_limit_in_seconds = time_limit_in_seconds + self.storage_location = storage_location + self.filters = filters + self.provisioning_state = None + + +class PacketCaptureResultProperties(PacketCaptureParameters): + """The properties of a packet capture session. + + Variables are only 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 target: Required. The ID of the targeted resource, only VM is currently supported. + :type target: str + :param bytes_to_capture_per_packet: Number of bytes captured per packet, the remaining bytes + are truncated. + :type bytes_to_capture_per_packet: long + :param total_bytes_per_session: Maximum size of the capture output. + :type total_bytes_per_session: long + :param time_limit_in_seconds: Maximum duration of the capture session in seconds. + :type time_limit_in_seconds: int + :param storage_location: Required. The storage location for a packet capture session. + :type storage_location: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureStorageLocation + :param filters: A list of packet capture filters. + :type filters: list[~azure.mgmt.network.v2020_08_01.models.PacketCaptureFilter] + :ivar provisioning_state: The provisioning state of the packet capture session. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'target': {'required': True}, + 'bytes_to_capture_per_packet': {'maximum': 4294967295, 'minimum': 0}, + 'total_bytes_per_session': {'maximum': 4294967295, 'minimum': 0}, + 'time_limit_in_seconds': {'maximum': 18000, 'minimum': 0}, + 'storage_location': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'target': {'key': 'target', 'type': 'str'}, + 'bytes_to_capture_per_packet': {'key': 'bytesToCapturePerPacket', 'type': 'long'}, + 'total_bytes_per_session': {'key': 'totalBytesPerSession', 'type': 'long'}, + 'time_limit_in_seconds': {'key': 'timeLimitInSeconds', 'type': 'int'}, + 'storage_location': {'key': 'storageLocation', 'type': 'PacketCaptureStorageLocation'}, + 'filters': {'key': 'filters', 'type': '[PacketCaptureFilter]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + target: str, + storage_location: "PacketCaptureStorageLocation", + bytes_to_capture_per_packet: Optional[int] = 0, + total_bytes_per_session: Optional[int] = 1073741824, + time_limit_in_seconds: Optional[int] = 18000, + filters: Optional[List["PacketCaptureFilter"]] = None, + **kwargs + ): + super(PacketCaptureResultProperties, self).__init__(target=target, bytes_to_capture_per_packet=bytes_to_capture_per_packet, total_bytes_per_session=total_bytes_per_session, time_limit_in_seconds=time_limit_in_seconds, storage_location=storage_location, filters=filters, **kwargs) + self.provisioning_state = None + + +class PacketCaptureStorageLocation(msrest.serialization.Model): + """The storage location for a packet capture session. + + :param storage_id: The ID of the storage account to save the packet capture session. Required + if no local file path is provided. + :type storage_id: str + :param storage_path: The URI of the storage path to save the packet capture. Must be a well- + formed URI describing the location to save the packet capture. + :type storage_path: str + :param file_path: A valid local path on the targeting VM. Must include the name of the capture + file (*.cap). For linux virtual machine it must start with /var/captures. Required if no + storage ID is provided, otherwise optional. + :type file_path: str + """ + + _attribute_map = { + 'storage_id': {'key': 'storageId', 'type': 'str'}, + 'storage_path': {'key': 'storagePath', 'type': 'str'}, + 'file_path': {'key': 'filePath', 'type': 'str'}, + } + + def __init__( + self, + *, + storage_id: Optional[str] = None, + storage_path: Optional[str] = None, + file_path: Optional[str] = None, + **kwargs + ): + super(PacketCaptureStorageLocation, self).__init__(**kwargs) + self.storage_id = storage_id + self.storage_path = storage_path + self.file_path = file_path + + +class PatchRouteFilter(SubResource): + """Route Filter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :vartype name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param rules: Collection of RouteFilterRules contained within a route filter. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :ivar peerings: A collection of references to express route circuit peerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar ipv6_peerings: A collection of references to express route circuit ipv6 peerings. + :vartype ipv6_peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar provisioning_state: The provisioning state of the route filter resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peerings': {'readonly': True}, + 'ipv6_peerings': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'rules': {'key': 'properties.rules', 'type': '[RouteFilterRule]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'ipv6_peerings': {'key': 'properties.ipv6Peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + rules: Optional[List["RouteFilterRule"]] = None, + **kwargs + ): + super(PatchRouteFilter, self).__init__(id=id, **kwargs) + self.name = None + self.etag = None + self.type = None + self.tags = tags + self.rules = rules + self.peerings = None + self.ipv6_peerings = None + self.provisioning_state = None + + +class PatchRouteFilterRule(SubResource): + """Route Filter Rule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :vartype name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param access: The access type of the rule. Possible values include: "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param route_filter_rule_type: The rule type of the rule. Possible values include: "Community". + :type route_filter_rule_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleType + :param communities: The collection for bgp community values to filter on. e.g. + ['12076:5010','12076:5020']. + :type communities: list[str] + :ivar provisioning_state: The provisioning state of the route filter rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'route_filter_rule_type': {'key': 'properties.routeFilterRuleType', 'type': 'str'}, + 'communities': {'key': 'properties.communities', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + access: Optional[Union[str, "Access"]] = None, + route_filter_rule_type: Optional[Union[str, "RouteFilterRuleType"]] = None, + communities: Optional[List[str]] = None, + **kwargs + ): + super(PatchRouteFilterRule, self).__init__(id=id, **kwargs) + self.name = None + self.etag = None + self.access = access + self.route_filter_rule_type = route_filter_rule_type + self.communities = communities + self.provisioning_state = None + + +class PeerExpressRouteCircuitConnection(SubResource): + """Peer Express Route Circuit Connection in an ExpressRouteCircuitPeering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :param express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the circuit. + :type express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param peer_express_route_circuit_peering: Reference to Express Route Circuit Private Peering + Resource of the peered circuit. + :type peer_express_route_circuit_peering: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: /29 IP address space to carve out Customer addresses for tunnels. + :type address_prefix: str + :ivar circuit_connection_status: Express Route Circuit connection state. Possible values + include: "Connected", "Connecting", "Disconnected". + :vartype circuit_connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.CircuitConnectionStatus + :param connection_name: The name of the express route circuit connection resource. + :type connection_name: str + :param auth_resource_guid: The resource guid of the authorization used for the express route + circuit connection. + :type auth_resource_guid: str + :ivar provisioning_state: The provisioning state of the peer express route circuit connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'circuit_connection_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'express_route_circuit_peering': {'key': 'properties.expressRouteCircuitPeering', 'type': 'SubResource'}, + 'peer_express_route_circuit_peering': {'key': 'properties.peerExpressRouteCircuitPeering', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'circuit_connection_status': {'key': 'properties.circuitConnectionStatus', 'type': 'str'}, + 'connection_name': {'key': 'properties.connectionName', 'type': 'str'}, + 'auth_resource_guid': {'key': 'properties.authResourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + express_route_circuit_peering: Optional["SubResource"] = None, + peer_express_route_circuit_peering: Optional["SubResource"] = None, + address_prefix: Optional[str] = None, + connection_name: Optional[str] = None, + auth_resource_guid: Optional[str] = None, + **kwargs + ): + super(PeerExpressRouteCircuitConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.express_route_circuit_peering = express_route_circuit_peering + self.peer_express_route_circuit_peering = peer_express_route_circuit_peering + self.address_prefix = address_prefix + self.circuit_connection_status = None + self.connection_name = connection_name + self.auth_resource_guid = auth_resource_guid + self.provisioning_state = None + + +class PeerExpressRouteCircuitConnectionListResult(msrest.serialization.Model): + """Response for ListPeeredConnections API service call retrieves all global reach peer circuit connections that belongs to a Private Peering for an ExpressRouteCircuit. + + :param value: The global reach peer circuit connection associated with Private Peering in an + ExpressRoute Circuit. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PeerExpressRouteCircuitConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PeerExpressRouteCircuitConnection"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PeerExpressRouteCircuitConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class PeerRoute(msrest.serialization.Model): + """Peer routing details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar local_address: The peer's local address. + :vartype local_address: str + :ivar network: The route's network prefix. + :vartype network: str + :ivar next_hop: The route's next hop. + :vartype next_hop: str + :ivar source_peer: The peer this route was learned from. + :vartype source_peer: str + :ivar origin: The source this route was learned from. + :vartype origin: str + :ivar as_path: The route's AS path sequence. + :vartype as_path: str + :ivar weight: The route's weight. + :vartype weight: int + """ + + _validation = { + 'local_address': {'readonly': True}, + 'network': {'readonly': True}, + 'next_hop': {'readonly': True}, + 'source_peer': {'readonly': True}, + 'origin': {'readonly': True}, + 'as_path': {'readonly': True}, + 'weight': {'readonly': True}, + } + + _attribute_map = { + 'local_address': {'key': 'localAddress', 'type': 'str'}, + 'network': {'key': 'network', 'type': 'str'}, + 'next_hop': {'key': 'nextHop', 'type': 'str'}, + 'source_peer': {'key': 'sourcePeer', 'type': 'str'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PeerRoute, self).__init__(**kwargs) + self.local_address = None + self.network = None + self.next_hop = None + self.source_peer = None + self.origin = None + self.as_path = None + self.weight = None + + +class PeerRouteList(msrest.serialization.Model): + """List of virtual router peer routes. + + :param value: List of peer routes. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PeerRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PeerRoute]'}, + } + + def __init__( + self, + *, + value: Optional[List["PeerRoute"]] = None, + **kwargs + ): + super(PeerRouteList, self).__init__(**kwargs) + self.value = value + + +class PolicySettings(msrest.serialization.Model): + """Defines contents of a web application firewall global configuration. + + :param state: The state of the policy. Possible values include: "Disabled", "Enabled". + :type state: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallEnabledState + :param mode: The mode of the policy. Possible values include: "Prevention", "Detection". + :type mode: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallMode + :param request_body_check: Whether to allow WAF to check request Body. + :type request_body_check: bool + :param max_request_body_size_in_kb: Maximum request body size in Kb for WAF. + :type max_request_body_size_in_kb: int + :param file_upload_limit_in_mb: Maximum file upload size in Mb for WAF. + :type file_upload_limit_in_mb: int + """ + + _validation = { + 'max_request_body_size_in_kb': {'maximum': 128, 'minimum': 8}, + 'file_upload_limit_in_mb': {'minimum': 0}, + } + + _attribute_map = { + 'state': {'key': 'state', 'type': 'str'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'request_body_check': {'key': 'requestBodyCheck', 'type': 'bool'}, + 'max_request_body_size_in_kb': {'key': 'maxRequestBodySizeInKb', 'type': 'int'}, + 'file_upload_limit_in_mb': {'key': 'fileUploadLimitInMb', 'type': 'int'}, + } + + def __init__( + self, + *, + state: Optional[Union[str, "WebApplicationFirewallEnabledState"]] = None, + mode: Optional[Union[str, "WebApplicationFirewallMode"]] = None, + request_body_check: Optional[bool] = None, + max_request_body_size_in_kb: Optional[int] = None, + file_upload_limit_in_mb: Optional[int] = None, + **kwargs + ): + super(PolicySettings, self).__init__(**kwargs) + self.state = state + self.mode = mode + self.request_body_check = request_body_check + self.max_request_body_size_in_kb = max_request_body_size_in_kb + self.file_upload_limit_in_mb = file_upload_limit_in_mb + + +class PrepareNetworkPoliciesRequest(msrest.serialization.Model): + """Details of PrepareNetworkPolicies for Subnet. + + :param service_name: The name of the service for which subnet is being prepared for. + :type service_name: str + :param network_intent_policy_configurations: A list of NetworkIntentPolicyConfiguration. + :type network_intent_policy_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkIntentPolicyConfiguration] + """ + + _attribute_map = { + 'service_name': {'key': 'serviceName', 'type': 'str'}, + 'network_intent_policy_configurations': {'key': 'networkIntentPolicyConfigurations', 'type': '[NetworkIntentPolicyConfiguration]'}, + } + + def __init__( + self, + *, + service_name: Optional[str] = None, + network_intent_policy_configurations: Optional[List["NetworkIntentPolicyConfiguration"]] = None, + **kwargs + ): + super(PrepareNetworkPoliciesRequest, self).__init__(**kwargs) + self.service_name = service_name + self.network_intent_policy_configurations = network_intent_policy_configurations + + +class PrivateDnsZoneConfig(msrest.serialization.Model): + """PrivateDnsZoneConfig resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :param private_dns_zone_id: The resource id of the private dns zone. + :type private_dns_zone_id: str + :ivar record_sets: A collection of information regarding a recordSet, holding information to + identify private resources. + :vartype record_sets: list[~azure.mgmt.network.v2020_08_01.models.RecordSet] + """ + + _validation = { + 'record_sets': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'private_dns_zone_id': {'key': 'properties.privateDnsZoneId', 'type': 'str'}, + 'record_sets': {'key': 'properties.recordSets', 'type': '[RecordSet]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + private_dns_zone_id: Optional[str] = None, + **kwargs + ): + super(PrivateDnsZoneConfig, self).__init__(**kwargs) + self.name = name + self.private_dns_zone_id = private_dns_zone_id + self.record_sets = None + + +class PrivateDnsZoneGroup(SubResource): + """Private dns zone group resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the private dns zone group resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_dns_zone_configs: A collection of private dns zone configurations of the private + dns zone group. + :type private_dns_zone_configs: + list[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneConfig] + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_dns_zone_configs': {'key': 'properties.privateDnsZoneConfigs', 'type': '[PrivateDnsZoneConfig]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_dns_zone_configs: Optional[List["PrivateDnsZoneConfig"]] = None, + **kwargs + ): + super(PrivateDnsZoneGroup, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.provisioning_state = None + self.private_dns_zone_configs = private_dns_zone_configs + + +class PrivateDnsZoneGroupListResult(msrest.serialization.Model): + """Response for the ListPrivateDnsZoneGroups API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of private dns zone group resources in a private endpoint. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateDnsZoneGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PrivateDnsZoneGroup"]] = None, + **kwargs + ): + super(PrivateDnsZoneGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PrivateEndpoint(Resource): + """Private endpoint resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param subnet: The ID of the subnet from which the private IP will be allocated. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :ivar network_interfaces: An array of references to the network interfaces created for this + private endpoint. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar provisioning_state: The provisioning state of the private endpoint resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_link_service_connections: A grouping of information about the connection to the + remote resource. + :type private_link_service_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnection] + :param manual_private_link_service_connections: A grouping of information about the connection + to the remote resource. Used when the network admin does not have access to approve connections + to the remote resource. + :type manual_private_link_service_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnection] + :param custom_dns_configs: An array of custom dns configurations. + :type custom_dns_configs: + list[~azure.mgmt.network.v2020_08_01.models.CustomDnsConfigPropertiesFormat] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interfaces': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_service_connections': {'key': 'properties.privateLinkServiceConnections', 'type': '[PrivateLinkServiceConnection]'}, + 'manual_private_link_service_connections': {'key': 'properties.manualPrivateLinkServiceConnections', 'type': '[PrivateLinkServiceConnection]'}, + 'custom_dns_configs': {'key': 'properties.customDnsConfigs', 'type': '[CustomDnsConfigPropertiesFormat]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + subnet: Optional["Subnet"] = None, + private_link_service_connections: Optional[List["PrivateLinkServiceConnection"]] = None, + manual_private_link_service_connections: Optional[List["PrivateLinkServiceConnection"]] = None, + custom_dns_configs: Optional[List["CustomDnsConfigPropertiesFormat"]] = None, + **kwargs + ): + super(PrivateEndpoint, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.etag = None + self.subnet = subnet + self.network_interfaces = None + self.provisioning_state = None + self.private_link_service_connections = private_link_service_connections + self.manual_private_link_service_connections = manual_private_link_service_connections + self.custom_dns_configs = custom_dns_configs + + +class PrivateEndpointConnection(SubResource): + """PrivateEndpointConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: The resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar private_endpoint: The resource of private end point. + :vartype private_endpoint: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :param private_link_service_connection_state: A collection of information about the state of + the connection between service consumer and provider. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + :ivar provisioning_state: The provisioning state of the private endpoint connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar link_identifier: The consumer link id. + :vartype link_identifier: str + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'private_endpoint': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'link_identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'PrivateEndpoint'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'link_identifier': {'key': 'properties.linkIdentifier', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_link_service_connection_state: Optional["PrivateLinkServiceConnectionState"] = None, + **kwargs + ): + super(PrivateEndpointConnection, self).__init__(id=id, **kwargs) + self.name = name + self.type = None + self.etag = None + self.private_endpoint = None + self.private_link_service_connection_state = private_link_service_connection_state + self.provisioning_state = None + self.link_identifier = None + + +class PrivateEndpointConnectionListResult(msrest.serialization.Model): + """Response for the ListPrivateEndpointConnection API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of PrivateEndpointConnection resources for a specific private link + service. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateEndpointConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PrivateEndpointConnection"]] = None, + **kwargs + ): + super(PrivateEndpointConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PrivateEndpointListResult(msrest.serialization.Model): + """Response for the ListPrivateEndpoints API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of private endpoint resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PrivateEndpoint"]] = None, + **kwargs + ): + super(PrivateEndpointListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PrivateLinkService(Resource): + """Private link service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the load balancer. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param load_balancer_frontend_ip_configurations: An array of references to the load balancer IP + configurations. + :type load_balancer_frontend_ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration] + :param ip_configurations: An array of private link service IP configurations. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceIpConfiguration] + :ivar network_interfaces: An array of references to the network interfaces created for this + private link service. + :vartype network_interfaces: list[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :ivar provisioning_state: The provisioning state of the private link service resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar private_endpoint_connections: An array of list about connections to the private endpoint. + :vartype private_endpoint_connections: + list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection] + :param visibility: The visibility list of the private link service. + :type visibility: ~azure.mgmt.network.v2020_08_01.models.ResourceSet + :param auto_approval: The auto-approval list of the private link service. + :type auto_approval: ~azure.mgmt.network.v2020_08_01.models.ResourceSet + :param fqdns: The list of Fqdn. + :type fqdns: list[str] + :ivar alias: The alias of the private link service. + :vartype alias: str + :param enable_proxy_protocol: Whether the private link service is enabled for proxy protocol or + not. + :type enable_proxy_protocol: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interfaces': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'private_endpoint_connections': {'readonly': True}, + 'alias': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'load_balancer_frontend_ip_configurations': {'key': 'properties.loadBalancerFrontendIpConfigurations', 'type': '[FrontendIPConfiguration]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[PrivateLinkServiceIpConfiguration]'}, + 'network_interfaces': {'key': 'properties.networkInterfaces', 'type': '[NetworkInterface]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint_connections': {'key': 'properties.privateEndpointConnections', 'type': '[PrivateEndpointConnection]'}, + 'visibility': {'key': 'properties.visibility', 'type': 'ResourceSet'}, + 'auto_approval': {'key': 'properties.autoApproval', 'type': 'ResourceSet'}, + 'fqdns': {'key': 'properties.fqdns', 'type': '[str]'}, + 'alias': {'key': 'properties.alias', 'type': 'str'}, + 'enable_proxy_protocol': {'key': 'properties.enableProxyProtocol', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + load_balancer_frontend_ip_configurations: Optional[List["FrontendIPConfiguration"]] = None, + ip_configurations: Optional[List["PrivateLinkServiceIpConfiguration"]] = None, + visibility: Optional["ResourceSet"] = None, + auto_approval: Optional["ResourceSet"] = None, + fqdns: Optional[List[str]] = None, + enable_proxy_protocol: Optional[bool] = None, + **kwargs + ): + super(PrivateLinkService, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.etag = None + self.load_balancer_frontend_ip_configurations = load_balancer_frontend_ip_configurations + self.ip_configurations = ip_configurations + self.network_interfaces = None + self.provisioning_state = None + self.private_endpoint_connections = None + self.visibility = visibility + self.auto_approval = auto_approval + self.fqdns = fqdns + self.alias = None + self.enable_proxy_protocol = enable_proxy_protocol + + +class PrivateLinkServiceConnection(SubResource): + """PrivateLinkServiceConnection resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: The resource type. + :vartype type: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the private link service connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_link_service_id: The resource id of private link service. + :type private_link_service_id: str + :param group_ids: The ID(s) of the group(s) obtained from the remote resource that this private + endpoint should connect to. + :type group_ids: list[str] + :param request_message: A message passed to the owner of the remote resource with this + connection request. Restricted to 140 chars. + :type request_message: str + :param private_link_service_connection_state: A collection of read-only information about the + state of the connection to the remote resource. + :type private_link_service_connection_state: + ~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceConnectionState + """ + + _validation = { + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_link_service_id': {'key': 'properties.privateLinkServiceId', 'type': 'str'}, + 'group_ids': {'key': 'properties.groupIds', 'type': '[str]'}, + 'request_message': {'key': 'properties.requestMessage', 'type': 'str'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkServiceConnectionState'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_link_service_id: Optional[str] = None, + group_ids: Optional[List[str]] = None, + request_message: Optional[str] = None, + private_link_service_connection_state: Optional["PrivateLinkServiceConnectionState"] = None, + **kwargs + ): + super(PrivateLinkServiceConnection, self).__init__(id=id, **kwargs) + self.name = name + self.type = None + self.etag = None + self.provisioning_state = None + self.private_link_service_id = private_link_service_id + self.group_ids = group_ids + self.request_message = request_message + self.private_link_service_connection_state = private_link_service_connection_state + + +class PrivateLinkServiceConnectionState(msrest.serialization.Model): + """A collection of information about the state of the connection between service consumer and provider. + + :param status: Indicates whether the connection has been Approved/Rejected/Removed by the owner + of the service. + :type status: str + :param description: The reason for approval/rejection of the connection. + :type description: str + :param actions_required: A message indicating if changes on the service provider require any + updates on the consumer. + :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(PrivateLinkServiceConnectionState, self).__init__(**kwargs) + self.status = status + self.description = description + self.actions_required = actions_required + + +class PrivateLinkServiceIpConfiguration(SubResource): + """The private link service ip configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of private link service ip configuration. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: The resource type. + :vartype type: str + :param private_ip_address: The private IP address of the IP configuration. + :type private_ip_address: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.Subnet + :param primary: Whether the ip configuration is primary or not. + :type primary: bool + :ivar provisioning_state: The provisioning state of the private link service IP configuration + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_ip_address_version: Whether the specific IP configuration is IPv4 or IPv6. + Default is IPv4. Possible values include: "IPv4", "IPv6". + :type private_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'Subnet'}, + 'primary': {'key': 'properties.primary', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_ip_address_version': {'key': 'properties.privateIPAddressVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_address: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["Subnet"] = None, + primary: Optional[bool] = None, + private_ip_address_version: Optional[Union[str, "IPVersion"]] = None, + **kwargs + ): + super(PrivateLinkServiceIpConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.private_ip_address = private_ip_address + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.primary = primary + self.provisioning_state = None + self.private_ip_address_version = private_ip_address_version + + +class PrivateLinkServiceListResult(msrest.serialization.Model): + """Response for the ListPrivateLinkService API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of PrivateLinkService resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PrivateLinkService] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkService]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PrivateLinkService"]] = None, + **kwargs + ): + super(PrivateLinkServiceListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceSet(msrest.serialization.Model): + """The base resource set for visibility and auto-approval. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + *, + subscriptions: Optional[List[str]] = None, + **kwargs + ): + super(ResourceSet, self).__init__(**kwargs) + self.subscriptions = subscriptions + + +class PrivateLinkServicePropertiesAutoApproval(ResourceSet): + """The auto-approval list of the private link service. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + *, + subscriptions: Optional[List[str]] = None, + **kwargs + ): + super(PrivateLinkServicePropertiesAutoApproval, self).__init__(subscriptions=subscriptions, **kwargs) + + +class PrivateLinkServicePropertiesVisibility(ResourceSet): + """The visibility list of the private link service. + + :param subscriptions: The list of subscriptions. + :type subscriptions: list[str] + """ + + _attribute_map = { + 'subscriptions': {'key': 'subscriptions', 'type': '[str]'}, + } + + def __init__( + self, + *, + subscriptions: Optional[List[str]] = None, + **kwargs + ): + super(PrivateLinkServicePropertiesVisibility, self).__init__(subscriptions=subscriptions, **kwargs) + + +class PrivateLinkServiceVisibility(msrest.serialization.Model): + """Response for the CheckPrivateLinkServiceVisibility API service call. + + :param visible: Private Link Service Visibility (True/False). + :type visible: bool + """ + + _attribute_map = { + 'visible': {'key': 'visible', 'type': 'bool'}, + } + + def __init__( + self, + *, + visible: Optional[bool] = None, + **kwargs + ): + super(PrivateLinkServiceVisibility, self).__init__(**kwargs) + self.visible = visible + + +class Probe(SubResource): + """A load balancer probe. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within the set of probes used by the load + balancer. This name can be used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Type of the resource. + :vartype type: str + :ivar load_balancing_rules: The load balancer rules that use this probe. + :vartype load_balancing_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param protocol: The protocol of the end point. If 'Tcp' is specified, a received ACK is + required for the probe to be successful. If 'Http' or 'Https' is specified, a 200 OK response + from the specifies URI is required for the probe to be successful. Possible values include: + "Http", "Tcp", "Https". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.ProbeProtocol + :param port: The port for communicating the probe. Possible values range from 1 to 65535, + inclusive. + :type port: int + :param interval_in_seconds: The interval, in seconds, for how frequently to probe the endpoint + for health status. Typically, the interval is slightly less than half the allocated timeout + period (in seconds) which allows two full probes before taking the instance out of rotation. + The default value is 15, the minimum value is 5. + :type interval_in_seconds: int + :param number_of_probes: The number of probes where if no response, will result in stopping + further traffic from being delivered to the endpoint. This values allows endpoints to be taken + out of rotation faster or slower than the typical times used in Azure. + :type number_of_probes: int + :param request_path: The URI used for requesting health status from the VM. Path is required if + a protocol is set to http. Otherwise, it is not allowed. There is no default value. + :type request_path: str + :ivar provisioning_state: The provisioning state of the probe resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'load_balancing_rules': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[SubResource]'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'interval_in_seconds': {'key': 'properties.intervalInSeconds', 'type': 'int'}, + 'number_of_probes': {'key': 'properties.numberOfProbes', 'type': 'int'}, + 'request_path': {'key': 'properties.requestPath', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + protocol: Optional[Union[str, "ProbeProtocol"]] = None, + port: Optional[int] = None, + interval_in_seconds: Optional[int] = None, + number_of_probes: Optional[int] = None, + request_path: Optional[str] = None, + **kwargs + ): + super(Probe, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.load_balancing_rules = None + self.protocol = protocol + self.port = port + self.interval_in_seconds = interval_in_seconds + self.number_of_probes = number_of_probes + self.request_path = request_path + self.provisioning_state = None + + +class PropagatedRouteTable(msrest.serialization.Model): + """The list of RouteTables to advertise the routes to. + + :param labels: The list of labels. + :type labels: list[str] + :param ids: The list of resource ids of all the RouteTables. + :type ids: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _attribute_map = { + 'labels': {'key': 'labels', 'type': '[str]'}, + 'ids': {'key': 'ids', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + labels: Optional[List[str]] = None, + ids: Optional[List["SubResource"]] = None, + **kwargs + ): + super(PropagatedRouteTable, self).__init__(**kwargs) + self.labels = labels + self.ids = ids + + +class ProtocolConfiguration(msrest.serialization.Model): + """Configuration of the protocol. + + :param http_configuration: HTTP configuration of the connectivity check. + :type http_configuration: ~azure.mgmt.network.v2020_08_01.models.HTTPConfiguration + """ + + _attribute_map = { + 'http_configuration': {'key': 'HTTPConfiguration', 'type': 'HTTPConfiguration'}, + } + + def __init__( + self, + *, + http_configuration: Optional["HTTPConfiguration"] = None, + **kwargs + ): + super(ProtocolConfiguration, self).__init__(**kwargs) + self.http_configuration = http_configuration + + +class ProtocolCustomSettingsFormat(msrest.serialization.Model): + """DDoS custom policy properties. + + :param protocol: The protocol for which the DDoS protection policy is being customized. + Possible values include: "Tcp", "Udp", "Syn". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicyProtocol + :param trigger_rate_override: The customized DDoS protection trigger rate. + :type trigger_rate_override: str + :param source_rate_override: The customized DDoS protection source rate. + :type source_rate_override: str + :param trigger_sensitivity_override: The customized DDoS protection trigger rate sensitivity + degrees. High: Trigger rate set with most sensitivity w.r.t. normal traffic. Default: Trigger + rate set with moderate sensitivity w.r.t. normal traffic. Low: Trigger rate set with less + sensitivity w.r.t. normal traffic. Relaxed: Trigger rate set with least sensitivity w.r.t. + normal traffic. Possible values include: "Relaxed", "Low", "Default", "High". + :type trigger_sensitivity_override: str or + ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicyTriggerSensitivityOverride + """ + + _attribute_map = { + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'trigger_rate_override': {'key': 'triggerRateOverride', 'type': 'str'}, + 'source_rate_override': {'key': 'sourceRateOverride', 'type': 'str'}, + 'trigger_sensitivity_override': {'key': 'triggerSensitivityOverride', 'type': 'str'}, + } + + def __init__( + self, + *, + protocol: Optional[Union[str, "DdosCustomPolicyProtocol"]] = None, + trigger_rate_override: Optional[str] = None, + source_rate_override: Optional[str] = None, + trigger_sensitivity_override: Optional[Union[str, "DdosCustomPolicyTriggerSensitivityOverride"]] = None, + **kwargs + ): + super(ProtocolCustomSettingsFormat, self).__init__(**kwargs) + self.protocol = protocol + self.trigger_rate_override = trigger_rate_override + self.source_rate_override = source_rate_override + self.trigger_sensitivity_override = trigger_sensitivity_override + + +class PublicIPAddress(Resource): + """Public IP address resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the public ip address. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The public IP address SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param public_ip_allocation_method: The public IP address allocation method. Possible values + include: "Static", "Dynamic". + :type public_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param public_ip_address_version: The public IP address version. Possible values include: + "IPv4", "IPv6". + :type public_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :ivar ip_configuration: The IP configuration associated with the public IP address. + :vartype ip_configuration: ~azure.mgmt.network.v2020_08_01.models.IPConfiguration + :param dns_settings: The FQDN of the DNS record associated with the public IP address. + :type dns_settings: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressDnsSettings + :param ddos_settings: The DDoS protection custom policy associated with the public IP address. + :type ddos_settings: ~azure.mgmt.network.v2020_08_01.models.DdosSettings + :param ip_tags: The list of tags associated with the public IP address. + :type ip_tags: list[~azure.mgmt.network.v2020_08_01.models.IpTag] + :param ip_address: The IP address associated with the public IP address resource. + :type ip_address: str + :param public_ip_prefix: The Public IP Prefix this Public IP Address should be allocated from. + :type public_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param idle_timeout_in_minutes: The idle timeout of the public IP address. + :type idle_timeout_in_minutes: int + :ivar resource_guid: The resource GUID property of the public IP address resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the public IP address resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'ip_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'PublicIPAddressSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'public_ip_allocation_method': {'key': 'properties.publicIPAllocationMethod', 'type': 'str'}, + 'public_ip_address_version': {'key': 'properties.publicIPAddressVersion', 'type': 'str'}, + 'ip_configuration': {'key': 'properties.ipConfiguration', 'type': 'IPConfiguration'}, + 'dns_settings': {'key': 'properties.dnsSettings', 'type': 'PublicIPAddressDnsSettings'}, + 'ddos_settings': {'key': 'properties.ddosSettings', 'type': 'DdosSettings'}, + 'ip_tags': {'key': 'properties.ipTags', 'type': '[IpTag]'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'public_ip_prefix': {'key': 'properties.publicIPPrefix', 'type': 'SubResource'}, + 'idle_timeout_in_minutes': {'key': 'properties.idleTimeoutInMinutes', 'type': 'int'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + sku: Optional["PublicIPAddressSku"] = None, + zones: Optional[List[str]] = None, + public_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + public_ip_address_version: Optional[Union[str, "IPVersion"]] = None, + dns_settings: Optional["PublicIPAddressDnsSettings"] = None, + ddos_settings: Optional["DdosSettings"] = None, + ip_tags: Optional[List["IpTag"]] = None, + ip_address: Optional[str] = None, + public_ip_prefix: Optional["SubResource"] = None, + idle_timeout_in_minutes: Optional[int] = None, + **kwargs + ): + super(PublicIPAddress, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.sku = sku + self.etag = None + self.zones = zones + self.public_ip_allocation_method = public_ip_allocation_method + self.public_ip_address_version = public_ip_address_version + self.ip_configuration = None + self.dns_settings = dns_settings + self.ddos_settings = ddos_settings + self.ip_tags = ip_tags + self.ip_address = ip_address + self.public_ip_prefix = public_ip_prefix + self.idle_timeout_in_minutes = idle_timeout_in_minutes + self.resource_guid = None + self.provisioning_state = None + + +class PublicIPAddressDnsSettings(msrest.serialization.Model): + """Contains FQDN of the DNS record associated with the public IP address. + + :param domain_name_label: The domain name label. The concatenation of the domain name label and + the regionalized DNS zone make up the fully qualified domain name associated with the public IP + address. If a domain name label is specified, an A DNS record is created for the public IP in + the Microsoft Azure DNS system. + :type domain_name_label: str + :param fqdn: The Fully Qualified Domain Name of the A DNS record associated with the public IP. + This is the concatenation of the domainNameLabel and the regionalized DNS zone. + :type fqdn: str + :param reverse_fqdn: The reverse FQDN. A user-visible, fully qualified domain name that + resolves to this public IP address. If the reverseFqdn is specified, then a PTR DNS record is + created pointing from the IP address in the in-addr.arpa domain to the reverse FQDN. + :type reverse_fqdn: str + """ + + _attribute_map = { + 'domain_name_label': {'key': 'domainNameLabel', 'type': 'str'}, + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'reverse_fqdn': {'key': 'reverseFqdn', 'type': 'str'}, + } + + def __init__( + self, + *, + domain_name_label: Optional[str] = None, + fqdn: Optional[str] = None, + reverse_fqdn: Optional[str] = None, + **kwargs + ): + super(PublicIPAddressDnsSettings, self).__init__(**kwargs) + self.domain_name_label = domain_name_label + self.fqdn = fqdn + self.reverse_fqdn = reverse_fqdn + + +class PublicIPAddressListResult(msrest.serialization.Model): + """Response for ListPublicIpAddresses API service call. + + :param value: A list of public IP addresses that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PublicIPAddress] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicIPAddress]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PublicIPAddress"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PublicIPAddressListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class PublicIPAddressSku(msrest.serialization.Model): + """SKU of a public IP address. + + :param name: Name of a public IP address SKU. Possible values include: "Basic", "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSkuName + :param tier: Tier of a public IP address SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPAddressSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "PublicIPAddressSkuName"]] = None, + tier: Optional[Union[str, "PublicIPAddressSkuTier"]] = None, + **kwargs + ): + super(PublicIPAddressSku, self).__init__(**kwargs) + self.name = name + self.tier = tier + + +class PublicIPPrefix(Resource): + """Public IP prefix resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the public ip address. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :param sku: The public IP prefix SKU. + :type sku: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSku + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param zones: A list of availability zones denoting the IP allocated for the resource needs to + come from. + :type zones: list[str] + :param public_ip_address_version: The public IP address version. Possible values include: + "IPv4", "IPv6". + :type public_ip_address_version: str or ~azure.mgmt.network.v2020_08_01.models.IPVersion + :param ip_tags: The list of tags associated with the public IP prefix. + :type ip_tags: list[~azure.mgmt.network.v2020_08_01.models.IpTag] + :param prefix_length: The Length of the Public IP Prefix. + :type prefix_length: int + :ivar ip_prefix: The allocated Prefix. + :vartype ip_prefix: str + :ivar public_ip_addresses: The list of all referenced PublicIPAddresses. + :vartype public_ip_addresses: + list[~azure.mgmt.network.v2020_08_01.models.ReferencedPublicIpAddress] + :ivar load_balancer_frontend_ip_configuration: The reference to load balancer frontend IP + configuration associated with the public IP prefix. + :vartype load_balancer_frontend_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.SubResource + :param custom_ip_prefix: The customIpPrefix that this prefix is associated with. + :type custom_ip_prefix: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar resource_guid: The resource GUID property of the public IP prefix resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the public IP prefix resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'ip_prefix': {'readonly': True}, + 'public_ip_addresses': {'readonly': True}, + 'load_balancer_frontend_ip_configuration': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'sku': {'key': 'sku', 'type': 'PublicIPPrefixSku'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'zones': {'key': 'zones', 'type': '[str]'}, + 'public_ip_address_version': {'key': 'properties.publicIPAddressVersion', 'type': 'str'}, + 'ip_tags': {'key': 'properties.ipTags', 'type': '[IpTag]'}, + 'prefix_length': {'key': 'properties.prefixLength', 'type': 'int'}, + 'ip_prefix': {'key': 'properties.ipPrefix', 'type': 'str'}, + 'public_ip_addresses': {'key': 'properties.publicIPAddresses', 'type': '[ReferencedPublicIpAddress]'}, + 'load_balancer_frontend_ip_configuration': {'key': 'properties.loadBalancerFrontendIpConfiguration', 'type': 'SubResource'}, + 'custom_ip_prefix': {'key': 'properties.customIPPrefix', 'type': 'SubResource'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + sku: Optional["PublicIPPrefixSku"] = None, + zones: Optional[List[str]] = None, + public_ip_address_version: Optional[Union[str, "IPVersion"]] = None, + ip_tags: Optional[List["IpTag"]] = None, + prefix_length: Optional[int] = None, + custom_ip_prefix: Optional["SubResource"] = None, + **kwargs + ): + super(PublicIPPrefix, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.sku = sku + self.etag = None + self.zones = zones + self.public_ip_address_version = public_ip_address_version + self.ip_tags = ip_tags + self.prefix_length = prefix_length + self.ip_prefix = None + self.public_ip_addresses = None + self.load_balancer_frontend_ip_configuration = None + self.custom_ip_prefix = custom_ip_prefix + self.resource_guid = None + self.provisioning_state = None + + +class PublicIPPrefixListResult(msrest.serialization.Model): + """Response for ListPublicIpPrefixes API service call. + + :param value: A list of public IP prefixes that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicIPPrefix]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PublicIPPrefix"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PublicIPPrefixListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class PublicIPPrefixSku(msrest.serialization.Model): + """SKU of a public IP prefix. + + :param name: Name of a public IP prefix SKU. Possible values include: "Standard". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSkuName + :param tier: Tier of a public IP prefix SKU. Possible values include: "Regional", "Global". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixSkuTier + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "PublicIPPrefixSkuName"]] = None, + tier: Optional[Union[str, "PublicIPPrefixSkuTier"]] = None, + **kwargs + ): + super(PublicIPPrefixSku, self).__init__(**kwargs) + self.name = name + self.tier = tier + + +class QosIpRange(msrest.serialization.Model): + """Qos Traffic Profiler IP Range properties. + + :param start_ip: Start IP Address. + :type start_ip: str + :param end_ip: End IP Address. + :type end_ip: str + """ + + _attribute_map = { + 'start_ip': {'key': 'startIP', 'type': 'str'}, + 'end_ip': {'key': 'endIP', 'type': 'str'}, + } + + def __init__( + self, + *, + start_ip: Optional[str] = None, + end_ip: Optional[str] = None, + **kwargs + ): + super(QosIpRange, self).__init__(**kwargs) + self.start_ip = start_ip + self.end_ip = end_ip + + +class QosPortRange(msrest.serialization.Model): + """Qos Traffic Profiler Port range properties. + + :param start: Qos Port Range start. + :type start: int + :param end: Qos Port Range end. + :type end: int + """ + + _attribute_map = { + 'start': {'key': 'start', 'type': 'int'}, + 'end': {'key': 'end', 'type': 'int'}, + } + + def __init__( + self, + *, + start: Optional[int] = None, + end: Optional[int] = None, + **kwargs + ): + super(QosPortRange, self).__init__(**kwargs) + self.start = start + self.end = end + + +class QueryTroubleshootingParameters(msrest.serialization.Model): + """Parameters that define the resource to query the troubleshooting result. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource ID to query the troubleshooting + result. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + **kwargs + ): + super(QueryTroubleshootingParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + + +class RadiusServer(msrest.serialization.Model): + """Radius Server Settings. + + All required parameters must be populated in order to send to Azure. + + :param radius_server_address: Required. The address of this radius server. + :type radius_server_address: str + :param radius_server_score: The initial score assigned to this radius server. + :type radius_server_score: long + :param radius_server_secret: The secret used for this radius server. + :type radius_server_secret: str + """ + + _validation = { + 'radius_server_address': {'required': True}, + } + + _attribute_map = { + 'radius_server_address': {'key': 'radiusServerAddress', 'type': 'str'}, + 'radius_server_score': {'key': 'radiusServerScore', 'type': 'long'}, + 'radius_server_secret': {'key': 'radiusServerSecret', 'type': 'str'}, + } + + def __init__( + self, + *, + radius_server_address: str, + radius_server_score: Optional[int] = None, + radius_server_secret: Optional[str] = None, + **kwargs + ): + super(RadiusServer, self).__init__(**kwargs) + self.radius_server_address = radius_server_address + self.radius_server_score = radius_server_score + self.radius_server_secret = radius_server_secret + + +class RecordSet(msrest.serialization.Model): + """A collective group of information about the record set information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param record_type: Resource record type. + :type record_type: str + :param record_set_name: Recordset name. + :type record_set_name: str + :param fqdn: Fqdn that resolves to private endpoint ip address. + :type fqdn: str + :ivar provisioning_state: The provisioning state of the recordset. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ttl: Recordset time to live. + :type ttl: int + :param ip_addresses: The private ip address of the private endpoint. + :type ip_addresses: list[str] + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'record_type': {'key': 'recordType', 'type': 'str'}, + 'record_set_name': {'key': 'recordSetName', 'type': 'str'}, + 'fqdn': {'key': 'fqdn', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'ttl': {'key': 'ttl', 'type': 'int'}, + 'ip_addresses': {'key': 'ipAddresses', 'type': '[str]'}, + } + + def __init__( + self, + *, + record_type: Optional[str] = None, + record_set_name: Optional[str] = None, + fqdn: Optional[str] = None, + ttl: Optional[int] = None, + ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(RecordSet, self).__init__(**kwargs) + self.record_type = record_type + self.record_set_name = record_set_name + self.fqdn = fqdn + self.provisioning_state = None + self.ttl = ttl + self.ip_addresses = ip_addresses + + +class ReferencedPublicIpAddress(msrest.serialization.Model): + """Reference to a public IP address. + + :param id: The PublicIPAddress Reference. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(ReferencedPublicIpAddress, self).__init__(**kwargs) + self.id = id + + +class ResourceNavigationLink(SubResource): + """ResourceNavigationLink resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param linked_resource_type: Resource type of the linked resource. + :type linked_resource_type: str + :param link: Link to the external resource. + :type link: str + :ivar provisioning_state: The provisioning state of the resource navigation link resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'linked_resource_type': {'key': 'properties.linkedResourceType', 'type': 'str'}, + 'link': {'key': 'properties.link', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + linked_resource_type: Optional[str] = None, + link: Optional[str] = None, + **kwargs + ): + super(ResourceNavigationLink, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.linked_resource_type = linked_resource_type + self.link = link + self.provisioning_state = None + + +class ResourceNavigationLinksListResult(msrest.serialization.Model): + """Response for ResourceNavigationLinks_List operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The resource navigation links in a subnet. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLink] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceNavigationLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ResourceNavigationLink"]] = None, + **kwargs + ): + super(ResourceNavigationLinksListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class RetentionPolicyParameters(msrest.serialization.Model): + """Parameters that define the retention policy for flow log. + + :param days: Number of days to retain flow log records. + :type days: int + :param enabled: Flag to enable/disable retention. + :type enabled: bool + """ + + _attribute_map = { + 'days': {'key': 'days', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + days: Optional[int] = 0, + enabled: Optional[bool] = False, + **kwargs + ): + super(RetentionPolicyParameters, self).__init__(**kwargs) + self.days = days + self.enabled = enabled + + +class Route(SubResource): + """Route resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param type: The type of the resource. + :type type: str + :param address_prefix: The destination CIDR to which the route applies. + :type address_prefix: str + :param next_hop_type: The type of Azure hop the packet should be sent to. Possible values + include: "VirtualNetworkGateway", "VnetLocal", "Internet", "VirtualAppliance", "None". + :type next_hop_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteNextHopType + :param next_hop_ip_address: The IP address packets should be forwarded to. Next hop values are + only allowed in routes where the next hop type is VirtualAppliance. + :type next_hop_ip_address: str + :ivar provisioning_state: The provisioning state of the route resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param has_bgp_override: A value indicating whether this route overrides overlapping BGP routes + regardless of LPM. + :type has_bgp_override: bool + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'next_hop_type': {'key': 'properties.nextHopType', 'type': 'str'}, + 'next_hop_ip_address': {'key': 'properties.nextHopIpAddress', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'has_bgp_override': {'key': 'properties.hasBgpOverride', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + type: Optional[str] = None, + address_prefix: Optional[str] = None, + next_hop_type: Optional[Union[str, "RouteNextHopType"]] = None, + next_hop_ip_address: Optional[str] = None, + has_bgp_override: Optional[bool] = None, + **kwargs + ): + super(Route, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = type + self.address_prefix = address_prefix + self.next_hop_type = next_hop_type + self.next_hop_ip_address = next_hop_ip_address + self.provisioning_state = None + self.has_bgp_override = has_bgp_override + + +class RouteFilter(Resource): + """Route Filter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param rules: Collection of RouteFilterRules contained within a route filter. + :type rules: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :ivar peerings: A collection of references to express route circuit peerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar ipv6_peerings: A collection of references to express route circuit ipv6 peerings. + :vartype ipv6_peerings: list[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :ivar provisioning_state: The provisioning state of the route filter resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'peerings': {'readonly': True}, + 'ipv6_peerings': {'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'}, + 'rules': {'key': 'properties.rules', 'type': '[RouteFilterRule]'}, + 'peerings': {'key': 'properties.peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'ipv6_peerings': {'key': 'properties.ipv6Peerings', 'type': '[ExpressRouteCircuitPeering]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + rules: Optional[List["RouteFilterRule"]] = None, + **kwargs + ): + super(RouteFilter, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.rules = rules + self.peerings = None + self.ipv6_peerings = None + self.provisioning_state = None + + +class RouteFilterListResult(msrest.serialization.Model): + """Response for the ListRouteFilters API service call. + + :param value: A list of route filters in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteFilter] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteFilter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["RouteFilter"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(RouteFilterListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class RouteFilterRule(SubResource): + """Route Filter Rule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :param location: Resource location. + :type location: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param access: The access type of the rule. Possible values include: "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param route_filter_rule_type: The rule type of the rule. Possible values include: "Community". + :type route_filter_rule_type: str or ~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleType + :param communities: The collection for bgp community values to filter on. e.g. + ['12076:5010','12076:5020']. + :type communities: list[str] + :ivar provisioning_state: The provisioning state of the route filter rule resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'route_filter_rule_type': {'key': 'properties.routeFilterRuleType', 'type': 'str'}, + 'communities': {'key': 'properties.communities', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + location: Optional[str] = None, + access: Optional[Union[str, "Access"]] = None, + route_filter_rule_type: Optional[Union[str, "RouteFilterRuleType"]] = None, + communities: Optional[List[str]] = None, + **kwargs + ): + super(RouteFilterRule, self).__init__(id=id, **kwargs) + self.name = name + self.location = location + self.etag = None + self.access = access + self.route_filter_rule_type = route_filter_rule_type + self.communities = communities + self.provisioning_state = None + + +class RouteFilterRuleListResult(msrest.serialization.Model): + """Response for the ListRouteFilterRules API service call. + + :param value: A list of RouteFilterRules in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteFilterRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["RouteFilterRule"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(RouteFilterRuleListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class RouteListResult(msrest.serialization.Model): + """Response for the ListRoute API service call. + + :param value: A list of routes in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Route] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Route]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Route"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(RouteListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class RouteTable(Resource): + """Route table resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param routes: Collection of routes contained within a route table. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.Route] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param disable_bgp_route_propagation: Whether to disable the routes learned by BGP on that + route table. True means disable. + :type disable_bgp_route_propagation: bool + :ivar provisioning_state: The provisioning state of the route table resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_guid: The resource GUID property of the route table. + :vartype resource_guid: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_guid': {'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'}, + 'routes': {'key': 'properties.routes', 'type': '[Route]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'disable_bgp_route_propagation': {'key': 'properties.disableBgpRoutePropagation', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + routes: Optional[List["Route"]] = None, + disable_bgp_route_propagation: Optional[bool] = None, + **kwargs + ): + super(RouteTable, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.routes = routes + self.subnets = None + self.disable_bgp_route_propagation = disable_bgp_route_propagation + self.provisioning_state = None + self.resource_guid = None + + +class RouteTableListResult(msrest.serialization.Model): + """Response for the ListRouteTable API service call. + + :param value: A list of route tables in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.RouteTable] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[RouteTable]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["RouteTable"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(RouteTableListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class RoutingConfiguration(msrest.serialization.Model): + """Routing Configuration indicating the associated and propagated route tables for this connection. + + :param associated_route_table: The resource id RouteTable associated with this + RoutingConfiguration. + :type associated_route_table: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param propagated_route_tables: The list of RouteTables to advertise the routes to. + :type propagated_route_tables: ~azure.mgmt.network.v2020_08_01.models.PropagatedRouteTable + :param vnet_routes: List of routes that control routing from VirtualHub into a virtual network + connection. + :type vnet_routes: ~azure.mgmt.network.v2020_08_01.models.VnetRoute + """ + + _attribute_map = { + 'associated_route_table': {'key': 'associatedRouteTable', 'type': 'SubResource'}, + 'propagated_route_tables': {'key': 'propagatedRouteTables', 'type': 'PropagatedRouteTable'}, + 'vnet_routes': {'key': 'vnetRoutes', 'type': 'VnetRoute'}, + } + + def __init__( + self, + *, + associated_route_table: Optional["SubResource"] = None, + propagated_route_tables: Optional["PropagatedRouteTable"] = None, + vnet_routes: Optional["VnetRoute"] = None, + **kwargs + ): + super(RoutingConfiguration, self).__init__(**kwargs) + self.associated_route_table = associated_route_table + self.propagated_route_tables = propagated_route_tables + self.vnet_routes = vnet_routes + + +class SecurityGroupNetworkInterface(msrest.serialization.Model): + """Network interface and all its associated security rules. + + :param id: ID of the network interface. + :type id: str + :param security_rule_associations: All security rules associated with the network interface. + :type security_rule_associations: + ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAssociations + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rule_associations': {'key': 'securityRuleAssociations', 'type': 'SecurityRuleAssociations'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + security_rule_associations: Optional["SecurityRuleAssociations"] = None, + **kwargs + ): + super(SecurityGroupNetworkInterface, self).__init__(**kwargs) + self.id = id + self.security_rule_associations = security_rule_associations + + +class SecurityGroupViewParameters(msrest.serialization.Model): + """Parameters that define the VM to check security groups for. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. ID of the target VM. + :type target_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + **kwargs + ): + super(SecurityGroupViewParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + + +class SecurityGroupViewResult(msrest.serialization.Model): + """The information about security rules applied to the specified VM. + + :param network_interfaces: List of network interfaces on the specified VM. + :type network_interfaces: + list[~azure.mgmt.network.v2020_08_01.models.SecurityGroupNetworkInterface] + """ + + _attribute_map = { + 'network_interfaces': {'key': 'networkInterfaces', 'type': '[SecurityGroupNetworkInterface]'}, + } + + def __init__( + self, + *, + network_interfaces: Optional[List["SecurityGroupNetworkInterface"]] = None, + **kwargs + ): + super(SecurityGroupViewResult, self).__init__(**kwargs) + self.network_interfaces = network_interfaces + + +class SecurityPartnerProvider(Resource): + """Security Partner Provider resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar provisioning_state: The provisioning state of the Security Partner Provider resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param security_provider_name: The security provider name. Possible values include: "ZScaler", + "IBoss", "Checkpoint". + :type security_provider_name: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityProviderName + :ivar connection_status: The connection status with the Security Partner Provider. Possible + values include: "Unknown", "PartiallyConnected", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderConnectionStatus + :param virtual_hub: The virtualHub to which the Security Partner Provider belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'connection_status': {'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'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'security_provider_name': {'key': 'properties.securityProviderName', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + security_provider_name: Optional[Union[str, "SecurityProviderName"]] = None, + virtual_hub: Optional["SubResource"] = None, + **kwargs + ): + super(SecurityPartnerProvider, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.provisioning_state = None + self.security_provider_name = security_provider_name + self.connection_status = None + self.virtual_hub = virtual_hub + + +class SecurityPartnerProviderListResult(msrest.serialization.Model): + """Response for ListSecurityPartnerProviders API service call. + + :param value: List of Security Partner Providers in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SecurityPartnerProvider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["SecurityPartnerProvider"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(SecurityPartnerProviderListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class SecurityRule(SubResource): + """Network security rule. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param type: The type of the resource. + :type type: str + :param description: A description for this rule. Restricted to 140 chars. + :type description: str + :param protocol: Network protocol this rule applies to. Possible values include: "Tcp", "Udp", + "Icmp", "Esp", "*", "Ah". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleProtocol + :param source_port_range: The source port or range. Integer or range between 0 and 65535. + Asterisk '*' can also be used to match all ports. + :type source_port_range: str + :param destination_port_range: The destination port or range. Integer or range between 0 and + 65535. Asterisk '*' can also be used to match all ports. + :type destination_port_range: str + :param source_address_prefix: The CIDR or source IP range. Asterisk '*' can also be used to + match all source IPs. Default tags such as 'VirtualNetwork', 'AzureLoadBalancer' and 'Internet' + can also be used. If this is an ingress rule, specifies where network traffic originates from. + :type source_address_prefix: str + :param source_address_prefixes: The CIDR or source IP ranges. + :type source_address_prefixes: list[str] + :param source_application_security_groups: The application security group specified as source. + :type source_application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :param destination_address_prefix: The destination address prefix. CIDR or destination IP + range. Asterisk '*' can also be used to match all source IPs. Default tags such as + 'VirtualNetwork', 'AzureLoadBalancer' and 'Internet' can also be used. + :type destination_address_prefix: str + :param destination_address_prefixes: The destination address prefixes. CIDR or destination IP + ranges. + :type destination_address_prefixes: list[str] + :param destination_application_security_groups: The application security group specified as + destination. + :type destination_application_security_groups: + list[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :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: The network traffic is allowed or denied. Possible values include: "Allow", + "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleAccess + :param priority: The priority of the rule. The value can be between 100 and 4096. 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: The direction of the rule. The direction specifies if rule will be evaluated + on incoming or outgoing traffic. Possible values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.SecurityRuleDirection + :ivar provisioning_state: The provisioning state of the security rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'protocol': {'key': 'properties.protocol', 'type': 'str'}, + 'source_port_range': {'key': 'properties.sourcePortRange', 'type': 'str'}, + 'destination_port_range': {'key': 'properties.destinationPortRange', 'type': 'str'}, + 'source_address_prefix': {'key': 'properties.sourceAddressPrefix', 'type': 'str'}, + 'source_address_prefixes': {'key': 'properties.sourceAddressPrefixes', 'type': '[str]'}, + 'source_application_security_groups': {'key': 'properties.sourceApplicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'destination_address_prefix': {'key': 'properties.destinationAddressPrefix', 'type': 'str'}, + 'destination_address_prefixes': {'key': 'properties.destinationAddressPrefixes', 'type': '[str]'}, + 'destination_application_security_groups': {'key': 'properties.destinationApplicationSecurityGroups', 'type': '[ApplicationSecurityGroup]'}, + 'source_port_ranges': {'key': 'properties.sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'properties.destinationPortRanges', 'type': '[str]'}, + 'access': {'key': 'properties.access', 'type': 'str'}, + 'priority': {'key': 'properties.priority', 'type': 'int'}, + 'direction': {'key': 'properties.direction', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + type: Optional[str] = None, + description: Optional[str] = None, + protocol: Optional[Union[str, "SecurityRuleProtocol"]] = None, + source_port_range: Optional[str] = None, + destination_port_range: Optional[str] = None, + source_address_prefix: Optional[str] = None, + source_address_prefixes: Optional[List[str]] = None, + source_application_security_groups: Optional[List["ApplicationSecurityGroup"]] = None, + destination_address_prefix: Optional[str] = None, + destination_address_prefixes: Optional[List[str]] = None, + destination_application_security_groups: Optional[List["ApplicationSecurityGroup"]] = None, + source_port_ranges: Optional[List[str]] = None, + destination_port_ranges: Optional[List[str]] = None, + access: Optional[Union[str, "SecurityRuleAccess"]] = None, + priority: Optional[int] = None, + direction: Optional[Union[str, "SecurityRuleDirection"]] = None, + **kwargs + ): + super(SecurityRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = type + self.description = description + self.protocol = protocol + self.source_port_range = source_port_range + self.destination_port_range = destination_port_range + self.source_address_prefix = source_address_prefix + self.source_address_prefixes = source_address_prefixes + self.source_application_security_groups = source_application_security_groups + self.destination_address_prefix = destination_address_prefix + self.destination_address_prefixes = destination_address_prefixes + self.destination_application_security_groups = destination_application_security_groups + self.source_port_ranges = source_port_ranges + self.destination_port_ranges = destination_port_ranges + self.access = access + self.priority = priority + self.direction = direction + self.provisioning_state = None + + +class SecurityRuleAssociations(msrest.serialization.Model): + """All security rules associated with the network interface. + + :param network_interface_association: Network interface and it's custom security rules. + :type network_interface_association: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceAssociation + :param subnet_association: Subnet and it's custom security rules. + :type subnet_association: ~azure.mgmt.network.v2020_08_01.models.SubnetAssociation + :param default_security_rules: Collection of default security rules of the network security + group. + :type default_security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :param effective_security_rules: Collection of effective security rules. + :type effective_security_rules: + list[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityRule] + """ + + _attribute_map = { + 'network_interface_association': {'key': 'networkInterfaceAssociation', 'type': 'NetworkInterfaceAssociation'}, + 'subnet_association': {'key': 'subnetAssociation', 'type': 'SubnetAssociation'}, + 'default_security_rules': {'key': 'defaultSecurityRules', 'type': '[SecurityRule]'}, + 'effective_security_rules': {'key': 'effectiveSecurityRules', 'type': '[EffectiveNetworkSecurityRule]'}, + } + + def __init__( + self, + *, + network_interface_association: Optional["NetworkInterfaceAssociation"] = None, + subnet_association: Optional["SubnetAssociation"] = None, + default_security_rules: Optional[List["SecurityRule"]] = None, + effective_security_rules: Optional[List["EffectiveNetworkSecurityRule"]] = None, + **kwargs + ): + super(SecurityRuleAssociations, self).__init__(**kwargs) + self.network_interface_association = network_interface_association + self.subnet_association = subnet_association + self.default_security_rules = default_security_rules + self.effective_security_rules = effective_security_rules + + +class SecurityRuleListResult(msrest.serialization.Model): + """Response for ListSecurityRule API service call. Retrieves all security rules that belongs to a network security group. + + :param value: The security rules in a network security group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SecurityRule]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["SecurityRule"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(SecurityRuleListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ServiceAssociationLink(SubResource): + """ServiceAssociationLink resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the resource that is unique within a resource group. This name can be used + to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param linked_resource_type: Resource type of the linked resource. + :type linked_resource_type: str + :param link: Link to the external resource. + :type link: str + :ivar provisioning_state: The provisioning state of the service association link resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param allow_delete: If true, the resource can be deleted. + :type allow_delete: bool + :param locations: A list of locations. + :type locations: list[str] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'linked_resource_type': {'key': 'properties.linkedResourceType', 'type': 'str'}, + 'link': {'key': 'properties.link', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'allow_delete': {'key': 'properties.allowDelete', 'type': 'bool'}, + 'locations': {'key': 'properties.locations', 'type': '[str]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + linked_resource_type: Optional[str] = None, + link: Optional[str] = None, + allow_delete: Optional[bool] = None, + locations: Optional[List[str]] = None, + **kwargs + ): + super(ServiceAssociationLink, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.linked_resource_type = linked_resource_type + self.link = link + self.provisioning_state = None + self.allow_delete = allow_delete + self.locations = locations + + +class ServiceAssociationLinksListResult(msrest.serialization.Model): + """Response for ServiceAssociationLinks_List operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: The service association links in a subnet. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLink] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceAssociationLink]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ServiceAssociationLink"]] = None, + **kwargs + ): + super(ServiceAssociationLinksListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ServiceEndpointPolicy(Resource): + """Service End point policy resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param service_endpoint_policy_definitions: A collection of service endpoint policy definitions + of the service endpoint policy. + :type service_endpoint_policy_definitions: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :ivar subnets: A collection of references to subnets. + :vartype subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :ivar resource_guid: The resource GUID property of the service endpoint policy resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the service endpoint policy resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'subnets': {'readonly': True}, + 'resource_guid': {'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'}, + 'service_endpoint_policy_definitions': {'key': 'properties.serviceEndpointPolicyDefinitions', 'type': '[ServiceEndpointPolicyDefinition]'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + service_endpoint_policy_definitions: Optional[List["ServiceEndpointPolicyDefinition"]] = None, + **kwargs + ): + super(ServiceEndpointPolicy, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.service_endpoint_policy_definitions = service_endpoint_policy_definitions + self.subnets = None + self.resource_guid = None + self.provisioning_state = None + + +class ServiceEndpointPolicyDefinition(SubResource): + """Service Endpoint policy definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param description: A description for this rule. Restricted to 140 chars. + :type description: str + :param service: Service endpoint name. + :type service: str + :param service_resources: A list of service resources. + :type service_resources: list[str] + :ivar provisioning_state: The provisioning state of the service endpoint policy definition + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'service': {'key': 'properties.service', 'type': 'str'}, + 'service_resources': {'key': 'properties.serviceResources', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + description: Optional[str] = None, + service: Optional[str] = None, + service_resources: Optional[List[str]] = None, + **kwargs + ): + super(ServiceEndpointPolicyDefinition, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.description = description + self.service = service + self.service_resources = service_resources + self.provisioning_state = None + + +class ServiceEndpointPolicyDefinitionListResult(msrest.serialization.Model): + """Response for ListServiceEndpointPolicyDefinition API service call. Retrieves all service endpoint policy definition that belongs to a service endpoint policy. + + :param value: The service endpoint policy definition in a service endpoint policy. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceEndpointPolicyDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ServiceEndpointPolicyDefinition"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ServiceEndpointPolicyDefinitionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ServiceEndpointPolicyListResult(msrest.serialization.Model): + """Response for ListServiceEndpointPolicies API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of ServiceEndpointPolicy resources. + :type value: list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceEndpointPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ServiceEndpointPolicy"]] = None, + **kwargs + ): + super(ServiceEndpointPolicyListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ServiceEndpointPropertiesFormat(msrest.serialization.Model): + """The service endpoint properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param service: The type of the endpoint service. + :type service: str + :param locations: A list of locations. + :type locations: list[str] + :ivar provisioning_state: The provisioning state of the service endpoint resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'service': {'key': 'service', 'type': 'str'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + service: Optional[str] = None, + locations: Optional[List[str]] = None, + **kwargs + ): + super(ServiceEndpointPropertiesFormat, self).__init__(**kwargs) + self.service = service + self.locations = locations + self.provisioning_state = None + + +class ServiceTagInformation(msrest.serialization.Model): + """The service tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar properties: Properties of the service tag information. + :vartype properties: + ~azure.mgmt.network.v2020_08_01.models.ServiceTagInformationPropertiesFormat + :ivar name: The name of service tag. + :vartype name: str + :ivar id: The ID of service tag. + :vartype id: str + """ + + _validation = { + 'properties': {'readonly': True}, + 'name': {'readonly': True}, + 'id': {'readonly': True}, + } + + _attribute_map = { + 'properties': {'key': 'properties', 'type': 'ServiceTagInformationPropertiesFormat'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagInformation, self).__init__(**kwargs) + self.properties = None + self.name = None + self.id = None + + +class ServiceTagInformationPropertiesFormat(msrest.serialization.Model): + """Properties of the service tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar change_number: The iteration number of service tag. + :vartype change_number: str + :ivar region: The region of service tag. + :vartype region: str + :ivar system_service: The name of system service. + :vartype system_service: str + :ivar address_prefixes: The list of IP address prefixes. + :vartype address_prefixes: list[str] + """ + + _validation = { + 'change_number': {'readonly': True}, + 'region': {'readonly': True}, + 'system_service': {'readonly': True}, + 'address_prefixes': {'readonly': True}, + } + + _attribute_map = { + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + 'region': {'key': 'region', 'type': 'str'}, + 'system_service': {'key': 'systemService', 'type': 'str'}, + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagInformationPropertiesFormat, self).__init__(**kwargs) + self.change_number = None + self.region = None + self.system_service = None + self.address_prefixes = None + + +class ServiceTagsListResult(msrest.serialization.Model): + """Response for the ListServiceTags API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: The name of the cloud. + :vartype name: str + :ivar id: The ID of the cloud. + :vartype id: str + :ivar type: The azure resource type. + :vartype type: str + :ivar change_number: The iteration number. + :vartype change_number: str + :ivar cloud: The name of the cloud. + :vartype cloud: str + :ivar values: The list of service tag information resources. + :vartype values: list[~azure.mgmt.network.v2020_08_01.models.ServiceTagInformation] + :ivar next_link: The URL to get next page of service tag information resources. + :vartype next_link: str + """ + + _validation = { + 'name': {'readonly': True}, + 'id': {'readonly': True}, + 'type': {'readonly': True}, + 'change_number': {'readonly': True}, + 'cloud': {'readonly': True}, + 'values': {'readonly': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'change_number': {'key': 'changeNumber', 'type': 'str'}, + 'cloud': {'key': 'cloud', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[ServiceTagInformation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTagsListResult, self).__init__(**kwargs) + self.name = None + self.id = None + self.type = None + self.change_number = None + self.cloud = None + self.values = None + self.next_link = None + + +class SessionIds(msrest.serialization.Model): + """List of session IDs. + + :param session_ids: List of session IDs. + :type session_ids: list[str] + """ + + _attribute_map = { + 'session_ids': {'key': 'sessionIds', 'type': '[str]'}, + } + + def __init__( + self, + *, + session_ids: Optional[List[str]] = None, + **kwargs + ): + super(SessionIds, self).__init__(**kwargs) + self.session_ids = session_ids + + +class StaticRoute(msrest.serialization.Model): + """List of all Static Routes. + + :param name: The name of the StaticRoute that is unique within a VnetRoute. + :type name: str + :param address_prefixes: List of all address prefixes. + :type address_prefixes: list[str] + :param next_hop_ip_address: The ip address of the next hop. + :type next_hop_ip_address: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + address_prefixes: Optional[List[str]] = None, + next_hop_ip_address: Optional[str] = None, + **kwargs + ): + super(StaticRoute, self).__init__(**kwargs) + self.name = name + self.address_prefixes = address_prefixes + self.next_hop_ip_address = next_hop_ip_address + + +class Subnet(SubResource): + """Subnet in a virtual network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param address_prefix: The address prefix for the subnet. + :type address_prefix: str + :param address_prefixes: List of address prefixes for the subnet. + :type address_prefixes: list[str] + :param network_security_group: The reference to the NetworkSecurityGroup resource. + :type network_security_group: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :param route_table: The reference to the RouteTable resource. + :type route_table: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :param nat_gateway: Nat gateway associated with this subnet. + :type nat_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param service_endpoints: An array of service endpoints. + :type service_endpoints: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPropertiesFormat] + :param service_endpoint_policies: An array of service endpoint policies. + :type service_endpoint_policies: + list[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :ivar private_endpoints: An array of references to private endpoints. + :vartype private_endpoints: list[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :ivar ip_configurations: An array of references to the network interface IP configurations + using subnet. + :vartype ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.IPConfiguration] + :ivar ip_configuration_profiles: Array of IP configuration profiles which reference this + subnet. + :vartype ip_configuration_profiles: + list[~azure.mgmt.network.v2020_08_01.models.IPConfigurationProfile] + :param ip_allocations: Array of IpAllocation which reference this subnet. + :type ip_allocations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar resource_navigation_links: An array of references to the external resources using subnet. + :vartype resource_navigation_links: + list[~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLink] + :ivar service_association_links: An array of references to services injecting into this subnet. + :vartype service_association_links: + list[~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLink] + :param delegations: An array of references to the delegations on the subnet. + :type delegations: list[~azure.mgmt.network.v2020_08_01.models.Delegation] + :ivar purpose: A read-only string identifying the intention of use for this subnet based on + delegations and other user-defined properties. + :vartype purpose: str + :ivar provisioning_state: The provisioning state of the subnet resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param private_endpoint_network_policies: Enable or Disable apply network policies on private + end point in the subnet. + :type private_endpoint_network_policies: str + :param private_link_service_network_policies: Enable or Disable apply network policies on + private link service in the subnet. + :type private_link_service_network_policies: str + """ + + _validation = { + 'etag': {'readonly': True}, + 'private_endpoints': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'ip_configuration_profiles': {'readonly': True}, + 'resource_navigation_links': {'readonly': True}, + 'service_association_links': {'readonly': True}, + 'purpose': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'address_prefixes': {'key': 'properties.addressPrefixes', 'type': '[str]'}, + 'network_security_group': {'key': 'properties.networkSecurityGroup', 'type': 'NetworkSecurityGroup'}, + 'route_table': {'key': 'properties.routeTable', 'type': 'RouteTable'}, + 'nat_gateway': {'key': 'properties.natGateway', 'type': 'SubResource'}, + 'service_endpoints': {'key': 'properties.serviceEndpoints', 'type': '[ServiceEndpointPropertiesFormat]'}, + 'service_endpoint_policies': {'key': 'properties.serviceEndpointPolicies', 'type': '[ServiceEndpointPolicy]'}, + 'private_endpoints': {'key': 'properties.privateEndpoints', 'type': '[PrivateEndpoint]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[IPConfiguration]'}, + 'ip_configuration_profiles': {'key': 'properties.ipConfigurationProfiles', 'type': '[IPConfigurationProfile]'}, + 'ip_allocations': {'key': 'properties.ipAllocations', 'type': '[SubResource]'}, + 'resource_navigation_links': {'key': 'properties.resourceNavigationLinks', 'type': '[ResourceNavigationLink]'}, + 'service_association_links': {'key': 'properties.serviceAssociationLinks', 'type': '[ServiceAssociationLink]'}, + 'delegations': {'key': 'properties.delegations', 'type': '[Delegation]'}, + 'purpose': {'key': 'properties.purpose', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint_network_policies': {'key': 'properties.privateEndpointNetworkPolicies', 'type': 'str'}, + 'private_link_service_network_policies': {'key': 'properties.privateLinkServiceNetworkPolicies', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + address_prefix: Optional[str] = None, + address_prefixes: Optional[List[str]] = None, + network_security_group: Optional["NetworkSecurityGroup"] = None, + route_table: Optional["RouteTable"] = None, + nat_gateway: Optional["SubResource"] = None, + service_endpoints: Optional[List["ServiceEndpointPropertiesFormat"]] = None, + service_endpoint_policies: Optional[List["ServiceEndpointPolicy"]] = None, + ip_allocations: Optional[List["SubResource"]] = None, + delegations: Optional[List["Delegation"]] = None, + private_endpoint_network_policies: Optional[str] = None, + private_link_service_network_policies: Optional[str] = None, + **kwargs + ): + super(Subnet, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.address_prefix = address_prefix + self.address_prefixes = address_prefixes + self.network_security_group = network_security_group + self.route_table = route_table + self.nat_gateway = nat_gateway + self.service_endpoints = service_endpoints + self.service_endpoint_policies = service_endpoint_policies + self.private_endpoints = None + self.ip_configurations = None + self.ip_configuration_profiles = None + self.ip_allocations = ip_allocations + self.resource_navigation_links = None + self.service_association_links = None + self.delegations = delegations + self.purpose = None + self.provisioning_state = None + self.private_endpoint_network_policies = private_endpoint_network_policies + self.private_link_service_network_policies = private_link_service_network_policies + + +class SubnetAssociation(msrest.serialization.Model): + """Subnet and it's custom security rules. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Subnet ID. + :vartype id: str + :param security_rules: Collection of custom security rules. + :type security_rules: list[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'security_rules': {'key': 'securityRules', 'type': '[SecurityRule]'}, + } + + def __init__( + self, + *, + security_rules: Optional[List["SecurityRule"]] = None, + **kwargs + ): + super(SubnetAssociation, self).__init__(**kwargs) + self.id = None + self.security_rules = security_rules + + +class SubnetListResult(msrest.serialization.Model): + """Response for ListSubnets API service callRetrieves all subnet that belongs to a virtual network. + + :param value: The subnets in a virtual network. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Subnet]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Subnet"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(SubnetListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class TagsObject(msrest.serialization.Model): + """Tags object for patch operations. + + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(TagsObject, self).__init__(**kwargs) + self.tags = tags + + +class Topology(msrest.serialization.Model): + """Topology of the specified resource group. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: GUID representing the operation id. + :vartype id: str + :ivar created_date_time: The datetime when the topology was initially created for the resource + group. + :vartype created_date_time: ~datetime.datetime + :ivar last_modified: The datetime when the topology was last modified. + :vartype last_modified: ~datetime.datetime + :param resources: A list of topology resources. + :type resources: list[~azure.mgmt.network.v2020_08_01.models.TopologyResource] + """ + + _validation = { + 'id': {'readonly': True}, + 'created_date_time': {'readonly': True}, + 'last_modified': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'created_date_time': {'key': 'createdDateTime', 'type': 'iso-8601'}, + 'last_modified': {'key': 'lastModified', 'type': 'iso-8601'}, + 'resources': {'key': 'resources', 'type': '[TopologyResource]'}, + } + + def __init__( + self, + *, + resources: Optional[List["TopologyResource"]] = None, + **kwargs + ): + super(Topology, self).__init__(**kwargs) + self.id = None + self.created_date_time = None + self.last_modified = None + self.resources = resources + + +class TopologyAssociation(msrest.serialization.Model): + """Resources that have an association with the parent resource. + + :param name: The name of the resource that is associated with the parent resource. + :type name: str + :param resource_id: The ID of the resource that is associated with the parent resource. + :type resource_id: str + :param association_type: The association type of the child resource to the parent resource. + Possible values include: "Associated", "Contains". + :type association_type: str or ~azure.mgmt.network.v2020_08_01.models.AssociationType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'association_type': {'key': 'associationType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + resource_id: Optional[str] = None, + association_type: Optional[Union[str, "AssociationType"]] = None, + **kwargs + ): + super(TopologyAssociation, self).__init__(**kwargs) + self.name = name + self.resource_id = resource_id + self.association_type = association_type + + +class TopologyParameters(msrest.serialization.Model): + """Parameters that define the representation of topology. + + :param target_resource_group_name: The name of the target resource group to perform topology + on. + :type target_resource_group_name: str + :param target_virtual_network: The reference to the Virtual Network resource. + :type target_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param target_subnet: The reference to the Subnet resource. + :type target_subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + """ + + _attribute_map = { + 'target_resource_group_name': {'key': 'targetResourceGroupName', 'type': 'str'}, + 'target_virtual_network': {'key': 'targetVirtualNetwork', 'type': 'SubResource'}, + 'target_subnet': {'key': 'targetSubnet', 'type': 'SubResource'}, + } + + def __init__( + self, + *, + target_resource_group_name: Optional[str] = None, + target_virtual_network: Optional["SubResource"] = None, + target_subnet: Optional["SubResource"] = None, + **kwargs + ): + super(TopologyParameters, self).__init__(**kwargs) + self.target_resource_group_name = target_resource_group_name + self.target_virtual_network = target_virtual_network + self.target_subnet = target_subnet + + +class TopologyResource(msrest.serialization.Model): + """The network resource topology information for the given resource group. + + :param name: Name of the resource. + :type name: str + :param id: ID of the resource. + :type id: str + :param location: Resource location. + :type location: str + :param associations: Holds the associations the resource has with other resources in the + resource group. + :type associations: list[~azure.mgmt.network.v2020_08_01.models.TopologyAssociation] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'associations': {'key': 'associations', 'type': '[TopologyAssociation]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + id: Optional[str] = None, + location: Optional[str] = None, + associations: Optional[List["TopologyAssociation"]] = None, + **kwargs + ): + super(TopologyResource, self).__init__(**kwargs) + self.name = name + self.id = id + self.location = location + self.associations = associations + + +class TrafficAnalyticsConfigurationProperties(msrest.serialization.Model): + """Parameters that define the configuration of traffic analytics. + + :param enabled: Flag to enable/disable traffic analytics. + :type enabled: bool + :param workspace_id: The resource guid of the attached workspace. + :type workspace_id: str + :param workspace_region: The location of the attached workspace. + :type workspace_region: str + :param workspace_resource_id: Resource Id of the attached workspace. + :type workspace_resource_id: str + :param traffic_analytics_interval: The interval in minutes which would decide how frequently TA + service should do flow analytics. + :type traffic_analytics_interval: int + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + 'workspace_id': {'key': 'workspaceId', 'type': 'str'}, + 'workspace_region': {'key': 'workspaceRegion', 'type': 'str'}, + 'workspace_resource_id': {'key': 'workspaceResourceId', 'type': 'str'}, + 'traffic_analytics_interval': {'key': 'trafficAnalyticsInterval', 'type': 'int'}, + } + + def __init__( + self, + *, + enabled: Optional[bool] = None, + workspace_id: Optional[str] = None, + workspace_region: Optional[str] = None, + workspace_resource_id: Optional[str] = None, + traffic_analytics_interval: Optional[int] = None, + **kwargs + ): + super(TrafficAnalyticsConfigurationProperties, self).__init__(**kwargs) + self.enabled = enabled + self.workspace_id = workspace_id + self.workspace_region = workspace_region + self.workspace_resource_id = workspace_resource_id + self.traffic_analytics_interval = traffic_analytics_interval + + +class TrafficAnalyticsProperties(msrest.serialization.Model): + """Parameters that define the configuration of traffic analytics. + + :param network_watcher_flow_analytics_configuration: Parameters that define the configuration + of traffic analytics. + :type network_watcher_flow_analytics_configuration: + ~azure.mgmt.network.v2020_08_01.models.TrafficAnalyticsConfigurationProperties + """ + + _attribute_map = { + 'network_watcher_flow_analytics_configuration': {'key': 'networkWatcherFlowAnalyticsConfiguration', 'type': 'TrafficAnalyticsConfigurationProperties'}, + } + + def __init__( + self, + *, + network_watcher_flow_analytics_configuration: Optional["TrafficAnalyticsConfigurationProperties"] = None, + **kwargs + ): + super(TrafficAnalyticsProperties, self).__init__(**kwargs) + self.network_watcher_flow_analytics_configuration = network_watcher_flow_analytics_configuration + + +class TrafficSelectorPolicy(msrest.serialization.Model): + """An traffic selector policy for a virtual network gateway connection. + + All required parameters must be populated in order to send to Azure. + + :param local_address_ranges: Required. A collection of local address spaces in CIDR format. + :type local_address_ranges: list[str] + :param remote_address_ranges: Required. A collection of remote address spaces in CIDR format. + :type remote_address_ranges: list[str] + """ + + _validation = { + 'local_address_ranges': {'required': True}, + 'remote_address_ranges': {'required': True}, + } + + _attribute_map = { + 'local_address_ranges': {'key': 'localAddressRanges', 'type': '[str]'}, + 'remote_address_ranges': {'key': 'remoteAddressRanges', 'type': '[str]'}, + } + + def __init__( + self, + *, + local_address_ranges: List[str], + remote_address_ranges: List[str], + **kwargs + ): + super(TrafficSelectorPolicy, self).__init__(**kwargs) + self.local_address_ranges = local_address_ranges + self.remote_address_ranges = remote_address_ranges + + +class TroubleshootingDetails(msrest.serialization.Model): + """Information gained from troubleshooting of specified resource. + + :param id: The id of the get troubleshoot operation. + :type id: str + :param reason_type: Reason type of failure. + :type reason_type: str + :param summary: A summary of troubleshooting. + :type summary: str + :param detail: Details on troubleshooting results. + :type detail: str + :param recommended_actions: List of recommended actions. + :type recommended_actions: + list[~azure.mgmt.network.v2020_08_01.models.TroubleshootingRecommendedActions] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'reason_type': {'key': 'reasonType', 'type': 'str'}, + 'summary': {'key': 'summary', 'type': 'str'}, + 'detail': {'key': 'detail', 'type': 'str'}, + 'recommended_actions': {'key': 'recommendedActions', 'type': '[TroubleshootingRecommendedActions]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + reason_type: Optional[str] = None, + summary: Optional[str] = None, + detail: Optional[str] = None, + recommended_actions: Optional[List["TroubleshootingRecommendedActions"]] = None, + **kwargs + ): + super(TroubleshootingDetails, self).__init__(**kwargs) + self.id = id + self.reason_type = reason_type + self.summary = summary + self.detail = detail + self.recommended_actions = recommended_actions + + +class TroubleshootingParameters(msrest.serialization.Model): + """Parameters that define the resource to troubleshoot. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The target resource to troubleshoot. + :type target_resource_id: str + :param storage_id: Required. The ID for the storage account to save the troubleshoot result. + :type storage_id: str + :param storage_path: Required. The path to the blob to save the troubleshoot result in. + :type storage_path: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'storage_id': {'required': True}, + 'storage_path': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'storage_id': {'key': 'properties.storageId', 'type': 'str'}, + 'storage_path': {'key': 'properties.storagePath', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + storage_id: str, + storage_path: str, + **kwargs + ): + super(TroubleshootingParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + self.storage_id = storage_id + self.storage_path = storage_path + + +class TroubleshootingRecommendedActions(msrest.serialization.Model): + """Recommended actions based on discovered issues. + + :param action_id: ID of the recommended action. + :type action_id: str + :param action_text: Description of recommended actions. + :type action_text: str + :param action_uri: The uri linking to a documentation for the recommended troubleshooting + actions. + :type action_uri: str + :param action_uri_text: The information from the URI for the recommended troubleshooting + actions. + :type action_uri_text: str + """ + + _attribute_map = { + 'action_id': {'key': 'actionId', 'type': 'str'}, + 'action_text': {'key': 'actionText', 'type': 'str'}, + 'action_uri': {'key': 'actionUri', 'type': 'str'}, + 'action_uri_text': {'key': 'actionUriText', 'type': 'str'}, + } + + def __init__( + self, + *, + action_id: Optional[str] = None, + action_text: Optional[str] = None, + action_uri: Optional[str] = None, + action_uri_text: Optional[str] = None, + **kwargs + ): + super(TroubleshootingRecommendedActions, self).__init__(**kwargs) + self.action_id = action_id + self.action_text = action_text + self.action_uri = action_uri + self.action_uri_text = action_uri_text + + +class TroubleshootingResult(msrest.serialization.Model): + """Troubleshooting information gained from specified resource. + + :param start_time: The start time of the troubleshooting. + :type start_time: ~datetime.datetime + :param end_time: The end time of the troubleshooting. + :type end_time: ~datetime.datetime + :param code: The result code of the troubleshooting. + :type code: str + :param results: Information from troubleshooting. + :type results: list[~azure.mgmt.network.v2020_08_01.models.TroubleshootingDetails] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'code': {'key': 'code', 'type': 'str'}, + 'results': {'key': 'results', 'type': '[TroubleshootingDetails]'}, + } + + def __init__( + self, + *, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + code: Optional[str] = None, + results: Optional[List["TroubleshootingDetails"]] = None, + **kwargs + ): + super(TroubleshootingResult, self).__init__(**kwargs) + self.start_time = start_time + self.end_time = end_time + self.code = code + self.results = results + + +class TunnelConnectionHealth(msrest.serialization.Model): + """VirtualNetworkGatewayConnection properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar tunnel: Tunnel name. + :vartype tunnel: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar ingress_bytes_transferred: The Ingress Bytes Transferred in this connection. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: The Egress Bytes Transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar last_connection_established_utc_time: The time at which connection was established in Utc + format. + :vartype last_connection_established_utc_time: str + """ + + _validation = { + 'tunnel': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'last_connection_established_utc_time': {'readonly': True}, + } + + _attribute_map = { + 'tunnel': {'key': 'tunnel', 'type': 'str'}, + 'connection_status': {'key': 'connectionStatus', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'egressBytesTransferred', 'type': 'long'}, + 'last_connection_established_utc_time': {'key': 'lastConnectionEstablishedUtcTime', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TunnelConnectionHealth, self).__init__(**kwargs) + self.tunnel = None + self.connection_status = None + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.last_connection_established_utc_time = None + + +class UnprepareNetworkPoliciesRequest(msrest.serialization.Model): + """Details of UnprepareNetworkPolicies for Subnet. + + :param service_name: The name of the service for which subnet is being unprepared for. + :type service_name: str + """ + + _attribute_map = { + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + *, + service_name: Optional[str] = None, + **kwargs + ): + super(UnprepareNetworkPoliciesRequest, self).__init__(**kwargs) + self.service_name = service_name + + +class Usage(msrest.serialization.Model): + """The network resource usage. + + Variables are only 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 identifier. + :vartype id: str + :param unit: Required. An enum describing the unit of measurement. Possible values include: + "Count". + :type unit: str or ~azure.mgmt.network.v2020_08_01.models.UsageUnit + :param current_value: Required. The current value of the usage. + :type current_value: long + :param limit: Required. The limit of usage. + :type limit: long + :param name: Required. The name of the type of usage. + :type name: ~azure.mgmt.network.v2020_08_01.models.UsageName + """ + + _validation = { + 'id': {'readonly': True}, + 'unit': {'required': True}, + 'current_value': {'required': True}, + 'limit': {'required': True}, + 'name': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'UsageName'}, + } + + def __init__( + self, + *, + unit: Union[str, "UsageUnit"], + current_value: int, + limit: int, + name: "UsageName", + **kwargs + ): + super(Usage, self).__init__(**kwargs) + self.id = None + self.unit = unit + self.current_value = current_value + self.limit = limit + self.name = name + + +class UsageName(msrest.serialization.Model): + """The usage names. + + :param value: A string describing the resource name. + :type value: str + :param localized_value: A localized string describing the resource 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(UsageName, self).__init__(**kwargs) + self.value = value + self.localized_value = localized_value + + +class UsagesListResult(msrest.serialization.Model): + """The list usages operation response. + + :param value: The list network resource usages. + :type value: list[~azure.mgmt.network.v2020_08_01.models.Usage] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Usage"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(UsagesListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VerificationIPFlowParameters(msrest.serialization.Model): + """Parameters that define the IP flow to be verified. + + All required parameters must be populated in order to send to Azure. + + :param target_resource_id: Required. The ID of the target resource to perform next-hop on. + :type target_resource_id: str + :param direction: Required. The direction of the packet represented as a 5-tuple. Possible + values include: "Inbound", "Outbound". + :type direction: str or ~azure.mgmt.network.v2020_08_01.models.Direction + :param protocol: Required. Protocol to be verified on. Possible values include: "TCP", "UDP". + :type protocol: str or ~azure.mgmt.network.v2020_08_01.models.IpFlowProtocol + :param local_port: Required. The local port. Acceptable values are a single integer in the + range (0-65535). Support for * for the source port, which depends on the direction. + :type local_port: str + :param remote_port: Required. The remote port. Acceptable values are a single integer in the + range (0-65535). Support for * for the source port, which depends on the direction. + :type remote_port: str + :param local_ip_address: Required. The local IP address. Acceptable values are valid IPv4 + addresses. + :type local_ip_address: str + :param remote_ip_address: Required. The remote IP address. Acceptable values are valid IPv4 + addresses. + :type remote_ip_address: str + :param target_nic_resource_id: The NIC ID. (If VM has multiple NICs and IP forwarding is + enabled on any of them, then this parameter must be specified. Otherwise optional). + :type target_nic_resource_id: str + """ + + _validation = { + 'target_resource_id': {'required': True}, + 'direction': {'required': True}, + 'protocol': {'required': True}, + 'local_port': {'required': True}, + 'remote_port': {'required': True}, + 'local_ip_address': {'required': True}, + 'remote_ip_address': {'required': True}, + } + + _attribute_map = { + 'target_resource_id': {'key': 'targetResourceId', 'type': 'str'}, + 'direction': {'key': 'direction', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'local_port': {'key': 'localPort', 'type': 'str'}, + 'remote_port': {'key': 'remotePort', 'type': 'str'}, + 'local_ip_address': {'key': 'localIPAddress', 'type': 'str'}, + 'remote_ip_address': {'key': 'remoteIPAddress', 'type': 'str'}, + 'target_nic_resource_id': {'key': 'targetNicResourceId', 'type': 'str'}, + } + + def __init__( + self, + *, + target_resource_id: str, + direction: Union[str, "Direction"], + protocol: Union[str, "IpFlowProtocol"], + local_port: str, + remote_port: str, + local_ip_address: str, + remote_ip_address: str, + target_nic_resource_id: Optional[str] = None, + **kwargs + ): + super(VerificationIPFlowParameters, self).__init__(**kwargs) + self.target_resource_id = target_resource_id + self.direction = direction + self.protocol = protocol + self.local_port = local_port + self.remote_port = remote_port + self.local_ip_address = local_ip_address + self.remote_ip_address = remote_ip_address + self.target_nic_resource_id = target_nic_resource_id + + +class VerificationIPFlowResult(msrest.serialization.Model): + """Results of IP flow verification on the target resource. + + :param access: Indicates whether the traffic is allowed or denied. Possible values include: + "Allow", "Deny". + :type access: str or ~azure.mgmt.network.v2020_08_01.models.Access + :param rule_name: Name of the rule. If input is not matched against any security rule, it is + not displayed. + :type rule_name: str + """ + + _attribute_map = { + 'access': {'key': 'access', 'type': 'str'}, + 'rule_name': {'key': 'ruleName', 'type': 'str'}, + } + + def __init__( + self, + *, + access: Optional[Union[str, "Access"]] = None, + rule_name: Optional[str] = None, + **kwargs + ): + super(VerificationIPFlowResult, self).__init__(**kwargs) + self.access = access + self.rule_name = rule_name + + +class VirtualApplianceNicProperties(msrest.serialization.Model): + """Network Virtual Appliance NIC properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar name: NIC name. + :vartype name: str + :ivar public_ip_address: Public IP address. + :vartype public_ip_address: str + :ivar private_ip_address: Private IP address. + :vartype private_ip_address: str + """ + + _validation = { + 'name': {'readonly': True}, + 'public_ip_address': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplianceNicProperties, self).__init__(**kwargs) + self.name = None + self.public_ip_address = None + self.private_ip_address = None + + +class VirtualApplianceSite(SubResource): + """Virtual Appliance Site resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the virtual appliance site. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Site type. + :vartype type: str + :param address_prefix: Address Prefix. + :type address_prefix: str + :param o365_policy: Office 365 Policy. + :type o365_policy: ~azure.mgmt.network.v2020_08_01.models.Office365PolicyProperties + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'o365_policy': {'key': 'properties.o365Policy', 'type': 'Office365PolicyProperties'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + address_prefix: Optional[str] = None, + o365_policy: Optional["Office365PolicyProperties"] = None, + **kwargs + ): + super(VirtualApplianceSite, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.address_prefix = address_prefix + self.o365_policy = o365_policy + self.provisioning_state = None + + +class VirtualApplianceSkuProperties(msrest.serialization.Model): + """Network Virtual Appliance Sku Properties. + + :param vendor: Virtual Appliance Vendor. + :type vendor: str + :param bundled_scale_unit: Virtual Appliance Scale Unit. + :type bundled_scale_unit: str + :param market_place_version: Virtual Appliance Version. + :type market_place_version: str + """ + + _attribute_map = { + 'vendor': {'key': 'vendor', 'type': 'str'}, + 'bundled_scale_unit': {'key': 'bundledScaleUnit', 'type': 'str'}, + 'market_place_version': {'key': 'marketPlaceVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + vendor: Optional[str] = None, + bundled_scale_unit: Optional[str] = None, + market_place_version: Optional[str] = None, + **kwargs + ): + super(VirtualApplianceSkuProperties, self).__init__(**kwargs) + self.vendor = vendor + self.bundled_scale_unit = bundled_scale_unit + self.market_place_version = market_place_version + + +class VirtualHub(Resource): + """VirtualHub Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_wan: The VirtualWAN to which the VirtualHub belongs. + :type virtual_wan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param vpn_gateway: The VpnGateway associated with this VirtualHub. + :type vpn_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param p2_s_vpn_gateway: The P2SVpnGateway associated with this VirtualHub. + :type p2_s_vpn_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param express_route_gateway: The expressRouteGateway associated with this VirtualHub. + :type express_route_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param azure_firewall: The azureFirewall associated with this VirtualHub. + :type azure_firewall: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param security_partner_provider: The securityPartnerProvider associated with this VirtualHub. + :type security_partner_provider: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param address_prefix: Address-prefix for this VirtualHub. + :type address_prefix: str + :param route_table: The routeTable associated with this virtual hub. + :type route_table: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTable + :ivar provisioning_state: The provisioning state of the virtual hub resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param security_provider_name: The Security Provider name. + :type security_provider_name: str + :param virtual_hub_route_table_v2_s: List of all virtual hub route table v2s associated with + this VirtualHub. + :type virtual_hub_route_table_v2_s: + list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :param sku: The sku of this VirtualHub. + :type sku: str + :ivar routing_state: The routing state. Possible values include: "None", "Provisioned", + "Provisioning", "Failed". + :vartype routing_state: str or ~azure.mgmt.network.v2020_08_01.models.RoutingState + :ivar bgp_connections: List of references to Bgp Connections. + :vartype bgp_connections: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar ip_configurations: List of references to IpConfigurations. + :vartype ip_configurations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param virtual_router_asn: VirtualRouter ASN. + :type virtual_router_asn: long + :param virtual_router_ips: VirtualRouter IPs. + :type virtual_router_ips: list[str] + :param allow_branch_to_branch_traffic: Flag to control transit for VirtualRouter hub. + :type allow_branch_to_branch_traffic: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'routing_state': {'readonly': True}, + 'bgp_connections': {'readonly': True}, + 'ip_configurations': {'readonly': True}, + 'virtual_router_asn': {'maximum': 4294967295, 'minimum': 0}, + } + + _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'}, + 'virtual_wan': {'key': 'properties.virtualWan', 'type': 'SubResource'}, + 'vpn_gateway': {'key': 'properties.vpnGateway', 'type': 'SubResource'}, + 'p2_s_vpn_gateway': {'key': 'properties.p2SVpnGateway', 'type': 'SubResource'}, + 'express_route_gateway': {'key': 'properties.expressRouteGateway', 'type': 'SubResource'}, + 'azure_firewall': {'key': 'properties.azureFirewall', 'type': 'SubResource'}, + 'security_partner_provider': {'key': 'properties.securityPartnerProvider', 'type': 'SubResource'}, + 'address_prefix': {'key': 'properties.addressPrefix', 'type': 'str'}, + 'route_table': {'key': 'properties.routeTable', 'type': 'VirtualHubRouteTable'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'security_provider_name': {'key': 'properties.securityProviderName', 'type': 'str'}, + 'virtual_hub_route_table_v2_s': {'key': 'properties.virtualHubRouteTableV2s', 'type': '[VirtualHubRouteTableV2]'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'routing_state': {'key': 'properties.routingState', 'type': 'str'}, + 'bgp_connections': {'key': 'properties.bgpConnections', 'type': '[SubResource]'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[SubResource]'}, + 'virtual_router_asn': {'key': 'properties.virtualRouterAsn', 'type': 'long'}, + 'virtual_router_ips': {'key': 'properties.virtualRouterIps', 'type': '[str]'}, + 'allow_branch_to_branch_traffic': {'key': 'properties.allowBranchToBranchTraffic', 'type': 'bool'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + virtual_wan: Optional["SubResource"] = None, + vpn_gateway: Optional["SubResource"] = None, + p2_s_vpn_gateway: Optional["SubResource"] = None, + express_route_gateway: Optional["SubResource"] = None, + azure_firewall: Optional["SubResource"] = None, + security_partner_provider: Optional["SubResource"] = None, + address_prefix: Optional[str] = None, + route_table: Optional["VirtualHubRouteTable"] = None, + security_provider_name: Optional[str] = None, + virtual_hub_route_table_v2_s: Optional[List["VirtualHubRouteTableV2"]] = None, + sku: Optional[str] = None, + virtual_router_asn: Optional[int] = None, + virtual_router_ips: Optional[List[str]] = None, + allow_branch_to_branch_traffic: Optional[bool] = None, + **kwargs + ): + super(VirtualHub, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.virtual_wan = virtual_wan + self.vpn_gateway = vpn_gateway + self.p2_s_vpn_gateway = p2_s_vpn_gateway + self.express_route_gateway = express_route_gateway + self.azure_firewall = azure_firewall + self.security_partner_provider = security_partner_provider + self.address_prefix = address_prefix + self.route_table = route_table + self.provisioning_state = None + self.security_provider_name = security_provider_name + self.virtual_hub_route_table_v2_s = virtual_hub_route_table_v2_s + self.sku = sku + self.routing_state = None + self.bgp_connections = None + self.ip_configurations = None + self.virtual_router_asn = virtual_router_asn + self.virtual_router_ips = virtual_router_ips + self.allow_branch_to_branch_traffic = allow_branch_to_branch_traffic + + +class VirtualHubEffectiveRoute(msrest.serialization.Model): + """The effective route configured on the virtual hub or specified resource. + + :param address_prefixes: The list of address prefixes. + :type address_prefixes: list[str] + :param next_hops: The list of next hops. + :type next_hops: list[str] + :param next_hop_type: The type of the next hop. + :type next_hop_type: str + :param as_path: The ASPath of this route. + :type as_path: str + :param route_origin: The origin of this route. + :type route_origin: str + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hops': {'key': 'nextHops', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'as_path': {'key': 'asPath', 'type': 'str'}, + 'route_origin': {'key': 'routeOrigin', 'type': 'str'}, + } + + def __init__( + self, + *, + address_prefixes: Optional[List[str]] = None, + next_hops: Optional[List[str]] = None, + next_hop_type: Optional[str] = None, + as_path: Optional[str] = None, + route_origin: Optional[str] = None, + **kwargs + ): + super(VirtualHubEffectiveRoute, self).__init__(**kwargs) + self.address_prefixes = address_prefixes + self.next_hops = next_hops + self.next_hop_type = next_hop_type + self.as_path = as_path + self.route_origin = route_origin + + +class VirtualHubEffectiveRouteList(msrest.serialization.Model): + """EffectiveRoutes List. + + :param value: The list of effective routes configured on the virtual hub or the specified + resource. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubEffectiveRoute] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualHubEffectiveRoute]'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualHubEffectiveRoute"]] = None, + **kwargs + ): + super(VirtualHubEffectiveRouteList, self).__init__(**kwargs) + self.value = value + + +class VirtualHubId(msrest.serialization.Model): + """Virtual Hub identifier. + + :param id: The resource URI for the Virtual Hub where the ExpressRoute gateway is or will be + deployed. The Virtual Hub resource and the ExpressRoute gateway resource reside in the same + subscription. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(VirtualHubId, self).__init__(**kwargs) + self.id = id + + +class VirtualHubRoute(msrest.serialization.Model): + """VirtualHub route. + + :param address_prefixes: List of all addressPrefixes. + :type address_prefixes: list[str] + :param next_hop_ip_address: NextHop ip address. + :type next_hop_ip_address: str + """ + + _attribute_map = { + 'address_prefixes': {'key': 'addressPrefixes', 'type': '[str]'}, + 'next_hop_ip_address': {'key': 'nextHopIpAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + address_prefixes: Optional[List[str]] = None, + next_hop_ip_address: Optional[str] = None, + **kwargs + ): + super(VirtualHubRoute, self).__init__(**kwargs) + self.address_prefixes = address_prefixes + self.next_hop_ip_address = next_hop_ip_address + + +class VirtualHubRouteTable(msrest.serialization.Model): + """VirtualHub route table. + + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRoute] + """ + + _attribute_map = { + 'routes': {'key': 'routes', 'type': '[VirtualHubRoute]'}, + } + + def __init__( + self, + *, + routes: Optional[List["VirtualHubRoute"]] = None, + **kwargs + ): + super(VirtualHubRouteTable, self).__init__(**kwargs) + self.routes = routes + + +class VirtualHubRouteTableV2(SubResource): + """VirtualHubRouteTableV2 Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param routes: List of all routes. + :type routes: list[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteV2] + :param attached_connections: List of all connections attached to this route table v2. + :type attached_connections: list[str] + :ivar provisioning_state: The provisioning state of the virtual hub route table v2 resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VirtualHubRouteV2]'}, + 'attached_connections': {'key': 'properties.attachedConnections', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + routes: Optional[List["VirtualHubRouteV2"]] = None, + attached_connections: Optional[List[str]] = None, + **kwargs + ): + super(VirtualHubRouteTableV2, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.routes = routes + self.attached_connections = attached_connections + self.provisioning_state = None + + +class VirtualHubRouteV2(msrest.serialization.Model): + """VirtualHubRouteTableV2 route. + + :param destination_type: The type of destinations. + :type destination_type: str + :param destinations: List of all destinations. + :type destinations: list[str] + :param next_hop_type: The type of next hops. + :type next_hop_type: str + :param next_hops: NextHops ip address. + :type next_hops: list[str] + """ + + _attribute_map = { + 'destination_type': {'key': 'destinationType', 'type': 'str'}, + 'destinations': {'key': 'destinations', 'type': '[str]'}, + 'next_hop_type': {'key': 'nextHopType', 'type': 'str'}, + 'next_hops': {'key': 'nextHops', 'type': '[str]'}, + } + + def __init__( + self, + *, + destination_type: Optional[str] = None, + destinations: Optional[List[str]] = None, + next_hop_type: Optional[str] = None, + next_hops: Optional[List[str]] = None, + **kwargs + ): + super(VirtualHubRouteV2, self).__init__(**kwargs) + self.destination_type = destination_type + self.destinations = destinations + self.next_hop_type = next_hop_type + self.next_hops = next_hops + + +class VirtualNetwork(Resource): + """Virtual Network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 extended_location: The extended location of the virtual network. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param address_space: The AddressSpace that contains an array of IP address ranges that can be + used by subnets. + :type address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param dhcp_options: The dhcpOptions that contains an array of DNS servers available to VMs + deployed in the virtual network. + :type dhcp_options: ~azure.mgmt.network.v2020_08_01.models.DhcpOptions + :param subnets: A list of subnets in a Virtual Network. + :type subnets: list[~azure.mgmt.network.v2020_08_01.models.Subnet] + :param virtual_network_peerings: A list of peerings in a Virtual Network. + :type virtual_network_peerings: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :ivar resource_guid: The resourceGuid property of the Virtual Network resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param enable_ddos_protection: Indicates if DDoS protection is enabled for all the protected + resources in the virtual network. It requires a DDoS protection plan associated with the + resource. + :type enable_ddos_protection: bool + :param enable_vm_protection: Indicates if VM protection is enabled for all the subnets in the + virtual network. + :type enable_vm_protection: bool + :param ddos_protection_plan: The DDoS protection plan associated with the virtual network. + :type ddos_protection_plan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param bgp_communities: Bgp Communities sent over ExpressRoute with each route corresponding to + a prefix in this VNET. + :type bgp_communities: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkBgpCommunities + :param ip_allocations: Array of IpAllocation which reference this VNET. + :type ip_allocations: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'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}'}, + 'extended_location': {'key': 'extendedLocation', 'type': 'ExtendedLocation'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'address_space': {'key': 'properties.addressSpace', 'type': 'AddressSpace'}, + 'dhcp_options': {'key': 'properties.dhcpOptions', 'type': 'DhcpOptions'}, + 'subnets': {'key': 'properties.subnets', 'type': '[Subnet]'}, + 'virtual_network_peerings': {'key': 'properties.virtualNetworkPeerings', 'type': '[VirtualNetworkPeering]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'enable_ddos_protection': {'key': 'properties.enableDdosProtection', 'type': 'bool'}, + 'enable_vm_protection': {'key': 'properties.enableVmProtection', 'type': 'bool'}, + 'ddos_protection_plan': {'key': 'properties.ddosProtectionPlan', 'type': 'SubResource'}, + 'bgp_communities': {'key': 'properties.bgpCommunities', 'type': 'VirtualNetworkBgpCommunities'}, + 'ip_allocations': {'key': 'properties.ipAllocations', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + extended_location: Optional["ExtendedLocation"] = None, + address_space: Optional["AddressSpace"] = None, + dhcp_options: Optional["DhcpOptions"] = None, + subnets: Optional[List["Subnet"]] = None, + virtual_network_peerings: Optional[List["VirtualNetworkPeering"]] = None, + enable_ddos_protection: Optional[bool] = False, + enable_vm_protection: Optional[bool] = False, + ddos_protection_plan: Optional["SubResource"] = None, + bgp_communities: Optional["VirtualNetworkBgpCommunities"] = None, + ip_allocations: Optional[List["SubResource"]] = None, + **kwargs + ): + super(VirtualNetwork, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.extended_location = extended_location + self.etag = None + self.address_space = address_space + self.dhcp_options = dhcp_options + self.subnets = subnets + self.virtual_network_peerings = virtual_network_peerings + self.resource_guid = None + self.provisioning_state = None + self.enable_ddos_protection = enable_ddos_protection + self.enable_vm_protection = enable_vm_protection + self.ddos_protection_plan = ddos_protection_plan + self.bgp_communities = bgp_communities + self.ip_allocations = ip_allocations + + +class VirtualNetworkBgpCommunities(msrest.serialization.Model): + """Bgp Communities sent over ExpressRoute with each route corresponding to a prefix in this VNET. + + Variables are only 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 virtual_network_community: Required. The BGP community associated with the virtual + network. + :type virtual_network_community: str + :ivar regional_community: The BGP community associated with the region of the virtual network. + :vartype regional_community: str + """ + + _validation = { + 'virtual_network_community': {'required': True}, + 'regional_community': {'readonly': True}, + } + + _attribute_map = { + 'virtual_network_community': {'key': 'virtualNetworkCommunity', 'type': 'str'}, + 'regional_community': {'key': 'regionalCommunity', 'type': 'str'}, + } + + def __init__( + self, + *, + virtual_network_community: str, + **kwargs + ): + super(VirtualNetworkBgpCommunities, self).__init__(**kwargs) + self.virtual_network_community = virtual_network_community + self.regional_community = None + + +class VirtualNetworkConnectionGatewayReference(msrest.serialization.Model): + """A reference to VirtualNetworkGateway or LocalNetworkGateway resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. The ID of VirtualNetworkGateway or LocalNetworkGateway resource. + :type id: str + """ + + _validation = { + 'id': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: str, + **kwargs + ): + super(VirtualNetworkConnectionGatewayReference, self).__init__(**kwargs) + self.id = id + + +class VirtualNetworkGateway(Resource): + """A common class for general resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param ip_configurations: IP configurations for virtual network gateway. + :type ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayIPConfiguration] + :param gateway_type: The type of this virtual network gateway. Possible values include: "Vpn", + "ExpressRoute", "LocalGateway". + :type gateway_type: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayType + :param vpn_type: The type of this virtual network gateway. Possible values include: + "PolicyBased", "RouteBased". + :type vpn_type: str or ~azure.mgmt.network.v2020_08_01.models.VpnType + :param vpn_gateway_generation: The generation for this VirtualNetworkGateway. Must be None if + gatewayType is not VPN. Possible values include: "None", "Generation1", "Generation2". + :type vpn_gateway_generation: str or + ~azure.mgmt.network.v2020_08_01.models.VpnGatewayGeneration + :param enable_bgp: Whether BGP is enabled for this virtual network gateway or not. + :type enable_bgp: bool + :param enable_private_ip_address: Whether private IP needs to be enabled on this gateway for + connections or not. + :type enable_private_ip_address: bool + :param active: ActiveActive flag. + :type active: bool + :param gateway_default_site: The reference to the LocalNetworkGateway resource which represents + local network site having default routes. Assign Null value in case of removing existing + default site setting. + :type gateway_default_site: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param sku: The reference to the VirtualNetworkGatewaySku resource which represents the SKU + selected for Virtual network gateway. + :type sku: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySku + :param vpn_client_configuration: The reference to the VpnClientConfiguration resource which + represents the P2S VpnClient configurations. + :type vpn_client_configuration: ~azure.mgmt.network.v2020_08_01.models.VpnClientConfiguration + :param bgp_settings: Virtual network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :param custom_routes: The reference to the address space resource which represents the custom + routes address space specified by the customer for virtual network gateway and VpnClient. + :type custom_routes: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :ivar resource_guid: The resource GUID property of the virtual network gateway resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param enable_dns_forwarding: Whether dns forwarding is enabled or not. + :type enable_dns_forwarding: bool + :ivar inbound_dns_forwarding_endpoint: The IP address allocated by the gateway to which dns + requests can be sent. + :vartype inbound_dns_forwarding_endpoint: str + :param virtual_network_extended_location_resource_id: MAS FIJI customer vnet resource id. + VirtualNetworkGateway of type local gateway is associated with the customer vnet. + :type virtual_network_extended_location_resource_id: str + :param extended_location: The extended location of type local virtual network gateway. + :type extended_location: ~azure.mgmt.network.v2020_08_01.models.ExtendedLocation + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'resource_guid': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'inbound_dns_forwarding_endpoint': {'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'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[VirtualNetworkGatewayIPConfiguration]'}, + 'gateway_type': {'key': 'properties.gatewayType', 'type': 'str'}, + 'vpn_type': {'key': 'properties.vpnType', 'type': 'str'}, + 'vpn_gateway_generation': {'key': 'properties.vpnGatewayGeneration', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'enable_private_ip_address': {'key': 'properties.enablePrivateIpAddress', 'type': 'bool'}, + 'active': {'key': 'properties.activeActive', 'type': 'bool'}, + 'gateway_default_site': {'key': 'properties.gatewayDefaultSite', 'type': 'SubResource'}, + 'sku': {'key': 'properties.sku', 'type': 'VirtualNetworkGatewaySku'}, + 'vpn_client_configuration': {'key': 'properties.vpnClientConfiguration', 'type': 'VpnClientConfiguration'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'custom_routes': {'key': 'properties.customRoutes', 'type': 'AddressSpace'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'enable_dns_forwarding': {'key': 'properties.enableDnsForwarding', 'type': 'bool'}, + 'inbound_dns_forwarding_endpoint': {'key': 'properties.inboundDnsForwardingEndpoint', 'type': 'str'}, + 'virtual_network_extended_location_resource_id': {'key': 'properties.virtualNetworkExtendedLocationResourceId', 'type': 'str'}, + 'extended_location': {'key': 'properties.extendedLocation', 'type': 'ExtendedLocation'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + ip_configurations: Optional[List["VirtualNetworkGatewayIPConfiguration"]] = None, + gateway_type: Optional[Union[str, "VirtualNetworkGatewayType"]] = None, + vpn_type: Optional[Union[str, "VpnType"]] = None, + vpn_gateway_generation: Optional[Union[str, "VpnGatewayGeneration"]] = None, + enable_bgp: Optional[bool] = None, + enable_private_ip_address: Optional[bool] = None, + active: Optional[bool] = None, + gateway_default_site: Optional["SubResource"] = None, + sku: Optional["VirtualNetworkGatewaySku"] = None, + vpn_client_configuration: Optional["VpnClientConfiguration"] = None, + bgp_settings: Optional["BgpSettings"] = None, + custom_routes: Optional["AddressSpace"] = None, + enable_dns_forwarding: Optional[bool] = None, + virtual_network_extended_location_resource_id: Optional[str] = None, + extended_location: Optional["ExtendedLocation"] = None, + **kwargs + ): + super(VirtualNetworkGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.ip_configurations = ip_configurations + self.gateway_type = gateway_type + self.vpn_type = vpn_type + self.vpn_gateway_generation = vpn_gateway_generation + self.enable_bgp = enable_bgp + self.enable_private_ip_address = enable_private_ip_address + self.active = active + self.gateway_default_site = gateway_default_site + self.sku = sku + self.vpn_client_configuration = vpn_client_configuration + self.bgp_settings = bgp_settings + self.custom_routes = custom_routes + self.resource_guid = None + self.provisioning_state = None + self.enable_dns_forwarding = enable_dns_forwarding + self.inbound_dns_forwarding_endpoint = None + self.virtual_network_extended_location_resource_id = virtual_network_extended_location_resource_id + self.extended_location = extended_location + + +class VirtualNetworkGatewayConnection(Resource): + """A common class for general resource 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 id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param authorization_key: The authorizationKey. + :type authorization_key: str + :param virtual_network_gateway1: Required. The reference to virtual network gateway resource. + :type virtual_network_gateway1: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :param virtual_network_gateway2: The reference to virtual network gateway resource. + :type virtual_network_gateway2: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :param local_network_gateway2: The reference to local network gateway resource. + :type local_network_gateway2: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :param connection_type: Required. Gateway connection type. Possible values include: "IPsec", + "Vnet2Vnet", "ExpressRoute", "VPNClient". + :type connection_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionType + :param connection_protocol: Connection protocol used for this connection. Possible values + include: "IKEv2", "IKEv1". + :type connection_protocol: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :param routing_weight: The routing weight. + :type routing_weight: int + :param dpd_timeout_seconds: The dead peer detection timeout of this connection in seconds. + :type dpd_timeout_seconds: int + :param connection_mode: The connection mode for this connection. Possible values include: + "Default", "ResponderOnly", "InitiatorOnly". + :type connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionMode + :param shared_key: The IPSec shared key. + :type shared_key: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar tunnel_connection_status: Collection of all tunnels' connection health status. + :vartype tunnel_connection_status: + list[~azure.mgmt.network.v2020_08_01.models.TunnelConnectionHealth] + :ivar egress_bytes_transferred: The egress bytes transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes transferred in this connection. + :vartype ingress_bytes_transferred: long + :param peer: The reference to peerings resource. + :type peer: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_local_azure_ip_address: Use private local Azure IP for the connection. + :type use_local_azure_ip_address: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param traffic_selector_policies: The Traffic Selector Policies to be considered by this + connection. + :type traffic_selector_policies: + list[~azure.mgmt.network.v2020_08_01.models.TrafficSelectorPolicy] + :ivar resource_guid: The resource GUID property of the virtual network gateway connection + resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_gateway_bypass: Bypass ExpressRoute Gateway for data forwarding. + :type express_route_gateway_bypass: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_network_gateway1': {'required': True}, + 'connection_type': {'required': True}, + 'connection_status': {'readonly': True}, + 'tunnel_connection_status': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'resource_guid': {'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'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'virtual_network_gateway1': {'key': 'properties.virtualNetworkGateway1', 'type': 'VirtualNetworkGateway'}, + 'virtual_network_gateway2': {'key': 'properties.virtualNetworkGateway2', 'type': 'VirtualNetworkGateway'}, + 'local_network_gateway2': {'key': 'properties.localNetworkGateway2', 'type': 'LocalNetworkGateway'}, + 'connection_type': {'key': 'properties.connectionType', 'type': 'str'}, + 'connection_protocol': {'key': 'properties.connectionProtocol', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'dpd_timeout_seconds': {'key': 'properties.dpdTimeoutSeconds', 'type': 'int'}, + 'connection_mode': {'key': 'properties.connectionMode', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'tunnel_connection_status': {'key': 'properties.tunnelConnectionStatus', 'type': '[TunnelConnectionHealth]'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'peer': {'key': 'properties.peer', 'type': 'SubResource'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'traffic_selector_policies': {'key': 'properties.trafficSelectorPolicies', 'type': '[TrafficSelectorPolicy]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + } + + def __init__( + self, + *, + virtual_network_gateway1: "VirtualNetworkGateway", + connection_type: Union[str, "VirtualNetworkGatewayConnectionType"], + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + authorization_key: Optional[str] = None, + virtual_network_gateway2: Optional["VirtualNetworkGateway"] = None, + local_network_gateway2: Optional["LocalNetworkGateway"] = None, + connection_protocol: Optional[Union[str, "VirtualNetworkGatewayConnectionProtocol"]] = None, + routing_weight: Optional[int] = None, + dpd_timeout_seconds: Optional[int] = None, + connection_mode: Optional[Union[str, "VirtualNetworkGatewayConnectionMode"]] = None, + shared_key: Optional[str] = None, + peer: Optional["SubResource"] = None, + enable_bgp: Optional[bool] = None, + use_local_azure_ip_address: Optional[bool] = None, + use_policy_based_traffic_selectors: Optional[bool] = None, + ipsec_policies: Optional[List["IpsecPolicy"]] = None, + traffic_selector_policies: Optional[List["TrafficSelectorPolicy"]] = None, + express_route_gateway_bypass: Optional[bool] = None, + **kwargs + ): + super(VirtualNetworkGatewayConnection, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.authorization_key = authorization_key + self.virtual_network_gateway1 = virtual_network_gateway1 + self.virtual_network_gateway2 = virtual_network_gateway2 + self.local_network_gateway2 = local_network_gateway2 + self.connection_type = connection_type + self.connection_protocol = connection_protocol + self.routing_weight = routing_weight + self.dpd_timeout_seconds = dpd_timeout_seconds + self.connection_mode = connection_mode + self.shared_key = shared_key + self.connection_status = None + self.tunnel_connection_status = None + self.egress_bytes_transferred = None + self.ingress_bytes_transferred = None + self.peer = peer + self.enable_bgp = enable_bgp + self.use_local_azure_ip_address = use_local_azure_ip_address + self.use_policy_based_traffic_selectors = use_policy_based_traffic_selectors + self.ipsec_policies = ipsec_policies + self.traffic_selector_policies = traffic_selector_policies + self.resource_guid = None + self.provisioning_state = None + self.express_route_gateway_bypass = express_route_gateway_bypass + + +class VirtualNetworkGatewayConnectionListEntity(Resource): + """A common class for general resource 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 id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param authorization_key: The authorizationKey. + :type authorization_key: str + :param virtual_network_gateway1: Required. The reference to virtual network gateway resource. + :type virtual_network_gateway1: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param virtual_network_gateway2: The reference to virtual network gateway resource. + :type virtual_network_gateway2: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param local_network_gateway2: The reference to local network gateway resource. + :type local_network_gateway2: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkConnectionGatewayReference + :param connection_type: Required. Gateway connection type. Possible values include: "IPsec", + "Vnet2Vnet", "ExpressRoute", "VPNClient". + :type connection_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionType + :param connection_protocol: Connection protocol used for this connection. Possible values + include: "IKEv2", "IKEv1". + :type connection_protocol: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :param routing_weight: The routing weight. + :type routing_weight: int + :param connection_mode: The connection mode for this connection. Possible values include: + "Default", "ResponderOnly", "InitiatorOnly". + :type connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionMode + :param shared_key: The IPSec shared key. + :type shared_key: str + :ivar connection_status: Virtual Network Gateway connection status. Possible values include: + "Unknown", "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionStatus + :ivar tunnel_connection_status: Collection of all tunnels' connection health status. + :vartype tunnel_connection_status: + list[~azure.mgmt.network.v2020_08_01.models.TunnelConnectionHealth] + :ivar egress_bytes_transferred: The egress bytes transferred in this connection. + :vartype egress_bytes_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes transferred in this connection. + :vartype ingress_bytes_transferred: long + :param peer: The reference to peerings resource. + :type peer: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param traffic_selector_policies: The Traffic Selector Policies to be considered by this + connection. + :type traffic_selector_policies: + list[~azure.mgmt.network.v2020_08_01.models.TrafficSelectorPolicy] + :ivar resource_guid: The resource GUID property of the virtual network gateway connection + resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network gateway connection + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param express_route_gateway_bypass: Bypass ExpressRoute Gateway for data forwarding. + :type express_route_gateway_bypass: bool + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_network_gateway1': {'required': True}, + 'connection_type': {'required': True}, + 'connection_status': {'readonly': True}, + 'tunnel_connection_status': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'resource_guid': {'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'}, + 'authorization_key': {'key': 'properties.authorizationKey', 'type': 'str'}, + 'virtual_network_gateway1': {'key': 'properties.virtualNetworkGateway1', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'virtual_network_gateway2': {'key': 'properties.virtualNetworkGateway2', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'local_network_gateway2': {'key': 'properties.localNetworkGateway2', 'type': 'VirtualNetworkConnectionGatewayReference'}, + 'connection_type': {'key': 'properties.connectionType', 'type': 'str'}, + 'connection_protocol': {'key': 'properties.connectionProtocol', 'type': 'str'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'connection_mode': {'key': 'properties.connectionMode', 'type': 'str'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'tunnel_connection_status': {'key': 'properties.tunnelConnectionStatus', 'type': '[TunnelConnectionHealth]'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'peer': {'key': 'properties.peer', 'type': 'SubResource'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'traffic_selector_policies': {'key': 'properties.trafficSelectorPolicies', 'type': '[TrafficSelectorPolicy]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'express_route_gateway_bypass': {'key': 'properties.expressRouteGatewayBypass', 'type': 'bool'}, + } + + def __init__( + self, + *, + virtual_network_gateway1: "VirtualNetworkConnectionGatewayReference", + connection_type: Union[str, "VirtualNetworkGatewayConnectionType"], + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + authorization_key: Optional[str] = None, + virtual_network_gateway2: Optional["VirtualNetworkConnectionGatewayReference"] = None, + local_network_gateway2: Optional["VirtualNetworkConnectionGatewayReference"] = None, + connection_protocol: Optional[Union[str, "VirtualNetworkGatewayConnectionProtocol"]] = None, + routing_weight: Optional[int] = None, + connection_mode: Optional[Union[str, "VirtualNetworkGatewayConnectionMode"]] = None, + shared_key: Optional[str] = None, + peer: Optional["SubResource"] = None, + enable_bgp: Optional[bool] = None, + use_policy_based_traffic_selectors: Optional[bool] = None, + ipsec_policies: Optional[List["IpsecPolicy"]] = None, + traffic_selector_policies: Optional[List["TrafficSelectorPolicy"]] = None, + express_route_gateway_bypass: Optional[bool] = None, + **kwargs + ): + super(VirtualNetworkGatewayConnectionListEntity, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.authorization_key = authorization_key + self.virtual_network_gateway1 = virtual_network_gateway1 + self.virtual_network_gateway2 = virtual_network_gateway2 + self.local_network_gateway2 = local_network_gateway2 + self.connection_type = connection_type + self.connection_protocol = connection_protocol + self.routing_weight = routing_weight + self.connection_mode = connection_mode + self.shared_key = shared_key + self.connection_status = None + self.tunnel_connection_status = None + self.egress_bytes_transferred = None + self.ingress_bytes_transferred = None + self.peer = peer + self.enable_bgp = enable_bgp + self.use_policy_based_traffic_selectors = use_policy_based_traffic_selectors + self.ipsec_policies = ipsec_policies + self.traffic_selector_policies = traffic_selector_policies + self.resource_guid = None + self.provisioning_state = None + self.express_route_gateway_bypass = express_route_gateway_bypass + + +class VirtualNetworkGatewayConnectionListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworkGatewayConnections API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGatewayConnection resources that exists in a resource + group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGatewayConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetworkGatewayConnection"]] = None, + **kwargs + ): + super(VirtualNetworkGatewayConnectionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class VirtualNetworkGatewayIPConfiguration(SubResource): + """IP configuration for virtual network gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param private_ip_allocation_method: The private IP address allocation method. Possible values + include: "Static", "Dynamic". + :type private_ip_allocation_method: str or + ~azure.mgmt.network.v2020_08_01.models.IPAllocationMethod + :param subnet: The reference to the subnet resource. + :type subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param public_ip_address: The reference to the public IP resource. + :type public_ip_address: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar private_ip_address: Private IP Address for this gateway. + :vartype private_ip_address: str + :ivar provisioning_state: The provisioning state of the virtual network gateway IP + configuration resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'private_ip_allocation_method': {'key': 'properties.privateIPAllocationMethod', 'type': 'str'}, + 'subnet': {'key': 'properties.subnet', 'type': 'SubResource'}, + 'public_ip_address': {'key': 'properties.publicIPAddress', 'type': 'SubResource'}, + 'private_ip_address': {'key': 'properties.privateIPAddress', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + private_ip_allocation_method: Optional[Union[str, "IPAllocationMethod"]] = None, + subnet: Optional["SubResource"] = None, + public_ip_address: Optional["SubResource"] = None, + **kwargs + ): + super(VirtualNetworkGatewayIPConfiguration, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.private_ip_allocation_method = private_ip_allocation_method + self.subnet = subnet + self.public_ip_address = public_ip_address + self.private_ip_address = None + self.provisioning_state = None + + +class VirtualNetworkGatewayListConnectionsResult(msrest.serialization.Model): + """Response for the VirtualNetworkGatewayListConnections API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGatewayConnection resources that exists in a resource + group. + :type value: + list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionListEntity] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGatewayConnectionListEntity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetworkGatewayConnectionListEntity"]] = None, + **kwargs + ): + super(VirtualNetworkGatewayListConnectionsResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class VirtualNetworkGatewayListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworkGateways API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: A list of VirtualNetworkGateway resources that exists in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :ivar next_link: The URL to get the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkGateway]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetworkGateway"]] = None, + **kwargs + ): + super(VirtualNetworkGatewayListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class VirtualNetworkGatewaySku(msrest.serialization.Model): + """VirtualNetworkGatewaySku details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Gateway SKU name. Possible values include: "Basic", "HighPerformance", "Standard", + "UltraPerformance", "VpnGw1", "VpnGw2", "VpnGw3", "VpnGw4", "VpnGw5", "VpnGw1AZ", "VpnGw2AZ", + "VpnGw3AZ", "VpnGw4AZ", "VpnGw5AZ", "ErGw1AZ", "ErGw2AZ", "ErGw3AZ". + :type name: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySkuName + :param tier: Gateway SKU tier. Possible values include: "Basic", "HighPerformance", "Standard", + "UltraPerformance", "VpnGw1", "VpnGw2", "VpnGw3", "VpnGw4", "VpnGw5", "VpnGw1AZ", "VpnGw2AZ", + "VpnGw3AZ", "VpnGw4AZ", "VpnGw5AZ", "ErGw1AZ", "ErGw2AZ", "ErGw3AZ". + :type tier: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewaySkuTier + :ivar capacity: The capacity. + :vartype capacity: int + """ + + _validation = { + 'capacity': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + *, + name: Optional[Union[str, "VirtualNetworkGatewaySkuName"]] = None, + tier: Optional[Union[str, "VirtualNetworkGatewaySkuTier"]] = None, + **kwargs + ): + super(VirtualNetworkGatewaySku, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.capacity = None + + +class VirtualNetworkListResult(msrest.serialization.Model): + """Response for the ListVirtualNetworks API service call. + + :param value: A list of VirtualNetwork resources in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetwork] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetwork]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetwork"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VirtualNetworkListUsageResult(msrest.serialization.Model): + """Response for the virtual networks GetUsage API service call. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar value: VirtualNetwork usage stats. + :vartype value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkUsage] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _validation = { + 'value': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkUsage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkListUsageResult, self).__init__(**kwargs) + self.value = None + self.next_link = next_link + + +class VirtualNetworkPeering(SubResource): + """Peerings in a virtual network resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param allow_virtual_network_access: Whether the VMs in the local virtual network space would + be able to access the VMs in remote virtual network space. + :type allow_virtual_network_access: bool + :param allow_forwarded_traffic: Whether the forwarded traffic from the VMs in the local virtual + network will be allowed/disallowed in remote virtual network. + :type allow_forwarded_traffic: bool + :param allow_gateway_transit: If gateway links can be used in remote virtual networking to link + to this virtual network. + :type allow_gateway_transit: bool + :param use_remote_gateways: If remote gateways can be used on this virtual network. If the flag + is set to true, and allowGatewayTransit on remote peering is also true, virtual network will + use gateways of remote virtual network for transit. Only one peering can have this flag set to + true. This flag cannot be set if virtual network already has a gateway. + :type use_remote_gateways: bool + :param remote_virtual_network: The reference to the remote virtual network. The remote virtual + network can be in the same or different region (preview). See here to register for the preview + and learn more (https://docs.microsoft.com/en-us/azure/virtual-network/virtual-network-create- + peering). + :type remote_virtual_network: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param remote_address_space: The reference to the remote virtual network address space. + :type remote_address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param remote_bgp_communities: The reference to the remote virtual network's Bgp Communities. + :type remote_bgp_communities: + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkBgpCommunities + :param peering_state: The status of the virtual network peering. Possible values include: + "Initiated", "Connected", "Disconnected". + :type peering_state: str or ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeeringState + :ivar provisioning_state: The provisioning state of the virtual network peering resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'allow_virtual_network_access': {'key': 'properties.allowVirtualNetworkAccess', 'type': 'bool'}, + 'allow_forwarded_traffic': {'key': 'properties.allowForwardedTraffic', 'type': 'bool'}, + 'allow_gateway_transit': {'key': 'properties.allowGatewayTransit', 'type': 'bool'}, + 'use_remote_gateways': {'key': 'properties.useRemoteGateways', 'type': 'bool'}, + 'remote_virtual_network': {'key': 'properties.remoteVirtualNetwork', 'type': 'SubResource'}, + 'remote_address_space': {'key': 'properties.remoteAddressSpace', 'type': 'AddressSpace'}, + 'remote_bgp_communities': {'key': 'properties.remoteBgpCommunities', 'type': 'VirtualNetworkBgpCommunities'}, + 'peering_state': {'key': 'properties.peeringState', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + allow_virtual_network_access: Optional[bool] = None, + allow_forwarded_traffic: Optional[bool] = None, + allow_gateway_transit: Optional[bool] = None, + use_remote_gateways: Optional[bool] = None, + remote_virtual_network: Optional["SubResource"] = None, + remote_address_space: Optional["AddressSpace"] = None, + remote_bgp_communities: Optional["VirtualNetworkBgpCommunities"] = None, + peering_state: Optional[Union[str, "VirtualNetworkPeeringState"]] = None, + **kwargs + ): + super(VirtualNetworkPeering, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.allow_virtual_network_access = allow_virtual_network_access + self.allow_forwarded_traffic = allow_forwarded_traffic + self.allow_gateway_transit = allow_gateway_transit + self.use_remote_gateways = use_remote_gateways + self.remote_virtual_network = remote_virtual_network + self.remote_address_space = remote_address_space + self.remote_bgp_communities = remote_bgp_communities + self.peering_state = peering_state + self.provisioning_state = None + + +class VirtualNetworkPeeringListResult(msrest.serialization.Model): + """Response for ListSubnets API service call. Retrieves all subnets that belong to a virtual network. + + :param value: The peerings in a virtual network. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetworkPeering"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkPeeringListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VirtualNetworkTap(Resource): + """Virtual Network Tap resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar network_interface_tap_configurations: Specifies the list of resource IDs for the network + interface IP configuration that needs to be tapped. + :vartype network_interface_tap_configurations: + list[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :ivar resource_guid: The resource GUID property of the virtual network tap resource. + :vartype resource_guid: str + :ivar provisioning_state: The provisioning state of the virtual network tap resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param destination_network_interface_ip_configuration: The reference to the private IP Address + of the collector nic that will receive the tap. + :type destination_network_interface_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :param destination_load_balancer_front_end_ip_configuration: The reference to the private IP + address on the internal Load Balancer that will receive the tap. + :type destination_load_balancer_front_end_ip_configuration: + ~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration + :param destination_port: The VXLAN destination port that will receive the tapped traffic. + :type destination_port: int + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'network_interface_tap_configurations': {'readonly': True}, + 'resource_guid': {'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'}, + 'network_interface_tap_configurations': {'key': 'properties.networkInterfaceTapConfigurations', 'type': '[NetworkInterfaceTapConfiguration]'}, + 'resource_guid': {'key': 'properties.resourceGuid', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'destination_network_interface_ip_configuration': {'key': 'properties.destinationNetworkInterfaceIPConfiguration', 'type': 'NetworkInterfaceIPConfiguration'}, + 'destination_load_balancer_front_end_ip_configuration': {'key': 'properties.destinationLoadBalancerFrontEndIPConfiguration', 'type': 'FrontendIPConfiguration'}, + 'destination_port': {'key': 'properties.destinationPort', 'type': 'int'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + destination_network_interface_ip_configuration: Optional["NetworkInterfaceIPConfiguration"] = None, + destination_load_balancer_front_end_ip_configuration: Optional["FrontendIPConfiguration"] = None, + destination_port: Optional[int] = None, + **kwargs + ): + super(VirtualNetworkTap, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.network_interface_tap_configurations = None + self.resource_guid = None + self.provisioning_state = None + self.destination_network_interface_ip_configuration = destination_network_interface_ip_configuration + self.destination_load_balancer_front_end_ip_configuration = destination_load_balancer_front_end_ip_configuration + self.destination_port = destination_port + + +class VirtualNetworkTapListResult(msrest.serialization.Model): + """Response for ListVirtualNetworkTap API service call. + + :param value: A list of VirtualNetworkTaps in a resource group. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :param next_link: The URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualNetworkTap]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualNetworkTap"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkTapListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VirtualNetworkUsage(msrest.serialization.Model): + """Usage details for subnet. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar current_value: Indicates number of IPs used from the Subnet. + :vartype current_value: float + :ivar id: Subnet identifier. + :vartype id: str + :ivar limit: Indicates the size of the subnet. + :vartype limit: float + :ivar name: The name containing common and localized value for usage. + :vartype name: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkUsageName + :ivar unit: Usage units. Returns 'Count'. + :vartype unit: str + """ + + _validation = { + 'current_value': {'readonly': True}, + 'id': {'readonly': True}, + 'limit': {'readonly': True}, + 'name': {'readonly': True}, + 'unit': {'readonly': True}, + } + + _attribute_map = { + 'current_value': {'key': 'currentValue', 'type': 'float'}, + 'id': {'key': 'id', 'type': 'str'}, + 'limit': {'key': 'limit', 'type': 'float'}, + 'name': {'key': 'name', 'type': 'VirtualNetworkUsageName'}, + 'unit': {'key': 'unit', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkUsage, self).__init__(**kwargs) + self.current_value = None + self.id = None + self.limit = None + self.name = None + self.unit = None + + +class VirtualNetworkUsageName(msrest.serialization.Model): + """Usage strings container. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar localized_value: Localized subnet size and usage string. + :vartype localized_value: str + :ivar value: Subnet size and usage string. + :vartype value: str + """ + + _validation = { + 'localized_value': {'readonly': True}, + 'value': {'readonly': True}, + } + + _attribute_map = { + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkUsageName, self).__init__(**kwargs) + self.localized_value = None + self.value = None + + +class VirtualRouter(Resource): + """VirtualRouter Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_router_asn: VirtualRouter ASN. + :type virtual_router_asn: long + :param virtual_router_ips: VirtualRouter IPs. + :type virtual_router_ips: list[str] + :param hosted_subnet: The Subnet on which VirtualRouter is hosted. + :type hosted_subnet: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param hosted_gateway: The Gateway on which VirtualRouter is hosted. + :type hosted_gateway: ~azure.mgmt.network.v2020_08_01.models.SubResource + :ivar peerings: List of references to VirtualRouterPeerings. + :vartype peerings: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_router_asn': {'maximum': 4294967295, 'minimum': 0}, + 'peerings': {'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'}, + 'virtual_router_asn': {'key': 'properties.virtualRouterAsn', 'type': 'long'}, + 'virtual_router_ips': {'key': 'properties.virtualRouterIps', 'type': '[str]'}, + 'hosted_subnet': {'key': 'properties.hostedSubnet', 'type': 'SubResource'}, + 'hosted_gateway': {'key': 'properties.hostedGateway', 'type': 'SubResource'}, + 'peerings': {'key': 'properties.peerings', 'type': '[SubResource]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + virtual_router_asn: Optional[int] = None, + virtual_router_ips: Optional[List[str]] = None, + hosted_subnet: Optional["SubResource"] = None, + hosted_gateway: Optional["SubResource"] = None, + **kwargs + ): + super(VirtualRouter, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.virtual_router_asn = virtual_router_asn + self.virtual_router_ips = virtual_router_ips + self.hosted_subnet = hosted_subnet + self.hosted_gateway = hosted_gateway + self.peerings = None + self.provisioning_state = None + + +class VirtualRouterListResult(msrest.serialization.Model): + """Response for ListVirtualRouters API service call. + + :param value: List of Virtual Routers. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualRouter] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualRouter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualRouter"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualRouterListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VirtualRouterPeering(SubResource): + """Virtual Router Peering resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: Name of the virtual router peering that is unique within a virtual router. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Peering type. + :vartype type: str + :param peer_asn: Peer ASN. + :type peer_asn: long + :param peer_ip: Peer IP. + :type peer_ip: str + :ivar provisioning_state: The provisioning state of the resource. Possible values include: + "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'peer_asn': {'maximum': 4294967295, 'minimum': 0}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'peer_asn': {'key': 'properties.peerAsn', 'type': 'long'}, + 'peer_ip': {'key': 'properties.peerIp', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + peer_asn: Optional[int] = None, + peer_ip: Optional[str] = None, + **kwargs + ): + super(VirtualRouterPeering, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.peer_asn = peer_asn + self.peer_ip = peer_ip + self.provisioning_state = None + + +class VirtualRouterPeeringListResult(msrest.serialization.Model): + """Response for ListVirtualRouterPeerings API service call. + + :param value: List of VirtualRouterPeerings in a VirtualRouter. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering] + :param next_link: URL to get the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VirtualRouterPeering]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["VirtualRouterPeering"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(VirtualRouterPeeringListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class VirtualWAN(Resource): + """VirtualWAN Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param disable_vpn_encryption: Vpn encryption to be disabled or not. + :type disable_vpn_encryption: bool + :ivar virtual_hubs: List of VirtualHubs in the VirtualWAN. + :vartype virtual_hubs: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar vpn_sites: List of VpnSites in the VirtualWAN. + :vartype vpn_sites: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param allow_branch_to_branch_traffic: True if branch to branch traffic is allowed. + :type allow_branch_to_branch_traffic: bool + :param allow_vnet_to_vnet_traffic: True if Vnet to Vnet traffic is allowed. + :type allow_vnet_to_vnet_traffic: bool + :ivar office365_local_breakout_category: The office local breakout category. Possible values + include: "Optimize", "OptimizeAndAllow", "All", "None". + :vartype office365_local_breakout_category: str or + ~azure.mgmt.network.v2020_08_01.models.OfficeTrafficCategory + :ivar provisioning_state: The provisioning state of the virtual WAN resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param type_properties_type: The type of the VirtualWAN. + :type type_properties_type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'virtual_hubs': {'readonly': True}, + 'vpn_sites': {'readonly': True}, + 'office365_local_breakout_category': {'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'}, + 'disable_vpn_encryption': {'key': 'properties.disableVpnEncryption', 'type': 'bool'}, + 'virtual_hubs': {'key': 'properties.virtualHubs', 'type': '[SubResource]'}, + 'vpn_sites': {'key': 'properties.vpnSites', 'type': '[SubResource]'}, + 'allow_branch_to_branch_traffic': {'key': 'properties.allowBranchToBranchTraffic', 'type': 'bool'}, + 'allow_vnet_to_vnet_traffic': {'key': 'properties.allowVnetToVnetTraffic', 'type': 'bool'}, + 'office365_local_breakout_category': {'key': 'properties.office365LocalBreakoutCategory', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + disable_vpn_encryption: Optional[bool] = None, + allow_branch_to_branch_traffic: Optional[bool] = None, + allow_vnet_to_vnet_traffic: Optional[bool] = None, + type_properties_type: Optional[str] = None, + **kwargs + ): + super(VirtualWAN, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.disable_vpn_encryption = disable_vpn_encryption + self.virtual_hubs = None + self.vpn_sites = None + self.allow_branch_to_branch_traffic = allow_branch_to_branch_traffic + self.allow_vnet_to_vnet_traffic = allow_vnet_to_vnet_traffic + self.office365_local_breakout_category = None + self.provisioning_state = None + self.type_properties_type = type_properties_type + + +class VirtualWanSecurityProvider(msrest.serialization.Model): + """Collection of SecurityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: Name of the security provider. + :type name: str + :param url: Url of the security provider. + :type url: str + :ivar type: Name of the security provider. Possible values include: "External", "Native". + :vartype type: str or ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviderType + """ + + _validation = { + 'type': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + url: Optional[str] = None, + **kwargs + ): + super(VirtualWanSecurityProvider, self).__init__(**kwargs) + self.name = name + self.url = url + self.type = None + + +class VirtualWanSecurityProviders(msrest.serialization.Model): + """Collection of SecurityProviders. + + :param supported_providers: List of VirtualWAN security providers. + :type supported_providers: + list[~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProvider] + """ + + _attribute_map = { + 'supported_providers': {'key': 'supportedProviders', 'type': '[VirtualWanSecurityProvider]'}, + } + + def __init__( + self, + *, + supported_providers: Optional[List["VirtualWanSecurityProvider"]] = None, + **kwargs + ): + super(VirtualWanSecurityProviders, self).__init__(**kwargs) + self.supported_providers = supported_providers + + +class VirtualWanVpnProfileParameters(msrest.serialization.Model): + """Virtual Wan Vpn profile parameters Vpn profile generation. + + :param vpn_server_configuration_resource_id: VpnServerConfiguration partial resource uri with + which VirtualWan is associated to. + :type vpn_server_configuration_resource_id: str + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + """ + + _attribute_map = { + 'vpn_server_configuration_resource_id': {'key': 'vpnServerConfigurationResourceId', 'type': 'str'}, + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + } + + def __init__( + self, + *, + vpn_server_configuration_resource_id: Optional[str] = None, + authentication_method: Optional[Union[str, "AuthenticationMethod"]] = None, + **kwargs + ): + super(VirtualWanVpnProfileParameters, self).__init__(**kwargs) + self.vpn_server_configuration_resource_id = vpn_server_configuration_resource_id + self.authentication_method = authentication_method + + +class VM(Resource): + """Describes a Virtual Machine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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 = { + '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, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(VM, self).__init__(id=id, location=location, tags=tags, **kwargs) + + +class VnetRoute(msrest.serialization.Model): + """List of routes that control routing from VirtualHub into a virtual network connection. + + :param static_routes: List of all Static Routes. + :type static_routes: list[~azure.mgmt.network.v2020_08_01.models.StaticRoute] + """ + + _attribute_map = { + 'static_routes': {'key': 'staticRoutes', 'type': '[StaticRoute]'}, + } + + def __init__( + self, + *, + static_routes: Optional[List["StaticRoute"]] = None, + **kwargs + ): + super(VnetRoute, self).__init__(**kwargs) + self.static_routes = static_routes + + +class VpnClientConfiguration(msrest.serialization.Model): + """VpnClientConfiguration for P2S client. + + :param vpn_client_address_pool: The reference to the address space resource which represents + Address space for P2S VpnClient. + :type vpn_client_address_pool: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param vpn_client_root_certificates: VpnClientRootCertificate for virtual network gateway. + :type vpn_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnClientRootCertificate] + :param vpn_client_revoked_certificates: VpnClientRevokedCertificate for Virtual network + gateway. + :type vpn_client_revoked_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnClientRevokedCertificate] + :param vpn_client_protocols: VpnClientProtocols for Virtual network gateway. + :type vpn_client_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnClientProtocol] + :param vpn_client_ipsec_policies: VpnClientIpsecPolicies for virtual network gateway P2S + client. + :type vpn_client_ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param radius_server_address: The radius server address property of the VirtualNetworkGateway + resource for vpn client connection. + :type radius_server_address: str + :param radius_server_secret: The radius secret property of the VirtualNetworkGateway resource + for vpn client connection. + :type radius_server_secret: str + :param radius_servers: The radiusServers property for multiple radius server configuration. + :type radius_servers: list[~azure.mgmt.network.v2020_08_01.models.RadiusServer] + :param aad_tenant: The AADTenant property of the VirtualNetworkGateway resource for vpn client + connection used for AAD authentication. + :type aad_tenant: str + :param aad_audience: The AADAudience property of the VirtualNetworkGateway resource for vpn + client connection used for AAD authentication. + :type aad_audience: str + :param aad_issuer: The AADIssuer property of the VirtualNetworkGateway resource for vpn client + connection used for AAD authentication. + :type aad_issuer: str + """ + + _attribute_map = { + 'vpn_client_address_pool': {'key': 'vpnClientAddressPool', 'type': 'AddressSpace'}, + 'vpn_client_root_certificates': {'key': 'vpnClientRootCertificates', 'type': '[VpnClientRootCertificate]'}, + 'vpn_client_revoked_certificates': {'key': 'vpnClientRevokedCertificates', 'type': '[VpnClientRevokedCertificate]'}, + 'vpn_client_protocols': {'key': 'vpnClientProtocols', 'type': '[str]'}, + 'vpn_client_ipsec_policies': {'key': 'vpnClientIpsecPolicies', 'type': '[IpsecPolicy]'}, + 'radius_server_address': {'key': 'radiusServerAddress', 'type': 'str'}, + 'radius_server_secret': {'key': 'radiusServerSecret', 'type': 'str'}, + 'radius_servers': {'key': 'radiusServers', 'type': '[RadiusServer]'}, + 'aad_tenant': {'key': 'aadTenant', 'type': 'str'}, + 'aad_audience': {'key': 'aadAudience', 'type': 'str'}, + 'aad_issuer': {'key': 'aadIssuer', 'type': 'str'}, + } + + def __init__( + self, + *, + vpn_client_address_pool: Optional["AddressSpace"] = None, + vpn_client_root_certificates: Optional[List["VpnClientRootCertificate"]] = None, + vpn_client_revoked_certificates: Optional[List["VpnClientRevokedCertificate"]] = None, + vpn_client_protocols: Optional[List[Union[str, "VpnClientProtocol"]]] = None, + vpn_client_ipsec_policies: Optional[List["IpsecPolicy"]] = None, + radius_server_address: Optional[str] = None, + radius_server_secret: Optional[str] = None, + radius_servers: Optional[List["RadiusServer"]] = None, + aad_tenant: Optional[str] = None, + aad_audience: Optional[str] = None, + aad_issuer: Optional[str] = None, + **kwargs + ): + super(VpnClientConfiguration, self).__init__(**kwargs) + self.vpn_client_address_pool = vpn_client_address_pool + self.vpn_client_root_certificates = vpn_client_root_certificates + self.vpn_client_revoked_certificates = vpn_client_revoked_certificates + self.vpn_client_protocols = vpn_client_protocols + self.vpn_client_ipsec_policies = vpn_client_ipsec_policies + self.radius_server_address = radius_server_address + self.radius_server_secret = radius_server_secret + self.radius_servers = radius_servers + self.aad_tenant = aad_tenant + self.aad_audience = aad_audience + self.aad_issuer = aad_issuer + + +class VpnClientConnectionHealth(msrest.serialization.Model): + """VpnClientConnectionHealth properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar total_ingress_bytes_transferred: Total of the Ingress Bytes Transferred in this P2S Vpn + connection. + :vartype total_ingress_bytes_transferred: long + :ivar total_egress_bytes_transferred: Total of the Egress Bytes Transferred in this connection. + :vartype total_egress_bytes_transferred: long + :param vpn_client_connections_count: The total of p2s vpn clients connected at this time to + this P2SVpnGateway. + :type vpn_client_connections_count: int + :param allocated_ip_addresses: List of allocated ip addresses to the connected p2s vpn clients. + :type allocated_ip_addresses: list[str] + """ + + _validation = { + 'total_ingress_bytes_transferred': {'readonly': True}, + 'total_egress_bytes_transferred': {'readonly': True}, + } + + _attribute_map = { + 'total_ingress_bytes_transferred': {'key': 'totalIngressBytesTransferred', 'type': 'long'}, + 'total_egress_bytes_transferred': {'key': 'totalEgressBytesTransferred', 'type': 'long'}, + 'vpn_client_connections_count': {'key': 'vpnClientConnectionsCount', 'type': 'int'}, + 'allocated_ip_addresses': {'key': 'allocatedIpAddresses', 'type': '[str]'}, + } + + def __init__( + self, + *, + vpn_client_connections_count: Optional[int] = None, + allocated_ip_addresses: Optional[List[str]] = None, + **kwargs + ): + super(VpnClientConnectionHealth, self).__init__(**kwargs) + self.total_ingress_bytes_transferred = None + self.total_egress_bytes_transferred = None + self.vpn_client_connections_count = vpn_client_connections_count + self.allocated_ip_addresses = allocated_ip_addresses + + +class VpnClientConnectionHealthDetail(msrest.serialization.Model): + """VPN client connection health detail. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar vpn_connection_id: The vpn client Id. + :vartype vpn_connection_id: str + :ivar vpn_connection_duration: The duration time of a connected vpn client. + :vartype vpn_connection_duration: long + :ivar vpn_connection_time: The start time of a connected vpn client. + :vartype vpn_connection_time: str + :ivar public_ip_address: The public Ip of a connected vpn client. + :vartype public_ip_address: str + :ivar private_ip_address: The assigned private Ip of a connected vpn client. + :vartype private_ip_address: str + :ivar vpn_user_name: The user name of a connected vpn client. + :vartype vpn_user_name: str + :ivar max_bandwidth: The max band width. + :vartype max_bandwidth: long + :ivar egress_packets_transferred: The egress packets per second. + :vartype egress_packets_transferred: long + :ivar egress_bytes_transferred: The egress bytes per second. + :vartype egress_bytes_transferred: long + :ivar ingress_packets_transferred: The ingress packets per second. + :vartype ingress_packets_transferred: long + :ivar ingress_bytes_transferred: The ingress bytes per second. + :vartype ingress_bytes_transferred: long + :ivar max_packets_per_second: The max packets transferred per second. + :vartype max_packets_per_second: long + """ + + _validation = { + 'vpn_connection_id': {'readonly': True}, + 'vpn_connection_duration': {'readonly': True}, + 'vpn_connection_time': {'readonly': True}, + 'public_ip_address': {'readonly': True}, + 'private_ip_address': {'readonly': True}, + 'vpn_user_name': {'readonly': True}, + 'max_bandwidth': {'readonly': True}, + 'egress_packets_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'ingress_packets_transferred': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'max_packets_per_second': {'readonly': True}, + } + + _attribute_map = { + 'vpn_connection_id': {'key': 'vpnConnectionId', 'type': 'str'}, + 'vpn_connection_duration': {'key': 'vpnConnectionDuration', 'type': 'long'}, + 'vpn_connection_time': {'key': 'vpnConnectionTime', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + 'vpn_user_name': {'key': 'vpnUserName', 'type': 'str'}, + 'max_bandwidth': {'key': 'maxBandwidth', 'type': 'long'}, + 'egress_packets_transferred': {'key': 'egressPacketsTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'egressBytesTransferred', 'type': 'long'}, + 'ingress_packets_transferred': {'key': 'ingressPacketsTransferred', 'type': 'long'}, + 'ingress_bytes_transferred': {'key': 'ingressBytesTransferred', 'type': 'long'}, + 'max_packets_per_second': {'key': 'maxPacketsPerSecond', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnClientConnectionHealthDetail, self).__init__(**kwargs) + self.vpn_connection_id = None + self.vpn_connection_duration = None + self.vpn_connection_time = None + self.public_ip_address = None + self.private_ip_address = None + self.vpn_user_name = None + self.max_bandwidth = None + self.egress_packets_transferred = None + self.egress_bytes_transferred = None + self.ingress_packets_transferred = None + self.ingress_bytes_transferred = None + self.max_packets_per_second = None + + +class VpnClientConnectionHealthDetailListResult(msrest.serialization.Model): + """List of virtual network gateway vpn client connection health. + + :param value: List of vpn client connection health. + :type value: list[~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealthDetail] + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[VpnClientConnectionHealthDetail]'}, + } + + def __init__( + self, + *, + value: Optional[List["VpnClientConnectionHealthDetail"]] = None, + **kwargs + ): + super(VpnClientConnectionHealthDetailListResult, self).__init__(**kwargs) + self.value = value + + +class VpnClientIPsecParameters(msrest.serialization.Model): + """An IPSec parameters for a virtual network gateway P2S connection. + + All required parameters must be populated in order to send to Azure. + + :param sa_life_time_seconds: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) lifetime in seconds for P2S client. + :type sa_life_time_seconds: int + :param sa_data_size_kilobytes: Required. The IPSec Security Association (also called Quick Mode + or Phase 2 SA) payload size in KB for P2S client.. + :type sa_data_size_kilobytes: int + :param ipsec_encryption: Required. The IPSec encryption algorithm (IKE phase 1). Possible + values include: "None", "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES128", "GCMAES192", + "GCMAES256". + :type ipsec_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IpsecEncryption + :param ipsec_integrity: Required. The IPSec integrity algorithm (IKE phase 1). Possible values + include: "MD5", "SHA1", "SHA256", "GCMAES128", "GCMAES192", "GCMAES256". + :type ipsec_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IpsecIntegrity + :param ike_encryption: Required. The IKE encryption algorithm (IKE phase 2). Possible values + include: "DES", "DES3", "AES128", "AES192", "AES256", "GCMAES256", "GCMAES128". + :type ike_encryption: str or ~azure.mgmt.network.v2020_08_01.models.IkeEncryption + :param ike_integrity: Required. The IKE integrity algorithm (IKE phase 2). Possible values + include: "MD5", "SHA1", "SHA256", "SHA384", "GCMAES256", "GCMAES128". + :type ike_integrity: str or ~azure.mgmt.network.v2020_08_01.models.IkeIntegrity + :param dh_group: Required. The DH Group used in IKE Phase 1 for initial SA. Possible values + include: "None", "DHGroup1", "DHGroup2", "DHGroup14", "DHGroup2048", "ECP256", "ECP384", + "DHGroup24". + :type dh_group: str or ~azure.mgmt.network.v2020_08_01.models.DhGroup + :param pfs_group: Required. The Pfs Group used in IKE Phase 2 for new child SA. Possible values + include: "None", "PFS1", "PFS2", "PFS2048", "ECP256", "ECP384", "PFS24", "PFS14", "PFSMM". + :type pfs_group: str or ~azure.mgmt.network.v2020_08_01.models.PfsGroup + """ + + _validation = { + 'sa_life_time_seconds': {'required': True}, + 'sa_data_size_kilobytes': {'required': True}, + 'ipsec_encryption': {'required': True}, + 'ipsec_integrity': {'required': True}, + 'ike_encryption': {'required': True}, + 'ike_integrity': {'required': True}, + 'dh_group': {'required': True}, + 'pfs_group': {'required': True}, + } + + _attribute_map = { + 'sa_life_time_seconds': {'key': 'saLifeTimeSeconds', 'type': 'int'}, + 'sa_data_size_kilobytes': {'key': 'saDataSizeKilobytes', 'type': 'int'}, + 'ipsec_encryption': {'key': 'ipsecEncryption', 'type': 'str'}, + 'ipsec_integrity': {'key': 'ipsecIntegrity', 'type': 'str'}, + 'ike_encryption': {'key': 'ikeEncryption', 'type': 'str'}, + 'ike_integrity': {'key': 'ikeIntegrity', 'type': 'str'}, + 'dh_group': {'key': 'dhGroup', 'type': 'str'}, + 'pfs_group': {'key': 'pfsGroup', 'type': 'str'}, + } + + def __init__( + self, + *, + sa_life_time_seconds: int, + sa_data_size_kilobytes: int, + ipsec_encryption: Union[str, "IpsecEncryption"], + ipsec_integrity: Union[str, "IpsecIntegrity"], + ike_encryption: Union[str, "IkeEncryption"], + ike_integrity: Union[str, "IkeIntegrity"], + dh_group: Union[str, "DhGroup"], + pfs_group: Union[str, "PfsGroup"], + **kwargs + ): + super(VpnClientIPsecParameters, self).__init__(**kwargs) + self.sa_life_time_seconds = sa_life_time_seconds + self.sa_data_size_kilobytes = sa_data_size_kilobytes + self.ipsec_encryption = ipsec_encryption + self.ipsec_integrity = ipsec_integrity + self.ike_encryption = ike_encryption + self.ike_integrity = ike_integrity + self.dh_group = dh_group + self.pfs_group = pfs_group + + +class VpnClientParameters(msrest.serialization.Model): + """Vpn Client Parameters for package generation. + + :param processor_architecture: VPN client Processor Architecture. Possible values include: + "Amd64", "X86". + :type processor_architecture: str or + ~azure.mgmt.network.v2020_08_01.models.ProcessorArchitecture + :param authentication_method: VPN client authentication method. Possible values include: + "EAPTLS", "EAPMSCHAPv2". + :type authentication_method: str or ~azure.mgmt.network.v2020_08_01.models.AuthenticationMethod + :param radius_server_auth_certificate: The public certificate data for the radius server + authentication certificate as a Base-64 encoded string. Required only if external radius + authentication has been configured with EAPTLS authentication. + :type radius_server_auth_certificate: str + :param client_root_certificates: A list of client root certificates public certificate data + encoded as Base-64 strings. Optional parameter for external radius based authentication with + EAPTLS. + :type client_root_certificates: list[str] + """ + + _attribute_map = { + 'processor_architecture': {'key': 'processorArchitecture', 'type': 'str'}, + 'authentication_method': {'key': 'authenticationMethod', 'type': 'str'}, + 'radius_server_auth_certificate': {'key': 'radiusServerAuthCertificate', 'type': 'str'}, + 'client_root_certificates': {'key': 'clientRootCertificates', 'type': '[str]'}, + } + + def __init__( + self, + *, + processor_architecture: Optional[Union[str, "ProcessorArchitecture"]] = None, + authentication_method: Optional[Union[str, "AuthenticationMethod"]] = None, + radius_server_auth_certificate: Optional[str] = None, + client_root_certificates: Optional[List[str]] = None, + **kwargs + ): + super(VpnClientParameters, self).__init__(**kwargs) + self.processor_architecture = processor_architecture + self.authentication_method = authentication_method + self.radius_server_auth_certificate = radius_server_auth_certificate + self.client_root_certificates = client_root_certificates + + +class VpnClientRevokedCertificate(SubResource): + """VPN client revoked certificate of virtual network gateway. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param thumbprint: The revoked VPN client certificate thumbprint. + :type thumbprint: str + :ivar provisioning_state: The provisioning state of the VPN client revoked certificate + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + thumbprint: Optional[str] = None, + **kwargs + ): + super(VpnClientRevokedCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.thumbprint = thumbprint + self.provisioning_state = None + + +class VpnClientRootCertificate(SubResource): + """VPN client root certificate of virtual network gateway. + + Variables are only 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 id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param public_cert_data: Required. The certificate public data. + :type public_cert_data: str + :ivar provisioning_state: The provisioning state of the VPN client root certificate resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'public_cert_data': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'public_cert_data': {'key': 'properties.publicCertData', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + public_cert_data: str, + id: Optional[str] = None, + name: Optional[str] = None, + **kwargs + ): + super(VpnClientRootCertificate, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.public_cert_data = public_cert_data + self.provisioning_state = None + + +class VpnConnection(SubResource): + """VpnConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param remote_vpn_site: Id of the connected vpn site. + :type remote_vpn_site: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param routing_weight: Routing weight for vpn connection. + :type routing_weight: int + :param dpd_timeout_seconds: DPD timeout in seconds for vpn connection. + :type dpd_timeout_seconds: int + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.VpnConnectionStatus + :param vpn_connection_protocol_type: Connection protocol used for this connection. Possible + values include: "IKEv2", "IKEv1". + :type vpn_connection_protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :ivar ingress_bytes_transferred: Ingress bytes transferred. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: Egress bytes transferred. + :vartype egress_bytes_transferred: long + :param connection_bandwidth: Expected bandwidth in MBPS. + :type connection_bandwidth: int + :param shared_key: SharedKey for the vpn connection. + :type shared_key: str + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param enable_rate_limiting: EnableBgp flag. + :type enable_rate_limiting: bool + :param enable_internet_security: Enable internet security. + :type enable_internet_security: bool + :param use_local_azure_ip_address: Use local azure ip to initiate connection. + :type use_local_azure_ip_address: bool + :ivar provisioning_state: The provisioning state of the VPN connection resource. Possible + values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_link_connections: List of all vpn site link connections to the gateway. + :type vpn_link_connections: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection] + :param routing_configuration: The Routing Configuration indicating the associated and + propagated route tables on this connection. + :type routing_configuration: ~azure.mgmt.network.v2020_08_01.models.RoutingConfiguration + """ + + _validation = { + 'etag': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'remote_vpn_site': {'key': 'properties.remoteVpnSite', 'type': 'SubResource'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'dpd_timeout_seconds': {'key': 'properties.dpdTimeoutSeconds', 'type': 'int'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'vpn_connection_protocol_type': {'key': 'properties.vpnConnectionProtocolType', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'connection_bandwidth': {'key': 'properties.connectionBandwidth', 'type': 'int'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'enable_rate_limiting': {'key': 'properties.enableRateLimiting', 'type': 'bool'}, + 'enable_internet_security': {'key': 'properties.enableInternetSecurity', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_link_connections': {'key': 'properties.vpnLinkConnections', 'type': '[VpnSiteLinkConnection]'}, + 'routing_configuration': {'key': 'properties.routingConfiguration', 'type': 'RoutingConfiguration'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + remote_vpn_site: Optional["SubResource"] = None, + routing_weight: Optional[int] = None, + dpd_timeout_seconds: Optional[int] = None, + vpn_connection_protocol_type: Optional[Union[str, "VirtualNetworkGatewayConnectionProtocol"]] = None, + connection_bandwidth: Optional[int] = None, + shared_key: Optional[str] = None, + enable_bgp: Optional[bool] = None, + use_policy_based_traffic_selectors: Optional[bool] = None, + ipsec_policies: Optional[List["IpsecPolicy"]] = None, + enable_rate_limiting: Optional[bool] = None, + enable_internet_security: Optional[bool] = None, + use_local_azure_ip_address: Optional[bool] = None, + vpn_link_connections: Optional[List["VpnSiteLinkConnection"]] = None, + routing_configuration: Optional["RoutingConfiguration"] = None, + **kwargs + ): + super(VpnConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.remote_vpn_site = remote_vpn_site + self.routing_weight = routing_weight + self.dpd_timeout_seconds = dpd_timeout_seconds + self.connection_status = None + self.vpn_connection_protocol_type = vpn_connection_protocol_type + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.connection_bandwidth = connection_bandwidth + self.shared_key = shared_key + self.enable_bgp = enable_bgp + self.use_policy_based_traffic_selectors = use_policy_based_traffic_selectors + self.ipsec_policies = ipsec_policies + self.enable_rate_limiting = enable_rate_limiting + self.enable_internet_security = enable_internet_security + self.use_local_azure_ip_address = use_local_azure_ip_address + self.provisioning_state = None + self.vpn_link_connections = vpn_link_connections + self.routing_configuration = routing_configuration + + +class VpnConnectionPacketCaptureStartParameters(msrest.serialization.Model): + """Vpn Connection packet capture parameters supplied to start packet capture on gateway connection. + + :param filter_data: Start Packet capture parameters on vpn connection. + :type filter_data: str + :param link_connection_names: List of site link connection names. + :type link_connection_names: list[str] + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + 'link_connection_names': {'key': 'linkConnectionNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + filter_data: Optional[str] = None, + link_connection_names: Optional[List[str]] = None, + **kwargs + ): + super(VpnConnectionPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = filter_data + self.link_connection_names = link_connection_names + + +class VpnConnectionPacketCaptureStopParameters(msrest.serialization.Model): + """Vpn Connection packet capture parameters supplied to stop packet capture on gateway connection. + + :param sas_url: SAS url for packet capture on vpn connection. + :type sas_url: str + :param link_connection_names: List of site link connection names. + :type link_connection_names: list[str] + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'link_connection_names': {'key': 'linkConnectionNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + link_connection_names: Optional[List[str]] = None, + **kwargs + ): + super(VpnConnectionPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = sas_url + self.link_connection_names = link_connection_names + + +class VpnDeviceScriptParameters(msrest.serialization.Model): + """Vpn device configuration script generation parameters. + + :param vendor: The vendor for the vpn device. + :type vendor: str + :param device_family: The device family for the vpn device. + :type device_family: str + :param firmware_version: The firmware version for the vpn device. + :type firmware_version: str + """ + + _attribute_map = { + 'vendor': {'key': 'vendor', 'type': 'str'}, + 'device_family': {'key': 'deviceFamily', 'type': 'str'}, + 'firmware_version': {'key': 'firmwareVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + vendor: Optional[str] = None, + device_family: Optional[str] = None, + firmware_version: Optional[str] = None, + **kwargs + ): + super(VpnDeviceScriptParameters, self).__init__(**kwargs) + self.vendor = vendor + self.device_family = device_family + self.firmware_version = firmware_version + + +class VpnGateway(Resource): + """VpnGateway Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_hub: The VirtualHub to which the gateway belongs. + :type virtual_hub: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param connections: List of all vpn connections to the gateway. + :type connections: list[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :param bgp_settings: Local network gateway's BGP speaker settings. + :type bgp_settings: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar provisioning_state: The provisioning state of the VPN gateway resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param vpn_gateway_scale_unit: The scale unit for this vpn gateway. + :type vpn_gateway_scale_unit: int + :ivar ip_configurations: List of all IPs configured on the gateway. + :vartype ip_configurations: + list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayIpConfiguration] + :param is_routing_preference_internet: Enable Routing Preference property for the Public IP + Interface of the VpnGateway. + :type is_routing_preference_internet: bool + :param nat_rules: List of all the nat Rules associated with the gateway. + :type nat_rules: list[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'ip_configurations': {'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'}, + 'virtual_hub': {'key': 'properties.virtualHub', 'type': 'SubResource'}, + 'connections': {'key': 'properties.connections', 'type': '[VpnConnection]'}, + 'bgp_settings': {'key': 'properties.bgpSettings', 'type': 'BgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'vpn_gateway_scale_unit': {'key': 'properties.vpnGatewayScaleUnit', 'type': 'int'}, + 'ip_configurations': {'key': 'properties.ipConfigurations', 'type': '[VpnGatewayIpConfiguration]'}, + 'is_routing_preference_internet': {'key': 'properties.isRoutingPreferenceInternet', 'type': 'bool'}, + 'nat_rules': {'key': 'properties.natRules', 'type': '[VpnGatewayNatRule]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + virtual_hub: Optional["SubResource"] = None, + connections: Optional[List["VpnConnection"]] = None, + bgp_settings: Optional["BgpSettings"] = None, + vpn_gateway_scale_unit: Optional[int] = None, + is_routing_preference_internet: Optional[bool] = None, + nat_rules: Optional[List["VpnGatewayNatRule"]] = None, + **kwargs + ): + super(VpnGateway, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.virtual_hub = virtual_hub + self.connections = connections + self.bgp_settings = bgp_settings + self.provisioning_state = None + self.vpn_gateway_scale_unit = vpn_gateway_scale_unit + self.ip_configurations = None + self.is_routing_preference_internet = is_routing_preference_internet + self.nat_rules = nat_rules + + +class VpnGatewayIpConfiguration(msrest.serialization.Model): + """IP Configuration of a VPN Gateway Resource. + + :param id: The identifier of the IP configuration for a VPN Gateway. + :type id: str + :param public_ip_address: The public IP address of this IP configuration. + :type public_ip_address: str + :param private_ip_address: The private IP address of this IP configuration. + :type private_ip_address: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'public_ip_address': {'key': 'publicIpAddress', 'type': 'str'}, + 'private_ip_address': {'key': 'privateIpAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + public_ip_address: Optional[str] = None, + private_ip_address: Optional[str] = None, + **kwargs + ): + super(VpnGatewayIpConfiguration, self).__init__(**kwargs) + self.id = id + self.public_ip_address = public_ip_address + self.private_ip_address = private_ip_address + + +class VpnGatewayNatRule(SubResource): + """VpnGatewayNatRule Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :ivar provisioning_state: The provisioning state of the NAT Rule resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param type_properties_type: The type of NAT rule for VPN NAT. Possible values include: + "Static", "Dynamic". + :type type_properties_type: str or ~azure.mgmt.network.v2020_08_01.models.VpnNatRuleType + :param mode: The Source NAT direction of a VPN NAT. Possible values include: "EgressSnat", + "IngressSnat". + :type mode: str or ~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMode + :param internal_mappings: The private IP address internal mapping for NAT. + :type internal_mappings: list[~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMapping] + :param external_mappings: The private IP address external mapping for NAT. + :type external_mappings: list[~azure.mgmt.network.v2020_08_01.models.VpnNatRuleMapping] + :param ip_configuration_id: The IP Configuration ID this NAT rule applies to. + :type ip_configuration_id: str + :ivar egress_vpn_site_link_connections: List of egress VpnSiteLinkConnections. + :vartype egress_vpn_site_link_connections: + list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar ingress_vpn_site_link_connections: List of ingress VpnSiteLinkConnections. + :vartype ingress_vpn_site_link_connections: + list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'egress_vpn_site_link_connections': {'readonly': True}, + 'ingress_vpn_site_link_connections': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'type_properties_type': {'key': 'properties.type', 'type': 'str'}, + 'mode': {'key': 'properties.mode', 'type': 'str'}, + 'internal_mappings': {'key': 'properties.internalMappings', 'type': '[VpnNatRuleMapping]'}, + 'external_mappings': {'key': 'properties.externalMappings', 'type': '[VpnNatRuleMapping]'}, + 'ip_configuration_id': {'key': 'properties.ipConfigurationId', 'type': 'str'}, + 'egress_vpn_site_link_connections': {'key': 'properties.egressVpnSiteLinkConnections', 'type': '[SubResource]'}, + 'ingress_vpn_site_link_connections': {'key': 'properties.ingressVpnSiteLinkConnections', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + type_properties_type: Optional[Union[str, "VpnNatRuleType"]] = None, + mode: Optional[Union[str, "VpnNatRuleMode"]] = None, + internal_mappings: Optional[List["VpnNatRuleMapping"]] = None, + external_mappings: Optional[List["VpnNatRuleMapping"]] = None, + ip_configuration_id: Optional[str] = None, + **kwargs + ): + super(VpnGatewayNatRule, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.provisioning_state = None + self.type_properties_type = type_properties_type + self.mode = mode + self.internal_mappings = internal_mappings + self.external_mappings = external_mappings + self.ip_configuration_id = ip_configuration_id + self.egress_vpn_site_link_connections = None + self.ingress_vpn_site_link_connections = None + + +class VpnGatewayPacketCaptureStartParameters(msrest.serialization.Model): + """Start packet capture parameters. + + :param filter_data: Start Packet capture parameters on vpn gateway. + :type filter_data: str + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + } + + def __init__( + self, + *, + filter_data: Optional[str] = None, + **kwargs + ): + super(VpnGatewayPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = filter_data + + +class VpnGatewayPacketCaptureStopParameters(msrest.serialization.Model): + """Stop packet capture parameters. + + :param sas_url: SAS url for packet capture on vpn gateway. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + **kwargs + ): + super(VpnGatewayPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = sas_url + + +class VpnLinkBgpSettings(msrest.serialization.Model): + """BGP settings details for a link. + + :param asn: The BGP speaker's ASN. + :type asn: long + :param bgp_peering_address: The BGP peering address and BGP identifier of this BGP speaker. + :type bgp_peering_address: str + """ + + _attribute_map = { + 'asn': {'key': 'asn', 'type': 'long'}, + 'bgp_peering_address': {'key': 'bgpPeeringAddress', 'type': 'str'}, + } + + def __init__( + self, + *, + asn: Optional[int] = None, + bgp_peering_address: Optional[str] = None, + **kwargs + ): + super(VpnLinkBgpSettings, self).__init__(**kwargs) + self.asn = asn + self.bgp_peering_address = bgp_peering_address + + +class VpnLinkProviderProperties(msrest.serialization.Model): + """List of properties of a link provider. + + :param link_provider_name: Name of the link provider. + :type link_provider_name: str + :param link_speed_in_mbps: Link speed. + :type link_speed_in_mbps: int + """ + + _attribute_map = { + 'link_provider_name': {'key': 'linkProviderName', 'type': 'str'}, + 'link_speed_in_mbps': {'key': 'linkSpeedInMbps', 'type': 'int'}, + } + + def __init__( + self, + *, + link_provider_name: Optional[str] = None, + link_speed_in_mbps: Optional[int] = None, + **kwargs + ): + super(VpnLinkProviderProperties, self).__init__(**kwargs) + self.link_provider_name = link_provider_name + self.link_speed_in_mbps = link_speed_in_mbps + + +class VpnNatRuleMapping(msrest.serialization.Model): + """Vpn NatRule mapping. + + :param address_space: Address space for Vpn NatRule mapping. + :type address_space: str + """ + + _attribute_map = { + 'address_space': {'key': 'addressSpace', 'type': 'str'}, + } + + def __init__( + self, + *, + address_space: Optional[str] = None, + **kwargs + ): + super(VpnNatRuleMapping, self).__init__(**kwargs) + self.address_space = address_space + + +class VpnPacketCaptureStartParameters(msrest.serialization.Model): + """Start packet capture parameters on virtual network gateway. + + :param filter_data: Start Packet capture parameters. + :type filter_data: str + """ + + _attribute_map = { + 'filter_data': {'key': 'filterData', 'type': 'str'}, + } + + def __init__( + self, + *, + filter_data: Optional[str] = None, + **kwargs + ): + super(VpnPacketCaptureStartParameters, self).__init__(**kwargs) + self.filter_data = filter_data + + +class VpnPacketCaptureStopParameters(msrest.serialization.Model): + """Stop packet capture parameters. + + :param sas_url: SAS url for packet capture on virtual network gateway. + :type sas_url: str + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + **kwargs + ): + super(VpnPacketCaptureStopParameters, self).__init__(**kwargs) + self.sas_url = sas_url + + +class VpnProfileResponse(msrest.serialization.Model): + """Vpn Profile Response for package generation. + + :param profile_url: URL to the VPN profile. + :type profile_url: str + """ + + _attribute_map = { + 'profile_url': {'key': 'profileUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + profile_url: Optional[str] = None, + **kwargs + ): + super(VpnProfileResponse, self).__init__(**kwargs) + self.profile_url = profile_url + + +class VpnServerConfigRadiusClientRootCertificate(msrest.serialization.Model): + """Properties of the Radius client root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param thumbprint: The Radius client root certificate thumbprint. + :type thumbprint: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + thumbprint: Optional[str] = None, + **kwargs + ): + super(VpnServerConfigRadiusClientRootCertificate, self).__init__(**kwargs) + self.name = name + self.thumbprint = thumbprint + + +class VpnServerConfigRadiusServerRootCertificate(msrest.serialization.Model): + """Properties of Radius Server root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param public_cert_data: The certificate public data. + :type public_cert_data: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_cert_data': {'key': 'publicCertData', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + public_cert_data: Optional[str] = None, + **kwargs + ): + super(VpnServerConfigRadiusServerRootCertificate, self).__init__(**kwargs) + self.name = name + self.public_cert_data = public_cert_data + + +class VpnServerConfiguration(Resource): + """VpnServerConfiguration Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param name_properties_name: The name of the VpnServerConfiguration that is unique within a + resource group. + :type name_properties_name: str + :param vpn_protocols: VPN protocols for the VpnServerConfiguration. + :type vpn_protocols: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnGatewayTunnelingProtocol] + :param vpn_authentication_types: VPN authentication types for the VpnServerConfiguration. + :type vpn_authentication_types: list[str or + ~azure.mgmt.network.v2020_08_01.models.VpnAuthenticationType] + :param vpn_client_root_certificates: VPN client root certificate of VpnServerConfiguration. + :type vpn_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigVpnClientRootCertificate] + :param vpn_client_revoked_certificates: VPN client revoked certificate of + VpnServerConfiguration. + :type vpn_client_revoked_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigVpnClientRevokedCertificate] + :param radius_server_root_certificates: Radius Server root certificate of + VpnServerConfiguration. + :type radius_server_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigRadiusServerRootCertificate] + :param radius_client_root_certificates: Radius client root certificate of + VpnServerConfiguration. + :type radius_client_root_certificates: + list[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigRadiusClientRootCertificate] + :param vpn_client_ipsec_policies: VpnClientIpsecPolicies for VpnServerConfiguration. + :type vpn_client_ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param radius_server_address: The radius server address property of the VpnServerConfiguration + resource for point to site client connection. + :type radius_server_address: str + :param radius_server_secret: The radius secret property of the VpnServerConfiguration resource + for point to site client connection. + :type radius_server_secret: str + :param radius_servers: Multiple Radius Server configuration for VpnServerConfiguration. + :type radius_servers: list[~azure.mgmt.network.v2020_08_01.models.RadiusServer] + :param aad_authentication_parameters: The set of aad vpn authentication parameters. + :type aad_authentication_parameters: + ~azure.mgmt.network.v2020_08_01.models.AadAuthenticationParameters + :ivar provisioning_state: The provisioning state of the VpnServerConfiguration resource. + Possible values are: 'Updating', 'Deleting', and 'Failed'. + :vartype provisioning_state: str + :ivar p2_s_vpn_gateways: List of references to P2SVpnGateways. + :vartype p2_s_vpn_gateways: list[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :ivar etag_properties_etag: A unique read-only string that changes whenever the resource is + updated. + :vartype etag_properties_etag: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'p2_s_vpn_gateways': {'readonly': True}, + 'etag_properties_etag': {'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'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'vpn_protocols': {'key': 'properties.vpnProtocols', 'type': '[str]'}, + 'vpn_authentication_types': {'key': 'properties.vpnAuthenticationTypes', 'type': '[str]'}, + 'vpn_client_root_certificates': {'key': 'properties.vpnClientRootCertificates', 'type': '[VpnServerConfigVpnClientRootCertificate]'}, + 'vpn_client_revoked_certificates': {'key': 'properties.vpnClientRevokedCertificates', 'type': '[VpnServerConfigVpnClientRevokedCertificate]'}, + 'radius_server_root_certificates': {'key': 'properties.radiusServerRootCertificates', 'type': '[VpnServerConfigRadiusServerRootCertificate]'}, + 'radius_client_root_certificates': {'key': 'properties.radiusClientRootCertificates', 'type': '[VpnServerConfigRadiusClientRootCertificate]'}, + 'vpn_client_ipsec_policies': {'key': 'properties.vpnClientIpsecPolicies', 'type': '[IpsecPolicy]'}, + 'radius_server_address': {'key': 'properties.radiusServerAddress', 'type': 'str'}, + 'radius_server_secret': {'key': 'properties.radiusServerSecret', 'type': 'str'}, + 'radius_servers': {'key': 'properties.radiusServers', 'type': '[RadiusServer]'}, + 'aad_authentication_parameters': {'key': 'properties.aadAuthenticationParameters', 'type': 'AadAuthenticationParameters'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'p2_s_vpn_gateways': {'key': 'properties.p2SVpnGateways', 'type': '[P2SVpnGateway]'}, + 'etag_properties_etag': {'key': 'properties.etag', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + name_properties_name: Optional[str] = None, + vpn_protocols: Optional[List[Union[str, "VpnGatewayTunnelingProtocol"]]] = None, + vpn_authentication_types: Optional[List[Union[str, "VpnAuthenticationType"]]] = None, + vpn_client_root_certificates: Optional[List["VpnServerConfigVpnClientRootCertificate"]] = None, + vpn_client_revoked_certificates: Optional[List["VpnServerConfigVpnClientRevokedCertificate"]] = None, + radius_server_root_certificates: Optional[List["VpnServerConfigRadiusServerRootCertificate"]] = None, + radius_client_root_certificates: Optional[List["VpnServerConfigRadiusClientRootCertificate"]] = None, + vpn_client_ipsec_policies: Optional[List["IpsecPolicy"]] = None, + radius_server_address: Optional[str] = None, + radius_server_secret: Optional[str] = None, + radius_servers: Optional[List["RadiusServer"]] = None, + aad_authentication_parameters: Optional["AadAuthenticationParameters"] = None, + **kwargs + ): + super(VpnServerConfiguration, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.name_properties_name = name_properties_name + self.vpn_protocols = vpn_protocols + self.vpn_authentication_types = vpn_authentication_types + self.vpn_client_root_certificates = vpn_client_root_certificates + self.vpn_client_revoked_certificates = vpn_client_revoked_certificates + self.radius_server_root_certificates = radius_server_root_certificates + self.radius_client_root_certificates = radius_client_root_certificates + self.vpn_client_ipsec_policies = vpn_client_ipsec_policies + self.radius_server_address = radius_server_address + self.radius_server_secret = radius_server_secret + self.radius_servers = radius_servers + self.aad_authentication_parameters = aad_authentication_parameters + self.provisioning_state = None + self.p2_s_vpn_gateways = None + self.etag_properties_etag = None + + +class VpnServerConfigurationsResponse(msrest.serialization.Model): + """VpnServerConfigurations list associated with VirtualWan Response. + + :param vpn_server_configuration_resource_ids: List of VpnServerConfigurations associated with + VirtualWan. + :type vpn_server_configuration_resource_ids: list[str] + """ + + _attribute_map = { + 'vpn_server_configuration_resource_ids': {'key': 'vpnServerConfigurationResourceIds', 'type': '[str]'}, + } + + def __init__( + self, + *, + vpn_server_configuration_resource_ids: Optional[List[str]] = None, + **kwargs + ): + super(VpnServerConfigurationsResponse, self).__init__(**kwargs) + self.vpn_server_configuration_resource_ids = vpn_server_configuration_resource_ids + + +class VpnServerConfigVpnClientRevokedCertificate(msrest.serialization.Model): + """Properties of the revoked VPN client certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param thumbprint: The revoked VPN client certificate thumbprint. + :type thumbprint: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + thumbprint: Optional[str] = None, + **kwargs + ): + super(VpnServerConfigVpnClientRevokedCertificate, self).__init__(**kwargs) + self.name = name + self.thumbprint = thumbprint + + +class VpnServerConfigVpnClientRootCertificate(msrest.serialization.Model): + """Properties of VPN client root certificate of VpnServerConfiguration. + + :param name: The certificate name. + :type name: str + :param public_cert_data: The certificate public data. + :type public_cert_data: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'public_cert_data': {'key': 'publicCertData', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + public_cert_data: Optional[str] = None, + **kwargs + ): + super(VpnServerConfigVpnClientRootCertificate, self).__init__(**kwargs) + self.name = name + self.public_cert_data = public_cert_data + + +class VpnSite(Resource): + """VpnSite Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param virtual_wan: The VirtualWAN to which the vpnSite belongs. + :type virtual_wan: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param device_properties: The device properties. + :type device_properties: ~azure.mgmt.network.v2020_08_01.models.DeviceProperties + :param ip_address: The ip-address for the vpn-site. + :type ip_address: str + :param site_key: The key for vpn-site that can be used for connections. + :type site_key: str + :param address_space: The AddressSpace that contains an array of IP address ranges. + :type address_space: ~azure.mgmt.network.v2020_08_01.models.AddressSpace + :param bgp_properties: The set of bgp properties. + :type bgp_properties: ~azure.mgmt.network.v2020_08_01.models.BgpSettings + :ivar provisioning_state: The provisioning state of the VPN site resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param is_security_site: IsSecuritySite flag. + :type is_security_site: bool + :param vpn_site_links: List of all vpn site links. + :type vpn_site_links: list[~azure.mgmt.network.v2020_08_01.models.VpnSiteLink] + :param o365_policy: Office365 Policy. + :type o365_policy: ~azure.mgmt.network.v2020_08_01.models.O365PolicyProperties + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'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'}, + 'virtual_wan': {'key': 'properties.virtualWan', 'type': 'SubResource'}, + 'device_properties': {'key': 'properties.deviceProperties', 'type': 'DeviceProperties'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'site_key': {'key': 'properties.siteKey', 'type': 'str'}, + 'address_space': {'key': 'properties.addressSpace', 'type': 'AddressSpace'}, + 'bgp_properties': {'key': 'properties.bgpProperties', 'type': 'BgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'is_security_site': {'key': 'properties.isSecuritySite', 'type': 'bool'}, + 'vpn_site_links': {'key': 'properties.vpnSiteLinks', 'type': '[VpnSiteLink]'}, + 'o365_policy': {'key': 'properties.o365Policy', 'type': 'O365PolicyProperties'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + virtual_wan: Optional["SubResource"] = None, + device_properties: Optional["DeviceProperties"] = None, + ip_address: Optional[str] = None, + site_key: Optional[str] = None, + address_space: Optional["AddressSpace"] = None, + bgp_properties: Optional["BgpSettings"] = None, + is_security_site: Optional[bool] = None, + vpn_site_links: Optional[List["VpnSiteLink"]] = None, + o365_policy: Optional["O365PolicyProperties"] = None, + **kwargs + ): + super(VpnSite, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.virtual_wan = virtual_wan + self.device_properties = device_properties + self.ip_address = ip_address + self.site_key = site_key + self.address_space = address_space + self.bgp_properties = bgp_properties + self.provisioning_state = None + self.is_security_site = is_security_site + self.vpn_site_links = vpn_site_links + self.o365_policy = o365_policy + + +class VpnSiteId(msrest.serialization.Model): + """VpnSite Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar vpn_site: The resource-uri of the vpn-site for which config is to be fetched. + :vartype vpn_site: str + """ + + _validation = { + 'vpn_site': {'readonly': True}, + } + + _attribute_map = { + 'vpn_site': {'key': 'vpnSite', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VpnSiteId, self).__init__(**kwargs) + self.vpn_site = None + + +class VpnSiteLink(SubResource): + """VpnSiteLink Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar type: Resource type. + :vartype type: str + :param link_properties: The link provider properties. + :type link_properties: ~azure.mgmt.network.v2020_08_01.models.VpnLinkProviderProperties + :param ip_address: The ip-address for the vpn-site-link. + :type ip_address: str + :param fqdn: FQDN of vpn-site-link. + :type fqdn: str + :param bgp_properties: The set of bgp properties. + :type bgp_properties: ~azure.mgmt.network.v2020_08_01.models.VpnLinkBgpSettings + :ivar provisioning_state: The provisioning state of the VPN site link resource. Possible values + include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'link_properties': {'key': 'properties.linkProperties', 'type': 'VpnLinkProviderProperties'}, + 'ip_address': {'key': 'properties.ipAddress', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'bgp_properties': {'key': 'properties.bgpProperties', 'type': 'VpnLinkBgpSettings'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + link_properties: Optional["VpnLinkProviderProperties"] = None, + ip_address: Optional[str] = None, + fqdn: Optional[str] = None, + bgp_properties: Optional["VpnLinkBgpSettings"] = None, + **kwargs + ): + super(VpnSiteLink, self).__init__(id=id, **kwargs) + self.etag = None + self.name = name + self.type = None + self.link_properties = link_properties + self.ip_address = ip_address + self.fqdn = fqdn + self.bgp_properties = bgp_properties + self.provisioning_state = None + + +class VpnSiteLinkConnection(SubResource): + """VpnSiteLinkConnection Resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type id: str + :param name: The name of the resource that is unique within a resource group. This name can be + used to access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :ivar type: Resource type. + :vartype type: str + :param vpn_site_link: Id of the connected vpn site link. + :type vpn_site_link: ~azure.mgmt.network.v2020_08_01.models.SubResource + :param routing_weight: Routing weight for vpn connection. + :type routing_weight: int + :param vpn_link_connection_mode: Vpn link connection mode. Possible values include: "Default", + "ResponderOnly", "InitiatorOnly". + :type vpn_link_connection_mode: str or + ~azure.mgmt.network.v2020_08_01.models.VpnLinkConnectionMode + :ivar connection_status: The connection status. Possible values include: "Unknown", + "Connecting", "Connected", "NotConnected". + :vartype connection_status: str or ~azure.mgmt.network.v2020_08_01.models.VpnConnectionStatus + :param vpn_connection_protocol_type: Connection protocol used for this connection. Possible + values include: "IKEv2", "IKEv1". + :type vpn_connection_protocol_type: str or + ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionProtocol + :ivar ingress_bytes_transferred: Ingress bytes transferred. + :vartype ingress_bytes_transferred: long + :ivar egress_bytes_transferred: Egress bytes transferred. + :vartype egress_bytes_transferred: long + :param connection_bandwidth: Expected bandwidth in MBPS. + :type connection_bandwidth: int + :param shared_key: SharedKey for the vpn connection. + :type shared_key: str + :param enable_bgp: EnableBgp flag. + :type enable_bgp: bool + :param use_policy_based_traffic_selectors: Enable policy-based traffic selectors. + :type use_policy_based_traffic_selectors: bool + :param ipsec_policies: The IPSec Policies to be considered by this connection. + :type ipsec_policies: list[~azure.mgmt.network.v2020_08_01.models.IpsecPolicy] + :param enable_rate_limiting: EnableBgp flag. + :type enable_rate_limiting: bool + :param use_local_azure_ip_address: Use local azure ip to initiate connection. + :type use_local_azure_ip_address: bool + :ivar provisioning_state: The provisioning state of the VPN site link connection resource. + Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :param ingress_nat_rules: List of ingress NatRules. + :type ingress_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :param egress_nat_rules: List of egress NatRules. + :type egress_nat_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'etag': {'readonly': True}, + 'type': {'readonly': True}, + 'connection_status': {'readonly': True}, + 'ingress_bytes_transferred': {'readonly': True}, + 'egress_bytes_transferred': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vpn_site_link': {'key': 'properties.vpnSiteLink', 'type': 'SubResource'}, + 'routing_weight': {'key': 'properties.routingWeight', 'type': 'int'}, + 'vpn_link_connection_mode': {'key': 'properties.vpnLinkConnectionMode', 'type': 'str'}, + 'connection_status': {'key': 'properties.connectionStatus', 'type': 'str'}, + 'vpn_connection_protocol_type': {'key': 'properties.vpnConnectionProtocolType', 'type': 'str'}, + 'ingress_bytes_transferred': {'key': 'properties.ingressBytesTransferred', 'type': 'long'}, + 'egress_bytes_transferred': {'key': 'properties.egressBytesTransferred', 'type': 'long'}, + 'connection_bandwidth': {'key': 'properties.connectionBandwidth', 'type': 'int'}, + 'shared_key': {'key': 'properties.sharedKey', 'type': 'str'}, + 'enable_bgp': {'key': 'properties.enableBgp', 'type': 'bool'}, + 'use_policy_based_traffic_selectors': {'key': 'properties.usePolicyBasedTrafficSelectors', 'type': 'bool'}, + 'ipsec_policies': {'key': 'properties.ipsecPolicies', 'type': '[IpsecPolicy]'}, + 'enable_rate_limiting': {'key': 'properties.enableRateLimiting', 'type': 'bool'}, + 'use_local_azure_ip_address': {'key': 'properties.useLocalAzureIpAddress', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'ingress_nat_rules': {'key': 'properties.ingressNatRules', 'type': '[SubResource]'}, + 'egress_nat_rules': {'key': 'properties.egressNatRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + vpn_site_link: Optional["SubResource"] = None, + routing_weight: Optional[int] = None, + vpn_link_connection_mode: Optional[Union[str, "VpnLinkConnectionMode"]] = None, + vpn_connection_protocol_type: Optional[Union[str, "VirtualNetworkGatewayConnectionProtocol"]] = None, + connection_bandwidth: Optional[int] = None, + shared_key: Optional[str] = None, + enable_bgp: Optional[bool] = None, + use_policy_based_traffic_selectors: Optional[bool] = None, + ipsec_policies: Optional[List["IpsecPolicy"]] = None, + enable_rate_limiting: Optional[bool] = None, + use_local_azure_ip_address: Optional[bool] = None, + ingress_nat_rules: Optional[List["SubResource"]] = None, + egress_nat_rules: Optional[List["SubResource"]] = None, + **kwargs + ): + super(VpnSiteLinkConnection, self).__init__(id=id, **kwargs) + self.name = name + self.etag = None + self.type = None + self.vpn_site_link = vpn_site_link + self.routing_weight = routing_weight + self.vpn_link_connection_mode = vpn_link_connection_mode + self.connection_status = None + self.vpn_connection_protocol_type = vpn_connection_protocol_type + self.ingress_bytes_transferred = None + self.egress_bytes_transferred = None + self.connection_bandwidth = connection_bandwidth + self.shared_key = shared_key + self.enable_bgp = enable_bgp + self.use_policy_based_traffic_selectors = use_policy_based_traffic_selectors + self.ipsec_policies = ipsec_policies + self.enable_rate_limiting = enable_rate_limiting + self.use_local_azure_ip_address = use_local_azure_ip_address + self.provisioning_state = None + self.ingress_nat_rules = ingress_nat_rules + self.egress_nat_rules = egress_nat_rules + + +class WebApplicationFirewallCustomRule(msrest.serialization.Model): + """Defines contents of a web application rule. + + Variables are only 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: The name of the resource that is unique within a policy. This name can be used to + access the resource. + :type name: str + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param priority: Required. Priority of the rule. Rules with a lower value will be evaluated + before rules with a higher value. + :type priority: int + :param rule_type: Required. The rule type. Possible values include: "MatchRule", "Invalid". + :type rule_type: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallRuleType + :param match_conditions: Required. List of match conditions. + :type match_conditions: list[~azure.mgmt.network.v2020_08_01.models.MatchCondition] + :param action: Required. Type of Actions. Possible values include: "Allow", "Block", "Log". + :type action: str or ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallAction + """ + + _validation = { + 'name': {'max_length': 128, 'min_length': 0}, + 'etag': {'readonly': True}, + 'priority': {'required': True}, + 'rule_type': {'required': True}, + 'match_conditions': {'required': True}, + 'action': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'rule_type': {'key': 'ruleType', 'type': 'str'}, + 'match_conditions': {'key': 'matchConditions', 'type': '[MatchCondition]'}, + 'action': {'key': 'action', 'type': 'str'}, + } + + def __init__( + self, + *, + priority: int, + rule_type: Union[str, "WebApplicationFirewallRuleType"], + match_conditions: List["MatchCondition"], + action: Union[str, "WebApplicationFirewallAction"], + name: Optional[str] = None, + **kwargs + ): + super(WebApplicationFirewallCustomRule, self).__init__(**kwargs) + self.name = name + self.etag = None + self.priority = priority + self.rule_type = rule_type + self.match_conditions = match_conditions + self.action = action + + +class WebApplicationFirewallPolicy(Resource): + """Defines web application firewall policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID. + :type 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] + :ivar etag: A unique read-only string that changes whenever the resource is updated. + :vartype etag: str + :param policy_settings: The PolicySettings for policy. + :type policy_settings: ~azure.mgmt.network.v2020_08_01.models.PolicySettings + :param custom_rules: The custom rules inside the policy. + :type custom_rules: + list[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallCustomRule] + :ivar application_gateways: A collection of references to application gateways. + :vartype application_gateways: list[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :ivar provisioning_state: The provisioning state of the web application firewall policy + resource. Possible values include: "Succeeded", "Updating", "Deleting", "Failed". + :vartype provisioning_state: str or ~azure.mgmt.network.v2020_08_01.models.ProvisioningState + :ivar resource_state: Resource status of the policy. Possible values include: "Creating", + "Enabling", "Enabled", "Disabling", "Disabled", "Deleting". + :vartype resource_state: str or + ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyResourceState + :param managed_rules: Describes the managedRules structure. + :type managed_rules: ~azure.mgmt.network.v2020_08_01.models.ManagedRulesDefinition + :ivar http_listeners: A collection of references to application gateway http listeners. + :vartype http_listeners: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + :ivar path_based_rules: A collection of references to application gateway path rules. + :vartype path_based_rules: list[~azure.mgmt.network.v2020_08_01.models.SubResource] + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'etag': {'readonly': True}, + 'application_gateways': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'resource_state': {'readonly': True}, + 'http_listeners': {'readonly': True}, + 'path_based_rules': {'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'}, + 'policy_settings': {'key': 'properties.policySettings', 'type': 'PolicySettings'}, + 'custom_rules': {'key': 'properties.customRules', 'type': '[WebApplicationFirewallCustomRule]'}, + 'application_gateways': {'key': 'properties.applicationGateways', 'type': '[ApplicationGateway]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'resource_state': {'key': 'properties.resourceState', 'type': 'str'}, + 'managed_rules': {'key': 'properties.managedRules', 'type': 'ManagedRulesDefinition'}, + 'http_listeners': {'key': 'properties.httpListeners', 'type': '[SubResource]'}, + 'path_based_rules': {'key': 'properties.pathBasedRules', 'type': '[SubResource]'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + policy_settings: Optional["PolicySettings"] = None, + custom_rules: Optional[List["WebApplicationFirewallCustomRule"]] = None, + managed_rules: Optional["ManagedRulesDefinition"] = None, + **kwargs + ): + super(WebApplicationFirewallPolicy, self).__init__(id=id, location=location, tags=tags, **kwargs) + self.etag = None + self.policy_settings = policy_settings + self.custom_rules = custom_rules + self.application_gateways = None + self.provisioning_state = None + self.resource_state = None + self.managed_rules = managed_rules + self.http_listeners = None + self.path_based_rules = None + + +class WebApplicationFirewallPolicyListResult(msrest.serialization.Model): + """Result of the request to list WebApplicationFirewallPolicies. It contains a list of WebApplicationFirewallPolicy objects and a URL link to get the next set of results. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar value: List of WebApplicationFirewallPolicies within a resource group. + :vartype value: list[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy] + :ivar next_link: URL to get the next set of WebApplicationFirewallPolicy objects if there are + any. + :vartype next_link: str + """ + + _validation = { + 'value': {'readonly': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebApplicationFirewallPolicy]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebApplicationFirewallPolicyListResult, self).__init__(**kwargs) + self.value = None + self.next_link = None diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_network_management_client_enums.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_network_management_client_enums.py new file mode 100644 index 000000000000..c59baa4b496a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/models/_network_management_client_enums.py @@ -0,0 +1,1340 @@ +# 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)): + """Access to be allowed or denied. + """ + + ALLOW = "Allow" + DENY = "Deny" + +class ApplicationGatewayBackendHealthServerHealth(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Health of backend server. + """ + + UNKNOWN = "Unknown" + UP = "Up" + DOWN = "Down" + PARTIAL = "Partial" + DRAINING = "Draining" + +class ApplicationGatewayCookieBasedAffinity(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Cookie based affinity. + """ + + ENABLED = "Enabled" + DISABLED = "Disabled" + +class ApplicationGatewayCustomErrorStatusCode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status code of the application gateway customer error. + """ + + HTTP_STATUS403 = "HttpStatus403" + HTTP_STATUS502 = "HttpStatus502" + +class ApplicationGatewayFirewallMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Web application firewall mode. + """ + + DETECTION = "Detection" + PREVENTION = "Prevention" + +class ApplicationGatewayOperationalState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Operational state of the application gateway resource. + """ + + STOPPED = "Stopped" + STARTING = "Starting" + RUNNING = "Running" + STOPPING = "Stopping" + +class ApplicationGatewayProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Application Gateway protocol. + """ + + HTTP = "Http" + HTTPS = "Https" + +class ApplicationGatewayRedirectType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Redirect type enum. + """ + + PERMANENT = "Permanent" + FOUND = "Found" + SEE_OTHER = "SeeOther" + TEMPORARY = "Temporary" + +class ApplicationGatewayRequestRoutingRuleType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Rule type. + """ + + BASIC = "Basic" + PATH_BASED_ROUTING = "PathBasedRouting" + +class ApplicationGatewaySkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of an application gateway SKU. + """ + + STANDARD_SMALL = "Standard_Small" + STANDARD_MEDIUM = "Standard_Medium" + STANDARD_LARGE = "Standard_Large" + WAF_MEDIUM = "WAF_Medium" + WAF_LARGE = "WAF_Large" + STANDARD_V2 = "Standard_v2" + WAF_V2 = "WAF_v2" + +class ApplicationGatewaySslCipherSuite(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Ssl cipher suites enums. + """ + + TLS_ECDHE_RSA_WITH_AES256_CBC_SHA384 = "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384" + TLS_ECDHE_RSA_WITH_AES128_CBC_SHA256 = "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256" + TLS_ECDHE_RSA_WITH_AES256_CBC_SHA = "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA" + TLS_ECDHE_RSA_WITH_AES128_CBC_SHA = "TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA" + TLS_DHE_RSA_WITH_AES256_GCM_SHA384 = "TLS_DHE_RSA_WITH_AES_256_GCM_SHA384" + TLS_DHE_RSA_WITH_AES128_GCM_SHA256 = "TLS_DHE_RSA_WITH_AES_128_GCM_SHA256" + TLS_DHE_RSA_WITH_AES256_CBC_SHA = "TLS_DHE_RSA_WITH_AES_256_CBC_SHA" + TLS_DHE_RSA_WITH_AES128_CBC_SHA = "TLS_DHE_RSA_WITH_AES_128_CBC_SHA" + TLS_RSA_WITH_AES256_GCM_SHA384 = "TLS_RSA_WITH_AES_256_GCM_SHA384" + TLS_RSA_WITH_AES128_GCM_SHA256 = "TLS_RSA_WITH_AES_128_GCM_SHA256" + TLS_RSA_WITH_AES256_CBC_SHA256 = "TLS_RSA_WITH_AES_256_CBC_SHA256" + TLS_RSA_WITH_AES128_CBC_SHA256 = "TLS_RSA_WITH_AES_128_CBC_SHA256" + TLS_RSA_WITH_AES256_CBC_SHA = "TLS_RSA_WITH_AES_256_CBC_SHA" + TLS_RSA_WITH_AES128_CBC_SHA = "TLS_RSA_WITH_AES_128_CBC_SHA" + TLS_ECDHE_ECDSA_WITH_AES256_GCM_SHA384 = "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384" + TLS_ECDHE_ECDSA_WITH_AES128_GCM_SHA256 = "TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256" + TLS_ECDHE_ECDSA_WITH_AES256_CBC_SHA384 = "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384" + TLS_ECDHE_ECDSA_WITH_AES128_CBC_SHA256 = "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256" + TLS_ECDHE_ECDSA_WITH_AES256_CBC_SHA = "TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA" + TLS_ECDHE_ECDSA_WITH_AES128_CBC_SHA = "TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA" + TLS_DHE_DSS_WITH_AES256_CBC_SHA256 = "TLS_DHE_DSS_WITH_AES_256_CBC_SHA256" + TLS_DHE_DSS_WITH_AES128_CBC_SHA256 = "TLS_DHE_DSS_WITH_AES_128_CBC_SHA256" + TLS_DHE_DSS_WITH_AES256_CBC_SHA = "TLS_DHE_DSS_WITH_AES_256_CBC_SHA" + TLS_DHE_DSS_WITH_AES128_CBC_SHA = "TLS_DHE_DSS_WITH_AES_128_CBC_SHA" + TLS_RSA_WITH3_DES_EDE_CBC_SHA = "TLS_RSA_WITH_3DES_EDE_CBC_SHA" + TLS_DHE_DSS_WITH3_DES_EDE_CBC_SHA = "TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA" + TLS_ECDHE_RSA_WITH_AES128_GCM_SHA256 = "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256" + TLS_ECDHE_RSA_WITH_AES256_GCM_SHA384 = "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384" + +class ApplicationGatewaySslPolicyName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Ssl predefined policy name enums. + """ + + APP_GW_SSL_POLICY20150501 = "AppGwSslPolicy20150501" + APP_GW_SSL_POLICY20170401 = "AppGwSslPolicy20170401" + APP_GW_SSL_POLICY20170401_S = "AppGwSslPolicy20170401S" + +class ApplicationGatewaySslPolicyType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of Ssl Policy. + """ + + PREDEFINED = "Predefined" + CUSTOM = "Custom" + +class ApplicationGatewaySslProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Ssl protocol enums. + """ + + TL_SV1_0 = "TLSv1_0" + TL_SV1_1 = "TLSv1_1" + TL_SV1_2 = "TLSv1_2" + +class ApplicationGatewayTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of an application gateway. + """ + + STANDARD = "Standard" + WAF = "WAF" + STANDARD_V2 = "Standard_v2" + WAF_V2 = "WAF_v2" + +class AssociationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The association type of the child resource to the parent resource. + """ + + ASSOCIATED = "Associated" + CONTAINS = "Contains" + +class AuthenticationMethod(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """VPN client authentication method. + """ + + EAPTLS = "EAPTLS" + EAPMSCHA_PV2 = "EAPMSCHAPv2" + +class AuthorizationUseStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The authorization use status. + """ + + AVAILABLE = "Available" + IN_USE = "InUse" + +class AzureFirewallApplicationRuleProtocolType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol type of a Application Rule resource. + """ + + HTTP = "Http" + HTTPS = "Https" + MSSQL = "Mssql" + +class AzureFirewallNatRCActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action type of a NAT rule collection. + """ + + SNAT = "Snat" + DNAT = "Dnat" + +class AzureFirewallNetworkRuleProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol of a Network Rule resource. + """ + + TCP = "TCP" + UDP = "UDP" + ANY = "Any" + ICMP = "ICMP" + +class AzureFirewallRCActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action type of a rule collection. + """ + + ALLOW = "Allow" + DENY = "Deny" + +class AzureFirewallSkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of an Azure Firewall SKU. + """ + + AZFW_VNET = "AZFW_VNet" + AZFW_HUB = "AZFW_Hub" + +class AzureFirewallSkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of an Azure Firewall. + """ + + STANDARD = "Standard" + PREMIUM = "Premium" + +class AzureFirewallThreatIntelMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The operation mode for Threat Intel. + """ + + ALERT = "Alert" + DENY = "Deny" + OFF = "Off" + +class BastionConnectProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol used to connect to the target. + """ + + SSH = "SSH" + RDP = "RDP" + +class BgpPeerState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The BGP peer state. + """ + + UNKNOWN = "Unknown" + STOPPED = "Stopped" + IDLE = "Idle" + CONNECTING = "Connecting" + CONNECTED = "Connected" + +class CircuitConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Express Route Circuit connection state. + """ + + CONNECTED = "Connected" + CONNECTING = "Connecting" + DISCONNECTED = "Disconnected" + +class CommissionedState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The commissioned state of the Custom IP Prefix. + """ + + PROVISIONING = "Provisioning" + PROVISIONED = "Provisioned" + COMMISSIONING = "Commissioning" + COMMISSIONED = "Commissioned" + DECOMMISSIONING = "Decommissioning" + DEPROVISIONING = "Deprovisioning" + +class ConnectionMonitorEndpointFilterItemType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of item included in the filter. Currently only 'AgentAddress' is supported. + """ + + AGENT_ADDRESS = "AgentAddress" + +class ConnectionMonitorEndpointFilterType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The behavior of the endpoint filter. Currently only 'Include' is supported. + """ + + INCLUDE = "Include" + +class ConnectionMonitorSourceStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of connection monitor source. + """ + + UNKNOWN = "Unknown" + ACTIVE = "Active" + INACTIVE = "Inactive" + +class ConnectionMonitorTestConfigurationProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol to use in test evaluation. + """ + + TCP = "Tcp" + HTTP = "Http" + ICMP = "Icmp" + +class ConnectionMonitorType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of connection monitor. + """ + + MULTI_ENDPOINT = "MultiEndpoint" + SINGLE_SOURCE_DESTINATION = "SingleSourceDestination" + +class ConnectionState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The connection state. + """ + + REACHABLE = "Reachable" + UNREACHABLE = "Unreachable" + UNKNOWN = "Unknown" + +class ConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The connection status. + """ + + UNKNOWN = "Unknown" + CONNECTED = "Connected" + DISCONNECTED = "Disconnected" + DEGRADED = "Degraded" + +class CoverageLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Test coverage for the endpoint. + """ + + DEFAULT = "Default" + LOW = "Low" + BELOW_AVERAGE = "BelowAverage" + AVERAGE = "Average" + ABOVE_AVERAGE = "AboveAverage" + FULL = "Full" + +class DdosCustomPolicyProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol for which the DDoS protection policy is being customized. + """ + + TCP = "Tcp" + UDP = "Udp" + SYN = "Syn" + +class DdosCustomPolicyTriggerSensitivityOverride(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The customized DDoS protection trigger rate sensitivity degrees. High: Trigger rate set with + most sensitivity w.r.t. normal traffic. Default: Trigger rate set with moderate sensitivity + w.r.t. normal traffic. Low: Trigger rate set with less sensitivity w.r.t. normal traffic. + Relaxed: Trigger rate set with least sensitivity w.r.t. normal traffic. + """ + + RELAXED = "Relaxed" + LOW = "Low" + DEFAULT = "Default" + HIGH = "High" + +class DdosSettingsProtectionCoverage(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The DDoS protection policy customizability of the public IP. Only standard coverage will have + the ability to be customized. + """ + + BASIC = "Basic" + STANDARD = "Standard" + +class DestinationPortBehavior(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Destination port behavior. + """ + + NONE = "None" + LISTEN_IF_AVAILABLE = "ListenIfAvailable" + +class DhGroup(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The DH Groups used in IKE Phase 1 for initial SA. + """ + + NONE = "None" + DH_GROUP1 = "DHGroup1" + DH_GROUP2 = "DHGroup2" + DH_GROUP14 = "DHGroup14" + DH_GROUP2048 = "DHGroup2048" + ECP256 = "ECP256" + ECP384 = "ECP384" + DH_GROUP24 = "DHGroup24" + +class Direction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The direction of the traffic. + """ + + INBOUND = "Inbound" + OUTBOUND = "Outbound" + +class EffectiveRouteSource(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Who created the route. + """ + + UNKNOWN = "Unknown" + USER = "User" + VIRTUAL_NETWORK_GATEWAY = "VirtualNetworkGateway" + DEFAULT = "Default" + +class EffectiveRouteState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The value of effective route. + """ + + ACTIVE = "Active" + INVALID = "Invalid" + +class EffectiveSecurityRuleProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The network protocol this rule applies to. + """ + + TCP = "Tcp" + UDP = "Udp" + ALL = "All" + +class EndpointType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The endpoint type. + """ + + AZURE_VM = "AzureVM" + AZURE_V_NET = "AzureVNet" + AZURE_SUBNET = "AzureSubnet" + EXTERNAL_ADDRESS = "ExternalAddress" + MMA_WORKSPACE_MACHINE = "MMAWorkspaceMachine" + MMA_WORKSPACE_NETWORK = "MMAWorkspaceNetwork" + +class EvaluationState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Connectivity analysis evaluation state. + """ + + NOT_STARTED = "NotStarted" + IN_PROGRESS = "InProgress" + COMPLETED = "Completed" + +class ExpressRouteCircuitPeeringAdvertisedPublicPrefixState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The advertised public prefix state of the Peering resource. + """ + + NOT_CONFIGURED = "NotConfigured" + CONFIGURING = "Configuring" + CONFIGURED = "Configured" + VALIDATION_NEEDED = "ValidationNeeded" + +class ExpressRouteCircuitPeeringState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The state of peering. + """ + + DISABLED = "Disabled" + ENABLED = "Enabled" + +class ExpressRouteCircuitSkuFamily(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The family of the SKU. + """ + + UNLIMITED_DATA = "UnlimitedData" + METERED_DATA = "MeteredData" + +class ExpressRouteCircuitSkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The tier of the SKU. + """ + + STANDARD = "Standard" + PREMIUM = "Premium" + BASIC = "Basic" + LOCAL = "Local" + +class ExpressRouteLinkAdminState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Administrative state of the physical port. + """ + + ENABLED = "Enabled" + DISABLED = "Disabled" + +class ExpressRouteLinkConnectorType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Physical fiber port type. + """ + + LC = "LC" + SC = "SC" + +class ExpressRouteLinkMacSecCipher(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Mac security cipher. + """ + + GCM_AES256 = "GcmAes256" + GCM_AES128 = "GcmAes128" + GCM_AES_XPN128 = "GcmAesXpn128" + GCM_AES_XPN256 = "GcmAesXpn256" + +class ExpressRouteLinkMacSecSciState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Sci mode enabled/disabled. + """ + + DISABLED = "Disabled" + ENABLED = "Enabled" + +class ExpressRoutePeeringState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The state of peering. + """ + + DISABLED = "Disabled" + ENABLED = "Enabled" + +class ExpressRoutePeeringType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The peering type. + """ + + AZURE_PUBLIC_PEERING = "AzurePublicPeering" + AZURE_PRIVATE_PEERING = "AzurePrivatePeering" + MICROSOFT_PEERING = "MicrosoftPeering" + +class ExpressRoutePortsEncapsulation(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Encapsulation method on physical ports. + """ + + DOT1_Q = "Dot1Q" + QIN_Q = "QinQ" + +class ExtendedLocationTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The supported ExtendedLocation types. Currently only EdgeZone is supported in Microsoft.Network + resources. + """ + + EDGE_ZONE = "EdgeZone" + +class FirewallPolicyFilterRuleCollectionActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action type of a rule. + """ + + ALLOW = "Allow" + DENY = "Deny" + +class FirewallPolicyIntrusionDetectionProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Possible intrusion detection bypass traffic protocols. + """ + + TCP = "TCP" + UDP = "UDP" + ICMP = "ICMP" + ANY = "ANY" + +class FirewallPolicyIntrusionDetectionStateType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Possible state values. + """ + + OFF = "Off" + ALERT = "Alert" + DENY = "Deny" + +class FirewallPolicyNatRuleCollectionActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action type of a rule. + """ + + DNAT = "DNAT" + +class FirewallPolicyRuleApplicationProtocolType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The application protocol type of a Rule. + """ + + HTTP = "Http" + HTTPS = "Https" + +class FirewallPolicyRuleCollectionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of the rule collection. + """ + + FIREWALL_POLICY_NAT_RULE_COLLECTION = "FirewallPolicyNatRuleCollection" + FIREWALL_POLICY_FILTER_RULE_COLLECTION = "FirewallPolicyFilterRuleCollection" + +class FirewallPolicyRuleNetworkProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The Network protocol of a Rule. + """ + + TCP = "TCP" + UDP = "UDP" + ANY = "Any" + ICMP = "ICMP" + +class FirewallPolicyRuleType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Rule Type. + """ + + APPLICATION_RULE = "ApplicationRule" + NETWORK_RULE = "NetworkRule" + NAT_RULE = "NatRule" + +class FirewallPolicySkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of Firewall Policy. + """ + + STANDARD = "Standard" + PREMIUM = "Premium" + +class FlowLogFormatType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The file type of flow log. + """ + + JSON = "JSON" + +class HTTPConfigurationMethod(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The HTTP method to use. + """ + + GET = "Get" + POST = "Post" + +class HTTPMethod(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """HTTP method. + """ + + GET = "Get" + +class HubBgpConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the VirtualHub to Peer. + """ + + UNKNOWN = "Unknown" + CONNECTING = "Connecting" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class HubVirtualNetworkConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the VirtualHub to vnet connection. + """ + + UNKNOWN = "Unknown" + CONNECTING = "Connecting" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class IkeEncryption(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The IKE encryption algorithm (IKE phase 2). + """ + + DES = "DES" + DES3 = "DES3" + AES128 = "AES128" + AES192 = "AES192" + AES256 = "AES256" + GCMAES256 = "GCMAES256" + GCMAES128 = "GCMAES128" + +class IkeIntegrity(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The IKE integrity algorithm (IKE phase 2). + """ + + MD5 = "MD5" + SHA1 = "SHA1" + SHA256 = "SHA256" + SHA384 = "SHA384" + GCMAES256 = "GCMAES256" + GCMAES128 = "GCMAES128" + +class InboundSecurityRulesProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Protocol. This should be either TCP or UDP. + """ + + TCP = "TCP" + UDP = "UDP" + +class IPAllocationMethod(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """IP address allocation method. + """ + + STATIC = "Static" + DYNAMIC = "Dynamic" + +class IpAllocationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """IpAllocation type. + """ + + UNDEFINED = "Undefined" + HYPERNET = "Hypernet" + +class IpFlowProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Protocol to be verified on. + """ + + TCP = "TCP" + UDP = "UDP" + +class IpsecEncryption(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The IPSec encryption algorithm (IKE phase 1). + """ + + NONE = "None" + DES = "DES" + DES3 = "DES3" + AES128 = "AES128" + AES192 = "AES192" + AES256 = "AES256" + GCMAES128 = "GCMAES128" + GCMAES192 = "GCMAES192" + GCMAES256 = "GCMAES256" + +class IpsecIntegrity(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The IPSec integrity algorithm (IKE phase 1). + """ + + MD5 = "MD5" + SHA1 = "SHA1" + SHA256 = "SHA256" + GCMAES128 = "GCMAES128" + GCMAES192 = "GCMAES192" + GCMAES256 = "GCMAES256" + +class IPVersion(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """IP address version. + """ + + I_PV4 = "IPv4" + I_PV6 = "IPv6" + +class IssueType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of issue. + """ + + UNKNOWN = "Unknown" + AGENT_STOPPED = "AgentStopped" + GUEST_FIREWALL = "GuestFirewall" + DNS_RESOLUTION = "DnsResolution" + SOCKET_BIND = "SocketBind" + NETWORK_SECURITY_RULE = "NetworkSecurityRule" + USER_DEFINED_ROUTE = "UserDefinedRoute" + PORT_THROTTLED = "PortThrottled" + PLATFORM = "Platform" + +class LoadBalancerOutboundRuleProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol for the outbound rule in load balancer. + """ + + TCP = "Tcp" + UDP = "Udp" + ALL = "All" + +class LoadBalancerSkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of a load balancer SKU. + """ + + BASIC = "Basic" + STANDARD = "Standard" + +class LoadBalancerSkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of a load balancer SKU. + """ + + REGIONAL = "Regional" + GLOBAL_ENUM = "Global" + +class LoadDistribution(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The load distribution policy for this rule. + """ + + DEFAULT = "Default" + SOURCE_IP = "SourceIP" + SOURCE_IP_PROTOCOL = "SourceIPProtocol" + +class ManagedRuleEnabledState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The state of the managed rule. Defaults to Disabled if not specified. + """ + + DISABLED = "Disabled" + +class NatGatewaySkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of Nat Gateway SKU. + """ + + STANDARD = "Standard" + +class NetworkOperationStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of the Azure async operation. + """ + + IN_PROGRESS = "InProgress" + SUCCEEDED = "Succeeded" + FAILED = "Failed" + +class NextHopType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Next hop type. + """ + + INTERNET = "Internet" + VIRTUAL_APPLIANCE = "VirtualAppliance" + VIRTUAL_NETWORK_GATEWAY = "VirtualNetworkGateway" + VNET_LOCAL = "VnetLocal" + HYPER_NET_GATEWAY = "HyperNetGateway" + NONE = "None" + +class OfficeTrafficCategory(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The office traffic category. + """ + + OPTIMIZE = "Optimize" + OPTIMIZE_AND_ALLOW = "OptimizeAndAllow" + ALL = "All" + NONE = "None" + +class Origin(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The origin of the issue. + """ + + LOCAL = "Local" + INBOUND = "Inbound" + OUTBOUND = "Outbound" + +class OutputType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Connection monitor output destination type. Currently, only "Workspace" is supported. + """ + + WORKSPACE = "Workspace" + +class OwaspCrsExclusionEntryMatchVariable(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The variable to be excluded. + """ + + REQUEST_HEADER_NAMES = "RequestHeaderNames" + REQUEST_COOKIE_NAMES = "RequestCookieNames" + REQUEST_ARG_NAMES = "RequestArgNames" + +class OwaspCrsExclusionEntrySelectorMatchOperator(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """When matchVariable is a collection, operate on the selector to specify which elements in the + collection this exclusion applies to. + """ + + EQUALS = "Equals" + CONTAINS = "Contains" + STARTS_WITH = "StartsWith" + ENDS_WITH = "EndsWith" + EQUALS_ANY = "EqualsAny" + +class PcError(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + INTERNAL_ERROR = "InternalError" + AGENT_STOPPED = "AgentStopped" + CAPTURE_FAILED = "CaptureFailed" + LOCAL_FILE_FAILED = "LocalFileFailed" + STORAGE_FAILED = "StorageFailed" + +class PcProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Protocol to be filtered on. + """ + + TCP = "TCP" + UDP = "UDP" + ANY = "Any" + +class PcStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The status of the packet capture session. + """ + + NOT_STARTED = "NotStarted" + RUNNING = "Running" + STOPPED = "Stopped" + ERROR = "Error" + UNKNOWN = "Unknown" + +class PfsGroup(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The Pfs Groups used in IKE Phase 2 for new child SA. + """ + + NONE = "None" + PFS1 = "PFS1" + PFS2 = "PFS2" + PFS2048 = "PFS2048" + ECP256 = "ECP256" + ECP384 = "ECP384" + PFS24 = "PFS24" + PFS14 = "PFS14" + PFSMM = "PFSMM" + +class PreferredIPVersion(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The preferred IP version to use in test evaluation. The connection monitor may choose to use a + different version depending on other parameters. + """ + + I_PV4 = "IPv4" + I_PV6 = "IPv6" + +class ProbeProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The protocol of the end point. If 'Tcp' is specified, a received ACK is required for the probe + to be successful. If 'Http' or 'Https' is specified, a 200 OK response from the specifies URI + is required for the probe to be successful. + """ + + HTTP = "Http" + TCP = "Tcp" + HTTPS = "Https" + +class ProcessorArchitecture(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """VPN client Processor Architecture. + """ + + AMD64 = "Amd64" + X86 = "X86" + +class Protocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Network protocol. + """ + + TCP = "Tcp" + HTTP = "Http" + HTTPS = "Https" + ICMP = "Icmp" + +class ProtocolType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """RNM supported protocol types. + """ + + DO_NOT_USE = "DoNotUse" + ICMP = "Icmp" + TCP = "Tcp" + UDP = "Udp" + GRE = "Gre" + ESP = "Esp" + AH = "Ah" + VXLAN = "Vxlan" + ALL = "All" + +class ProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current provisioning state. + """ + + SUCCEEDED = "Succeeded" + UPDATING = "Updating" + DELETING = "Deleting" + FAILED = "Failed" + +class PublicIPAddressSkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of a public IP address SKU. + """ + + BASIC = "Basic" + STANDARD = "Standard" + +class PublicIPAddressSkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of a public IP address SKU. + """ + + REGIONAL = "Regional" + GLOBAL_ENUM = "Global" + +class PublicIPPrefixSkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of a public IP prefix SKU. + """ + + STANDARD = "Standard" + +class PublicIPPrefixSkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Tier of a public IP prefix SKU. + """ + + REGIONAL = "Regional" + GLOBAL_ENUM = "Global" + +class ResourceIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of identity used for the resource. The type 'SystemAssigned, UserAssigned' includes + both an implicitly created identity and a set of user assigned identities. The type 'None' will + remove any identities from the virtual machine. + """ + + SYSTEM_ASSIGNED = "SystemAssigned" + USER_ASSIGNED = "UserAssigned" + SYSTEM_ASSIGNED_USER_ASSIGNED = "SystemAssigned, UserAssigned" + NONE = "None" + +class RouteFilterRuleType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The rule type of the rule. + """ + + COMMUNITY = "Community" + +class RouteNextHopType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of Azure hop the packet should be sent to. + """ + + VIRTUAL_NETWORK_GATEWAY = "VirtualNetworkGateway" + VNET_LOCAL = "VnetLocal" + INTERNET = "Internet" + VIRTUAL_APPLIANCE = "VirtualAppliance" + NONE = "None" + +class RoutingState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current routing state of the VirtualHub. + """ + + NONE = "None" + PROVISIONED = "Provisioned" + PROVISIONING = "Provisioning" + FAILED = "Failed" + +class SecurityPartnerProviderConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the connection with Security Partner Provider. + """ + + UNKNOWN = "Unknown" + PARTIALLY_CONNECTED = "PartiallyConnected" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class SecurityProviderName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The Security Providers. + """ + + Z_SCALER = "ZScaler" + I_BOSS = "IBoss" + CHECKPOINT = "Checkpoint" + +class SecurityRuleAccess(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Whether network traffic is allowed or denied. + """ + + ALLOW = "Allow" + DENY = "Deny" + +class SecurityRuleDirection(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The direction of the rule. The direction specifies if rule will be evaluated on incoming or + outgoing traffic. + """ + + INBOUND = "Inbound" + OUTBOUND = "Outbound" + +class SecurityRuleProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Network protocol this rule applies to. + """ + + TCP = "Tcp" + UDP = "Udp" + ICMP = "Icmp" + ESP = "Esp" + ASTERISK = "*" + AH = "Ah" + +class ServiceProviderProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The ServiceProviderProvisioningState state of the resource. + """ + + NOT_PROVISIONED = "NotProvisioned" + PROVISIONING = "Provisioning" + PROVISIONED = "Provisioned" + DEPROVISIONING = "Deprovisioning" + +class Severity(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The severity of the issue. + """ + + ERROR = "Error" + WARNING = "Warning" + +class TransportProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The transport protocol for the endpoint. + """ + + UDP = "Udp" + TCP = "Tcp" + ALL = "All" + +class TunnelConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the tunnel. + """ + + UNKNOWN = "Unknown" + CONNECTING = "Connecting" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class UsageUnit(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """An enum describing the unit of measurement. + """ + + COUNT = "Count" + +class VerbosityLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Verbosity level. + """ + + NORMAL = "Normal" + MINIMUM = "Minimum" + FULL = "Full" + +class VirtualNetworkGatewayConnectionMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Gateway connection type. + """ + + DEFAULT = "Default" + RESPONDER_ONLY = "ResponderOnly" + INITIATOR_ONLY = "InitiatorOnly" + +class VirtualNetworkGatewayConnectionProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Gateway connection protocol. + """ + + IK_EV2 = "IKEv2" + IK_EV1 = "IKEv1" + +class VirtualNetworkGatewayConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Virtual Network Gateway connection status. + """ + + UNKNOWN = "Unknown" + CONNECTING = "Connecting" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class VirtualNetworkGatewayConnectionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Gateway connection type. + """ + + I_PSEC = "IPsec" + VNET2_VNET = "Vnet2Vnet" + EXPRESS_ROUTE = "ExpressRoute" + VPN_CLIENT = "VPNClient" + +class VirtualNetworkGatewaySkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Gateway SKU name. + """ + + BASIC = "Basic" + HIGH_PERFORMANCE = "HighPerformance" + STANDARD = "Standard" + ULTRA_PERFORMANCE = "UltraPerformance" + VPN_GW1 = "VpnGw1" + VPN_GW2 = "VpnGw2" + VPN_GW3 = "VpnGw3" + VPN_GW4 = "VpnGw4" + VPN_GW5 = "VpnGw5" + VPN_GW1_AZ = "VpnGw1AZ" + VPN_GW2_AZ = "VpnGw2AZ" + VPN_GW3_AZ = "VpnGw3AZ" + VPN_GW4_AZ = "VpnGw4AZ" + VPN_GW5_AZ = "VpnGw5AZ" + ER_GW1_AZ = "ErGw1AZ" + ER_GW2_AZ = "ErGw2AZ" + ER_GW3_AZ = "ErGw3AZ" + +class VirtualNetworkGatewaySkuTier(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Gateway SKU tier. + """ + + BASIC = "Basic" + HIGH_PERFORMANCE = "HighPerformance" + STANDARD = "Standard" + ULTRA_PERFORMANCE = "UltraPerformance" + VPN_GW1 = "VpnGw1" + VPN_GW2 = "VpnGw2" + VPN_GW3 = "VpnGw3" + VPN_GW4 = "VpnGw4" + VPN_GW5 = "VpnGw5" + VPN_GW1_AZ = "VpnGw1AZ" + VPN_GW2_AZ = "VpnGw2AZ" + VPN_GW3_AZ = "VpnGw3AZ" + VPN_GW4_AZ = "VpnGw4AZ" + VPN_GW5_AZ = "VpnGw5AZ" + ER_GW1_AZ = "ErGw1AZ" + ER_GW2_AZ = "ErGw2AZ" + ER_GW3_AZ = "ErGw3AZ" + +class VirtualNetworkGatewayType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of this virtual network gateway. + """ + + VPN = "Vpn" + EXPRESS_ROUTE = "ExpressRoute" + LOCAL_GATEWAY = "LocalGateway" + +class VirtualNetworkPeeringState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The status of the virtual network peering. + """ + + INITIATED = "Initiated" + CONNECTED = "Connected" + DISCONNECTED = "Disconnected" + +class VirtualWanSecurityProviderType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The virtual wan security provider type. + """ + + EXTERNAL = "External" + NATIVE = "Native" + +class VpnAuthenticationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """VPN authentication types enabled for the VpnServerConfiguration. + """ + + CERTIFICATE = "Certificate" + RADIUS = "Radius" + AAD = "AAD" + +class VpnClientProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """VPN client protocol enabled for the virtual network gateway. + """ + + IKE_V2 = "IkeV2" + SSTP = "SSTP" + OPEN_VPN = "OpenVPN" + +class VpnConnectionStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the vpn connection. + """ + + UNKNOWN = "Unknown" + CONNECTING = "Connecting" + CONNECTED = "Connected" + NOT_CONNECTED = "NotConnected" + +class VpnGatewayGeneration(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The generation for this VirtualNetworkGateway. Must be None if gatewayType is not VPN. + """ + + NONE = "None" + GENERATION1 = "Generation1" + GENERATION2 = "Generation2" + +class VpnGatewayTunnelingProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """VPN protocol enabled for the VpnServerConfiguration. + """ + + IKE_V2 = "IkeV2" + OPEN_VPN = "OpenVPN" + +class VpnLinkConnectionMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Vpn link connection mode. + """ + + DEFAULT = "Default" + RESPONDER_ONLY = "ResponderOnly" + INITIATOR_ONLY = "InitiatorOnly" + +class VpnNatRuleMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The Source NAT direction of a VPN NAT. + """ + + EGRESS_SNAT = "EgressSnat" + INGRESS_SNAT = "IngressSnat" + +class VpnNatRuleType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of NAT rule for VPN NAT. + """ + + STATIC = "Static" + DYNAMIC = "Dynamic" + +class VpnType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of this virtual network gateway. + """ + + POLICY_BASED = "PolicyBased" + ROUTE_BASED = "RouteBased" + +class WebApplicationFirewallAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of Actions. + """ + + ALLOW = "Allow" + BLOCK = "Block" + LOG = "Log" + +class WebApplicationFirewallEnabledState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The state of the policy. + """ + + DISABLED = "Disabled" + ENABLED = "Enabled" + +class WebApplicationFirewallMatchVariable(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Match Variable. + """ + + REMOTE_ADDR = "RemoteAddr" + REQUEST_METHOD = "RequestMethod" + QUERY_STRING = "QueryString" + POST_ARGS = "PostArgs" + REQUEST_URI = "RequestUri" + REQUEST_HEADERS = "RequestHeaders" + REQUEST_BODY = "RequestBody" + REQUEST_COOKIES = "RequestCookies" + +class WebApplicationFirewallMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The mode of the policy. + """ + + PREVENTION = "Prevention" + DETECTION = "Detection" + +class WebApplicationFirewallOperator(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The operator to be matched. + """ + + IP_MATCH = "IPMatch" + EQUAL = "Equal" + CONTAINS = "Contains" + LESS_THAN = "LessThan" + GREATER_THAN = "GreaterThan" + LESS_THAN_OR_EQUAL = "LessThanOrEqual" + GREATER_THAN_OR_EQUAL = "GreaterThanOrEqual" + BEGINS_WITH = "BeginsWith" + ENDS_WITH = "EndsWith" + REGEX = "Regex" + GEO_MATCH = "GeoMatch" + +class WebApplicationFirewallPolicyResourceState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Resource status of the policy. + """ + + CREATING = "Creating" + ENABLING = "Enabling" + ENABLED = "Enabled" + DISABLING = "Disabling" + DISABLED = "Disabled" + DELETING = "Deleting" + +class WebApplicationFirewallRuleType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The rule type. + """ + + MATCH_RULE = "MatchRule" + INVALID = "Invalid" + +class WebApplicationFirewallTransform(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Transforms applied before matching. + """ + + LOWERCASE = "Lowercase" + TRIM = "Trim" + URL_DECODE = "UrlDecode" + URL_ENCODE = "UrlEncode" + REMOVE_NULLS = "RemoveNulls" + HTML_ENTITY_DECODE = "HtmlEntityDecode" diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/__init__.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/__init__.py new file mode 100644 index 000000000000..e3c7e3bb9c53 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/__init__.py @@ -0,0 +1,225 @@ +# 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_gateways_operations import ApplicationGatewaysOperations +from ._application_gateway_private_link_resources_operations import ApplicationGatewayPrivateLinkResourcesOperations +from ._application_gateway_private_endpoint_connections_operations import ApplicationGatewayPrivateEndpointConnectionsOperations +from ._application_security_groups_operations import ApplicationSecurityGroupsOperations +from ._available_delegations_operations import AvailableDelegationsOperations +from ._available_resource_group_delegations_operations import AvailableResourceGroupDelegationsOperations +from ._available_service_aliases_operations import AvailableServiceAliasesOperations +from ._azure_firewalls_operations import AzureFirewallsOperations +from ._azure_firewall_fqdn_tags_operations import AzureFirewallFqdnTagsOperations +from ._web_categories_operations import WebCategoriesOperations +from ._bastion_hosts_operations import BastionHostsOperations +from ._network_management_client_operations import NetworkManagementClientOperationsMixin +from ._custom_ip_prefixes_operations import CustomIPPrefixesOperations +from ._ddos_custom_policies_operations import DdosCustomPoliciesOperations +from ._ddos_protection_plans_operations import DdosProtectionPlansOperations +from ._dscp_configuration_operations import DscpConfigurationOperations +from ._available_endpoint_services_operations import AvailableEndpointServicesOperations +from ._express_route_circuit_authorizations_operations import ExpressRouteCircuitAuthorizationsOperations +from ._express_route_circuit_peerings_operations import ExpressRouteCircuitPeeringsOperations +from ._express_route_circuit_connections_operations import ExpressRouteCircuitConnectionsOperations +from ._peer_express_route_circuit_connections_operations import PeerExpressRouteCircuitConnectionsOperations +from ._express_route_circuits_operations import ExpressRouteCircuitsOperations +from ._express_route_service_providers_operations import ExpressRouteServiceProvidersOperations +from ._express_route_cross_connections_operations import ExpressRouteCrossConnectionsOperations +from ._express_route_cross_connection_peerings_operations import ExpressRouteCrossConnectionPeeringsOperations +from ._express_route_ports_locations_operations import ExpressRoutePortsLocationsOperations +from ._express_route_ports_operations import ExpressRoutePortsOperations +from ._express_route_links_operations import ExpressRouteLinksOperations +from ._firewall_policies_operations import FirewallPoliciesOperations +from ._firewall_policy_rule_collection_groups_operations import FirewallPolicyRuleCollectionGroupsOperations +from ._ip_allocations_operations import IpAllocationsOperations +from ._ip_groups_operations import IpGroupsOperations +from ._load_balancers_operations import LoadBalancersOperations +from ._load_balancer_backend_address_pools_operations import LoadBalancerBackendAddressPoolsOperations +from ._load_balancer_frontend_ip_configurations_operations import LoadBalancerFrontendIPConfigurationsOperations +from ._inbound_nat_rules_operations import InboundNatRulesOperations +from ._load_balancer_load_balancing_rules_operations import LoadBalancerLoadBalancingRulesOperations +from ._load_balancer_outbound_rules_operations import LoadBalancerOutboundRulesOperations +from ._load_balancer_network_interfaces_operations import LoadBalancerNetworkInterfacesOperations +from ._load_balancer_probes_operations import LoadBalancerProbesOperations +from ._nat_gateways_operations import NatGatewaysOperations +from ._network_interfaces_operations import NetworkInterfacesOperations +from ._network_interface_ip_configurations_operations import NetworkInterfaceIPConfigurationsOperations +from ._network_interface_load_balancers_operations import NetworkInterfaceLoadBalancersOperations +from ._network_interface_tap_configurations_operations import NetworkInterfaceTapConfigurationsOperations +from ._network_profiles_operations import NetworkProfilesOperations +from ._network_security_groups_operations import NetworkSecurityGroupsOperations +from ._security_rules_operations import SecurityRulesOperations +from ._default_security_rules_operations import DefaultSecurityRulesOperations +from ._network_virtual_appliances_operations import NetworkVirtualAppliancesOperations +from ._virtual_appliance_sites_operations import VirtualApplianceSitesOperations +from ._virtual_appliance_skus_operations import VirtualApplianceSkusOperations +from ._inbound_security_rule_operations import InboundSecurityRuleOperations +from ._network_watchers_operations import NetworkWatchersOperations +from ._packet_captures_operations import PacketCapturesOperations +from ._connection_monitors_operations import ConnectionMonitorsOperations +from ._flow_logs_operations import FlowLogsOperations +from ._operations import Operations +from ._private_endpoints_operations import PrivateEndpointsOperations +from ._available_private_endpoint_types_operations import AvailablePrivateEndpointTypesOperations +from ._private_dns_zone_groups_operations import PrivateDnsZoneGroupsOperations +from ._private_link_services_operations import PrivateLinkServicesOperations +from ._public_ip_addresses_operations import PublicIPAddressesOperations +from ._public_ip_prefixes_operations import PublicIPPrefixesOperations +from ._route_filters_operations import RouteFiltersOperations +from ._route_filter_rules_operations import RouteFilterRulesOperations +from ._route_tables_operations import RouteTablesOperations +from ._routes_operations import RoutesOperations +from ._security_partner_providers_operations import SecurityPartnerProvidersOperations +from ._bgp_service_communities_operations import BgpServiceCommunitiesOperations +from ._service_endpoint_policies_operations import ServiceEndpointPoliciesOperations +from ._service_endpoint_policy_definitions_operations import ServiceEndpointPolicyDefinitionsOperations +from ._service_tags_operations import ServiceTagsOperations +from ._usages_operations import UsagesOperations +from ._virtual_networks_operations import VirtualNetworksOperations +from ._subnets_operations import SubnetsOperations +from ._resource_navigation_links_operations import ResourceNavigationLinksOperations +from ._service_association_links_operations import ServiceAssociationLinksOperations +from ._virtual_network_peerings_operations import VirtualNetworkPeeringsOperations +from ._virtual_network_gateways_operations import VirtualNetworkGatewaysOperations +from ._virtual_network_gateway_connections_operations import VirtualNetworkGatewayConnectionsOperations +from ._local_network_gateways_operations import LocalNetworkGatewaysOperations +from ._virtual_network_taps_operations import VirtualNetworkTapsOperations +from ._virtual_routers_operations import VirtualRoutersOperations +from ._virtual_router_peerings_operations import VirtualRouterPeeringsOperations +from ._virtual_wans_operations import VirtualWansOperations +from ._vpn_sites_operations import VpnSitesOperations +from ._vpn_site_links_operations import VpnSiteLinksOperations +from ._vpn_sites_configuration_operations import VpnSitesConfigurationOperations +from ._vpn_server_configurations_operations import VpnServerConfigurationsOperations +from ._virtual_hubs_operations import VirtualHubsOperations +from ._hub_virtual_network_connections_operations import HubVirtualNetworkConnectionsOperations +from ._vpn_gateways_operations import VpnGatewaysOperations +from ._vpn_connections_operations import VpnConnectionsOperations +from ._vpn_site_link_connections_operations import VpnSiteLinkConnectionsOperations +from ._vpn_link_connections_operations import VpnLinkConnectionsOperations +from ._nat_rules_operations import NatRulesOperations +from ._p2_svpn_gateways_operations import P2SVpnGatewaysOperations +from ._vpn_server_configurations_associated_with_virtual_wan_operations import VpnServerConfigurationsAssociatedWithVirtualWanOperations +from ._virtual_hub_route_table_v2_s_operations import VirtualHubRouteTableV2SOperations +from ._express_route_gateways_operations import ExpressRouteGatewaysOperations +from ._express_route_connections_operations import ExpressRouteConnectionsOperations +from ._virtual_hub_bgp_connection_operations import VirtualHubBgpConnectionOperations +from ._virtual_hub_bgp_connections_operations import VirtualHubBgpConnectionsOperations +from ._virtual_hub_ip_configuration_operations import VirtualHubIpConfigurationOperations +from ._hub_route_tables_operations import HubRouteTablesOperations +from ._web_application_firewall_policies_operations import WebApplicationFirewallPoliciesOperations + +__all__ = [ + 'ApplicationGatewaysOperations', + 'ApplicationGatewayPrivateLinkResourcesOperations', + 'ApplicationGatewayPrivateEndpointConnectionsOperations', + 'ApplicationSecurityGroupsOperations', + 'AvailableDelegationsOperations', + 'AvailableResourceGroupDelegationsOperations', + 'AvailableServiceAliasesOperations', + 'AzureFirewallsOperations', + 'AzureFirewallFqdnTagsOperations', + 'WebCategoriesOperations', + 'BastionHostsOperations', + 'NetworkManagementClientOperationsMixin', + 'CustomIPPrefixesOperations', + 'DdosCustomPoliciesOperations', + 'DdosProtectionPlansOperations', + 'DscpConfigurationOperations', + 'AvailableEndpointServicesOperations', + 'ExpressRouteCircuitAuthorizationsOperations', + 'ExpressRouteCircuitPeeringsOperations', + 'ExpressRouteCircuitConnectionsOperations', + 'PeerExpressRouteCircuitConnectionsOperations', + 'ExpressRouteCircuitsOperations', + 'ExpressRouteServiceProvidersOperations', + 'ExpressRouteCrossConnectionsOperations', + 'ExpressRouteCrossConnectionPeeringsOperations', + 'ExpressRoutePortsLocationsOperations', + 'ExpressRoutePortsOperations', + 'ExpressRouteLinksOperations', + 'FirewallPoliciesOperations', + 'FirewallPolicyRuleCollectionGroupsOperations', + 'IpAllocationsOperations', + 'IpGroupsOperations', + 'LoadBalancersOperations', + 'LoadBalancerBackendAddressPoolsOperations', + 'LoadBalancerFrontendIPConfigurationsOperations', + 'InboundNatRulesOperations', + 'LoadBalancerLoadBalancingRulesOperations', + 'LoadBalancerOutboundRulesOperations', + 'LoadBalancerNetworkInterfacesOperations', + 'LoadBalancerProbesOperations', + 'NatGatewaysOperations', + 'NetworkInterfacesOperations', + 'NetworkInterfaceIPConfigurationsOperations', + 'NetworkInterfaceLoadBalancersOperations', + 'NetworkInterfaceTapConfigurationsOperations', + 'NetworkProfilesOperations', + 'NetworkSecurityGroupsOperations', + 'SecurityRulesOperations', + 'DefaultSecurityRulesOperations', + 'NetworkVirtualAppliancesOperations', + 'VirtualApplianceSitesOperations', + 'VirtualApplianceSkusOperations', + 'InboundSecurityRuleOperations', + 'NetworkWatchersOperations', + 'PacketCapturesOperations', + 'ConnectionMonitorsOperations', + 'FlowLogsOperations', + 'Operations', + 'PrivateEndpointsOperations', + 'AvailablePrivateEndpointTypesOperations', + 'PrivateDnsZoneGroupsOperations', + 'PrivateLinkServicesOperations', + 'PublicIPAddressesOperations', + 'PublicIPPrefixesOperations', + 'RouteFiltersOperations', + 'RouteFilterRulesOperations', + 'RouteTablesOperations', + 'RoutesOperations', + 'SecurityPartnerProvidersOperations', + 'BgpServiceCommunitiesOperations', + 'ServiceEndpointPoliciesOperations', + 'ServiceEndpointPolicyDefinitionsOperations', + 'ServiceTagsOperations', + 'UsagesOperations', + 'VirtualNetworksOperations', + 'SubnetsOperations', + 'ResourceNavigationLinksOperations', + 'ServiceAssociationLinksOperations', + 'VirtualNetworkPeeringsOperations', + 'VirtualNetworkGatewaysOperations', + 'VirtualNetworkGatewayConnectionsOperations', + 'LocalNetworkGatewaysOperations', + 'VirtualNetworkTapsOperations', + 'VirtualRoutersOperations', + 'VirtualRouterPeeringsOperations', + 'VirtualWansOperations', + 'VpnSitesOperations', + 'VpnSiteLinksOperations', + 'VpnSitesConfigurationOperations', + 'VpnServerConfigurationsOperations', + 'VirtualHubsOperations', + 'HubVirtualNetworkConnectionsOperations', + 'VpnGatewaysOperations', + 'VpnConnectionsOperations', + 'VpnSiteLinkConnectionsOperations', + 'VpnLinkConnectionsOperations', + 'NatRulesOperations', + 'P2SVpnGatewaysOperations', + 'VpnServerConfigurationsAssociatedWithVirtualWanOperations', + 'VirtualHubRouteTableV2SOperations', + 'ExpressRouteGatewaysOperations', + 'ExpressRouteConnectionsOperations', + 'VirtualHubBgpConnectionOperations', + 'VirtualHubBgpConnectionsOperations', + 'VirtualHubIpConfigurationOperations', + 'HubRouteTablesOperations', + 'WebApplicationFirewallPoliciesOperations', +] diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_endpoint_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_endpoint_connections_operations.py new file mode 100644 index 000000000000..0f8fe3f25ff4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_endpoint_connections_operations.py @@ -0,0 +1,439 @@ +# 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 ApplicationGatewayPrivateEndpointConnectionsOperations(object): + """ApplicationGatewayPrivateEndpointConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + connection_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-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type 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 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, + application_gateway_name=application_gateway_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def _update_initial( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + connection_name, # type: str + parameters, # type: "_models.ApplicationGatewayPrivateEndpointConnection" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ApplicationGatewayPrivateEndpointConnection"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayPrivateEndpointConnection"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(parameters, 'ApplicationGatewayPrivateEndpointConnection') + 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def begin_update( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + connection_name, # type: str + parameters, # type: "_models.ApplicationGatewayPrivateEndpointConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationGatewayPrivateEndpointConnection"] + """Updates the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type connection_name: str + :param parameters: Parameters supplied to update application gateway private endpoint + connection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationGatewayPrivateEndpointConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnection"] + lro_delay = kwargs.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, + application_gateway_name=application_gateway_name, + connection_name=connection_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('ApplicationGatewayPrivateEndpointConnection', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGatewayPrivateEndpointConnection" + """Gets the specified private endpoint connection on application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param connection_name: The name of the application gateway private endpoint connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayPrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationGatewayPrivateEndpointConnectionListResult"] + """Lists all private endpoint connections on an application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayPrivateEndpointConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateEndpointConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateEndpointConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayPrivateEndpointConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateEndpointConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_link_resources_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_link_resources_operations.py new file mode 100644 index 000000000000..47b38d805c9a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateway_private_link_resources_operations.py @@ -0,0 +1,121 @@ +# 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 ApplicationGatewayPrivateLinkResourcesOperations(object): + """ApplicationGatewayPrivateLinkResourcesOperations 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.network.v2020_08_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_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationGatewayPrivateLinkResourceListResult"] + """Lists all private link resources on an application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayPrivateLinkResourceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayPrivateLinkResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayPrivateLinkResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayPrivateLinkResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/privateLinkResources'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateways_operations.py new file mode 100644 index 000000000000..d6d1ccf6b1aa --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_gateways_operations.py @@ -0,0 +1,1413 @@ +# 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 ApplicationGatewaysOperations(object): + """ApplicationGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + application_gateway_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-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGateway" + """Gets the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + parameters, # type: "_models.ApplicationGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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(parameters, 'ApplicationGateway') + 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('ApplicationGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + parameters, # type: "_models.ApplicationGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationGateway"] + """Creates or updates the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param parameters: Parameters supplied to the create or update application gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + lro_delay = kwargs.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, + application_gateway_name=application_gateway_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('ApplicationGateway', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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': 'azure-async-operation'}, 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.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGateway" + """Updates the specified application gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param parameters: Parameters supplied to update application gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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(parameters, 'TagsObject') + 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('ApplicationGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationGatewayListResult"] + """Lists all application gateways in a 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 ApplicationGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/applicationGateways'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationGatewayListResult"] + """Gets all the application gateways 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 ApplicationGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ApplicationGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGateways'} # type: ignore + + def _start_initial( + self, + resource_group_name, # type: str + application_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._start_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _start_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/start'} # type: ignore + + def begin_start( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Starts the specified application gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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._start_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/start'} # type: ignore + + def _stop_initial( + self, + resource_group_name, # type: str + application_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/stop'} # type: ignore + + def begin_stop( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Stops the specified application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_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._stop_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/stop'} # type: ignore + + def _backend_health_initial( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ApplicationGatewayBackendHealth"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayBackendHealth"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._backend_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ApplicationGatewayBackendHealth', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _backend_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/backendhealth'} # type: ignore + + def begin_backend_health( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationGatewayBackendHealth"] + """Gets the backend health of the specified application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param expand: Expands BackendAddressPool and BackendHttpSettings referenced in backend health. + :type expand: 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 ApplicationGatewayBackendHealth or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealth] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayBackendHealth"] + lro_delay = kwargs.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._backend_health_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_name, + expand=expand, + 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('ApplicationGatewayBackendHealth', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_backend_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/backendhealth'} # type: ignore + + def _backend_health_on_demand_initial( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + probe_request, # type: "_models.ApplicationGatewayOnDemandProbe" + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ApplicationGatewayBackendHealthOnDemand"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationGatewayBackendHealthOnDemand"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._backend_health_on_demand_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(probe_request, 'ApplicationGatewayOnDemandProbe') + 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('ApplicationGatewayBackendHealthOnDemand', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _backend_health_on_demand_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/getBackendHealthOnDemand'} # type: ignore + + def begin_backend_health_on_demand( + self, + resource_group_name, # type: str + application_gateway_name, # type: str + probe_request, # type: "_models.ApplicationGatewayOnDemandProbe" + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationGatewayBackendHealthOnDemand"] + """Gets the backend health for given combination of backend pool and http setting of the specified + application gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_gateway_name: The name of the application gateway. + :type application_gateway_name: str + :param probe_request: Request body for on-demand test probe operation. + :type probe_request: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayOnDemandProbe + :param expand: Expands BackendAddressPool and BackendHttpSettings referenced in backend health. + :type expand: 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 ApplicationGatewayBackendHealthOnDemand or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayBackendHealthOnDemand] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayBackendHealthOnDemand"] + lro_delay = kwargs.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._backend_health_on_demand_initial( + resource_group_name=resource_group_name, + application_gateway_name=application_gateway_name, + probe_request=probe_request, + expand=expand, + 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('ApplicationGatewayBackendHealthOnDemand', 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'), + 'applicationGatewayName': self._serialize.url("application_gateway_name", application_gateway_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_backend_health_on_demand.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationGateways/{applicationGatewayName}/getBackendHealthOnDemand'} # type: ignore + + def list_available_server_variables( + self, + **kwargs # type: Any + ): + # type: (...) -> List[str] + """Lists all available server variables. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_server_variables.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.Error, 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 + list_available_server_variables.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableServerVariables'} # type: ignore + + def list_available_request_headers( + self, + **kwargs # type: Any + ): + # type: (...) -> List[str] + """Lists all available request headers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_request_headers.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.Error, 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 + list_available_request_headers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableRequestHeaders'} # type: ignore + + def list_available_response_headers( + self, + **kwargs # type: Any + ): + # type: (...) -> List[str] + """Lists all available response headers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of str, or the result of cls(response) + :rtype: list[str] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_response_headers.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.Error, 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 + list_available_response_headers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableResponseHeaders'} # type: ignore + + def list_available_waf_rule_sets( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGatewayAvailableWafRuleSetsResult" + """Lists all available web application firewall rule sets. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayAvailableWafRuleSetsResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableWafRuleSetsResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableWafRuleSetsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_waf_rule_sets.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayAvailableWafRuleSetsResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_available_waf_rule_sets.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableWafRuleSets'} # type: ignore + + def list_available_ssl_options( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGatewayAvailableSslOptions" + """Lists available Ssl options for configuring Ssl policy. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewayAvailableSslOptions, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableSslOptions + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableSslOptions"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list_available_ssl_options.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationGatewayAvailableSslOptions', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_available_ssl_options.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default'} # type: ignore + + def list_available_ssl_predefined_policies( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationGatewayAvailableSslPredefinedPolicies"] + """Lists all SSL predefined policies for configuring Ssl policy. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationGatewayAvailableSslPredefinedPolicies or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationGatewayAvailableSslPredefinedPolicies] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewayAvailableSslPredefinedPolicies"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_available_ssl_predefined_policies.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('ApplicationGatewayAvailableSslPredefinedPolicies', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_available_ssl_predefined_policies.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default/predefinedPolicies'} # type: ignore + + def get_ssl_predefined_policy( + self, + predefined_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationGatewaySslPredefinedPolicy" + """Gets Ssl predefined policy with the specified policy name. + + :param predefined_policy_name: Name of Ssl predefined policy. + :type predefined_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationGatewaySslPredefinedPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationGatewaySslPredefinedPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationGatewaySslPredefinedPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_ssl_predefined_policy.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'predefinedPolicyName': self._serialize.url("predefined_policy_name", predefined_policy_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('ApplicationGatewaySslPredefinedPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ssl_predefined_policy.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationGatewayAvailableSslOptions/default/predefinedPolicies/{predefinedPolicyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_security_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_security_groups_operations.py new file mode 100644 index 000000000000..a8378c6cbced --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_application_security_groups_operations.py @@ -0,0 +1,553 @@ +# 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 ApplicationSecurityGroupsOperations(object): + """ApplicationSecurityGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + application_security_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-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + application_security_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_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, + application_security_group_name=application_security_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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_group_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.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + application_security_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationSecurityGroup" + """Gets information about the specified application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + application_security_group_name, # type: str + parameters, # type: "_models.ApplicationSecurityGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationSecurityGroup" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ApplicationSecurityGroup') + 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('ApplicationSecurityGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + application_security_group_name, # type: str + parameters, # type: "_models.ApplicationSecurityGroup" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationSecurityGroup"] + """Creates or updates an application security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :param parameters: Parameters supplied to the create or update ApplicationSecurityGroup + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ApplicationSecurityGroup or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + lro_delay = kwargs.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, + application_security_group_name=application_security_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('ApplicationSecurityGroup', 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'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_group_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': 'azure-async-operation'}, 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.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + application_security_group_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationSecurityGroup" + """Updates an application security group's tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param application_security_group_name: The name of the application security group. + :type application_security_group_name: str + :param parameters: Parameters supplied to update application security group tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'applicationSecurityGroupName': self._serialize.url("application_security_group_name", application_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ApplicationSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/applicationSecurityGroups/{applicationSecurityGroupName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationSecurityGroupListResult"] + """Gets all application security groups 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 ApplicationSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ApplicationSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/applicationSecurityGroups'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationSecurityGroupListResult"] + """Gets all the application security groups in a 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 ApplicationSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ApplicationSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/applicationSecurityGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_delegations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_delegations_operations.py new file mode 100644 index 000000000000..53e6bda06e3e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_delegations_operations.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. +# -------------------------------------------------------------------------- +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 AvailableDelegationsOperations(object): + """AvailableDelegationsOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailableDelegationsResult"] + """Gets all of the available subnet delegations for this subscription in this region. + + :param location: The location of the subnet. + :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 AvailableDelegationsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableDelegationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableDelegationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailableDelegationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/availableDelegations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_endpoint_services_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_endpoint_services_operations.py new file mode 100644 index 000000000000..d2293c6c859a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_endpoint_services_operations.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. +# -------------------------------------------------------------------------- +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 AvailableEndpointServicesOperations(object): + """AvailableEndpointServicesOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.EndpointServicesListResult"] + """List what values of endpoint services are available for use. + + :param location: The location to check available endpoint services. + :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 EndpointServicesListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.EndpointServicesListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.EndpointServicesListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('EndpointServicesListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/virtualNetworkAvailableEndpointServices'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_private_endpoint_types_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_private_endpoint_types_operations.py new file mode 100644 index 000000000000..52c0c42e89b0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_private_endpoint_types_operations.py @@ -0,0 +1,194 @@ +# 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 AvailablePrivateEndpointTypesOperations(object): + """AvailablePrivateEndpointTypesOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailablePrivateEndpointTypesResult"] + """Returns all of the resource types that can be linked to a Private Endpoint in this subscription + in this region. + + :param location: The location of the domain name. + :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 AvailablePrivateEndpointTypesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointTypesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailablePrivateEndpointTypesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailablePrivateEndpointTypesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/availablePrivateEndpointTypes'} # type: ignore + + def list_by_resource_group( + self, + location, # type: str + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailablePrivateEndpointTypesResult"] + """Returns all of the resource types that can be linked to a Private Endpoint in this subscription + in this region. + + :param location: The location of the domain name. + :type location: str + :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 AvailablePrivateEndpointTypesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailablePrivateEndpointTypesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailablePrivateEndpointTypesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str'), + '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('AvailablePrivateEndpointTypesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/availablePrivateEndpointTypes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_resource_group_delegations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_resource_group_delegations_operations.py new file mode 100644 index 000000000000..7c70871a83df --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_resource_group_delegations_operations.py @@ -0,0 +1,121 @@ +# 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 AvailableResourceGroupDelegationsOperations(object): + """AvailableResourceGroupDelegationsOperations 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.network.v2020_08_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, + location, # type: str + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailableDelegationsResult"] + """Gets all of the available subnet delegations for this resource group in this region. + + :param location: The location of the domain name. + :type location: str + :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 AvailableDelegationsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableDelegationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableDelegationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str'), + '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('AvailableDelegationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/locations/{location}/availableDelegations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_service_aliases_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_service_aliases_operations.py new file mode 100644 index 000000000000..c872ae70ed76 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_available_service_aliases_operations.py @@ -0,0 +1,192 @@ +# 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 AvailableServiceAliasesOperations(object): + """AvailableServiceAliasesOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailableServiceAliasesResult"] + """Gets all available service aliases for this subscription in this region. + + :param location: The 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 AvailableServiceAliasesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAliasesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableServiceAliasesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + '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('AvailableServiceAliasesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/availableServiceAliases'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AvailableServiceAliasesResult"] + """Gets all available service aliases for this resource group in this region. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param location: The 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 AvailableServiceAliasesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AvailableServiceAliasesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableServiceAliasesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + '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('AvailableServiceAliasesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/availableServiceAliases'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewall_fqdn_tags_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewall_fqdn_tags_operations.py new file mode 100644 index 000000000000..990b471e8bc3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewall_fqdn_tags_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 AzureFirewallFqdnTagsOperations(object): + """AzureFirewallFqdnTagsOperations 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.network.v2020_08_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_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AzureFirewallFqdnTagListResult"] + """Gets all the Azure Firewall FQDN Tags 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 AzureFirewallFqdnTagListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallFqdnTagListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallFqdnTagListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('AzureFirewallFqdnTagListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureFirewallFqdnTags'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewalls_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewalls_operations.py new file mode 100644 index 000000000000..f6fb78f0450d --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_azure_firewalls_operations.py @@ -0,0 +1,613 @@ +# 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 AzureFirewallsOperations(object): + """AzureFirewallsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + azure_firewall_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-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_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, + azure_firewall_name=azure_firewall_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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_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.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureFirewall" + """Gets the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureFirewall, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.AzureFirewall + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + parameters, # type: "_models.AzureFirewall" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureFirewall" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str', max_length=56, min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AzureFirewall') + 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('AzureFirewall', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + parameters, # type: "_models.AzureFirewall" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AzureFirewall"] + """Creates or updates the specified Azure Firewall. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :param parameters: Parameters supplied to the create or update Azure Firewall operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AzureFirewall + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureFirewall or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + lro_delay = kwargs.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, + azure_firewall_name=azure_firewall_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('AzureFirewall', 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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str', max_length=56, min_length=1), + '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': 'azure-async-operation'}, 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.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.AzureFirewall"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AzureFirewall"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('AzureFirewall', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + azure_firewall_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AzureFirewall"] + """Updates tags of an Azure Firewall resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param azure_firewall_name: The name of the Azure Firewall. + :type azure_firewall_name: str + :param parameters: Parameters supplied to update azure firewall tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureFirewall or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.AzureFirewall] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewall"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + azure_firewall_name=azure_firewall_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('AzureFirewall', 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'), + 'azureFirewallName': self._serialize.url("azure_firewall_name", azure_firewall_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': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/azureFirewalls/{azureFirewallName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AzureFirewallListResult"] + """Lists all Azure Firewalls in a 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 AzureFirewallListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AzureFirewallListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/azureFirewalls'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AzureFirewallListResult"] + """Gets all the Azure Firewalls 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 AzureFirewallListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureFirewallListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureFirewallListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('AzureFirewallListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureFirewalls'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bastion_hosts_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bastion_hosts_operations.py new file mode 100644 index 000000000000..f90f2cc07c14 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bastion_hosts_operations.py @@ -0,0 +1,485 @@ +# 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 BastionHostsOperations(object): + """BastionHostsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + bastion_host_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-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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, 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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_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, + bastion_host_name=bastion_host_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BastionHost" + """Gets the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BastionHost, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BastionHost + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BastionHost', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + parameters, # type: "_models.BastionHost" + **kwargs # type: Any + ): + # type: (...) -> "_models.BastionHost" + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(parameters, 'BastionHost') + 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('BastionHost', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BastionHost', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + parameters, # type: "_models.BastionHost" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.BastionHost"] + """Creates or updates the specified Bastion Host. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param parameters: Parameters supplied to the create or update Bastion Host operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BastionHost + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BastionHost or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.BastionHost] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHost"] + lro_delay = kwargs.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, + bastion_host_name=bastion_host_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('BastionHost', 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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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': 'azure-async-operation'}, 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.Network/bastionHosts/{bastionHostName}'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BastionHostListResult"] + """Lists all Bastion Hosts 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 BastionHostListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionHostListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHostListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BastionHostListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/bastionHosts'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BastionHostListResult"] + """Lists all Bastion Hosts in a 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 BastionHostListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionHostListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionHostListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BastionHostListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/bastionHosts'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bgp_service_communities_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bgp_service_communities_operations.py new file mode 100644 index 000000000000..5046538f9887 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_bgp_service_communities_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 BgpServiceCommunitiesOperations(object): + """BgpServiceCommunitiesOperations 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.network.v2020_08_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.BgpServiceCommunityListResult"] + """Gets all the available bgp service communities. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BgpServiceCommunityListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BgpServiceCommunityListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpServiceCommunityListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('BgpServiceCommunityListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/bgpServiceCommunities'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_connection_monitors_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_connection_monitors_operations.py new file mode 100644 index 000000000000..c7fcb267c016 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_connection_monitors_operations.py @@ -0,0 +1,887 @@ +# 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 ConnectionMonitorsOperations(object): + """ConnectionMonitorsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + parameters, # type: "_models.ConnectionMonitor" + migrate=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionMonitorResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 migrate is not None: + query_parameters['migrate'] = self._serialize.query("migrate", migrate, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ConnectionMonitor') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + parameters, # type: "_models.ConnectionMonitor" + migrate=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ConnectionMonitorResult"] + """Create or update a connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :param parameters: Parameters that define the operation to create a connection monitor. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitor + :param migrate: Value indicating whether connection monitor V1 should be migrated to V2 format. + :type migrate: 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 ConnectionMonitorResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + lro_delay = kwargs.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, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_name, + parameters=parameters, + migrate=migrate, + 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('ConnectionMonitorResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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': 'azure-async-operation'}, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionMonitorResult" + """Gets a connection monitor by name. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionMonitorResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionMonitorResult" + """Update tags of the specified connection monitor. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_name: str + :param parameters: Parameters supplied to update connection monitor tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionMonitorResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionMonitorResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}'} # type: ignore + + def _stop_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/stop'} # type: ignore + + def begin_stop( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Stops the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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._stop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/stop'} # type: ignore + + def _start_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_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-08-01" + accept = "application/json" + + # Construct URL + url = self._start_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _start_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/start'} # type: ignore + + def begin_start( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Starts the specified connection monitor. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name of the connection monitor. + :type connection_monitor_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._start_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/start'} # type: ignore + + def _query_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionMonitorQueryResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorQueryResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._query_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectionMonitorQueryResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ConnectionMonitorQueryResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _query_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/query'} # type: ignore + + def begin_query( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + connection_monitor_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ConnectionMonitorQueryResult"] + """Query a snapshot of the most recent connection states. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param connection_monitor_name: The name given to the connection monitor. + :type connection_monitor_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 ConnectionMonitorQueryResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorQueryResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorQueryResult"] + lro_delay = kwargs.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._query_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + connection_monitor_name=connection_monitor_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('ConnectionMonitorQueryResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'connectionMonitorName': self._serialize.url("connection_monitor_name", connection_monitor_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_query.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectionMonitors/{connectionMonitorName}/query'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ConnectionMonitorListResult"] + """Lists all connection monitors for the specified Network Watcher. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ConnectionMonitorListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ConnectionMonitorListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionMonitorListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ConnectionMonitorListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/connectionMonitors'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_custom_ip_prefixes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_custom_ip_prefixes_operations.py new file mode 100644 index 000000000000..b4d2196128b4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_custom_ip_prefixes_operations.py @@ -0,0 +1,557 @@ +# 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 CustomIPPrefixesOperations(object): + """CustomIPPrefixesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + custom_ip_prefix_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-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + custom_ip_prefix_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified custom IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the CustomIpPrefix. + :type custom_ip_prefix_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, + custom_ip_prefix_name=custom_ip_prefix_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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_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.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + custom_ip_prefix_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomIpPrefix" + """Gets the specified custom IP prefix in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomIpPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + custom_ip_prefix_name, # type: str + parameters, # type: "_models.CustomIpPrefix" + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomIpPrefix" + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'CustomIpPrefix') + 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('CustomIpPrefix', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + custom_ip_prefix_name, # type: str + parameters, # type: "_models.CustomIpPrefix" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.CustomIpPrefix"] + """Creates or updates a custom IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param parameters: Parameters supplied to the create or update custom IP prefix operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 CustomIpPrefix or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + lro_delay = kwargs.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, + custom_ip_prefix_name=custom_ip_prefix_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('CustomIpPrefix', 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'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_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.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + custom_ip_prefix_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomIpPrefix" + """Updates custom IP prefix tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param custom_ip_prefix_name: The name of the custom IP prefix. + :type custom_ip_prefix_name: str + :param parameters: Parameters supplied to update custom IP prefix tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomIpPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.CustomIpPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'customIpPrefixName': self._serialize.url("custom_ip_prefix_name", custom_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('CustomIpPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/customIpPrefixes/{customIpPrefixName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CustomIpPrefixListResult"] + """Gets all the custom IP prefixes 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 CustomIpPrefixListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('CustomIpPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/customIpPrefixes'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CustomIpPrefixListResult"] + """Gets all custom IP prefixes in a 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 CustomIpPrefixListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.CustomIpPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomIpPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CustomIpPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/customIpPrefixes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_custom_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_custom_policies_operations.py new file mode 100644 index 000000000000..b1b78de0cc68 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_custom_policies_operations.py @@ -0,0 +1,413 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DdosCustomPoliciesOperations(object): + """DdosCustomPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + ddos_custom_policy_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-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + ddos_custom_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_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, + ddos_custom_policy_name=ddos_custom_policy_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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_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.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + ddos_custom_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosCustomPolicy" + """Gets information about the specified DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosCustomPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + ddos_custom_policy_name, # type: str + parameters, # type: "_models.DdosCustomPolicy" + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosCustomPolicy" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DdosCustomPolicy') + 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('DdosCustomPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + ddos_custom_policy_name, # type: str + parameters, # type: "_models.DdosCustomPolicy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DdosCustomPolicy"] + """Creates or updates a DDoS custom policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :param parameters: Parameters supplied to the create or update operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DdosCustomPolicy or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + lro_delay = kwargs.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, + ddos_custom_policy_name=ddos_custom_policy_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('DdosCustomPolicy', 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'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_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': 'azure-async-operation'}, 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.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + ddos_custom_policy_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosCustomPolicy" + """Update a DDoS custom policy tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_custom_policy_name: The name of the DDoS custom policy. + :type ddos_custom_policy_name: str + :param parameters: Parameters supplied to update DDoS custom policy resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosCustomPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosCustomPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosCustomPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ddosCustomPolicyName': self._serialize.url("ddos_custom_policy_name", ddos_custom_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('DdosCustomPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosCustomPolicies/{ddosCustomPolicyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_protection_plans_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_protection_plans_operations.py new file mode 100644 index 000000000000..a1b8f750b121 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ddos_protection_plans_operations.py @@ -0,0 +1,552 @@ +# 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 DdosProtectionPlansOperations(object): + """DdosProtectionPlansOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + ddos_protection_plan_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-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + ddos_protection_plan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_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, + ddos_protection_plan_name=ddos_protection_plan_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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_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.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + ddos_protection_plan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosProtectionPlan" + """Gets information about the specified DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosProtectionPlan, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + ddos_protection_plan_name, # type: str + parameters, # type: "_models.DdosProtectionPlan" + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosProtectionPlan" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DdosProtectionPlan') + 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('DdosProtectionPlan', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + ddos_protection_plan_name, # type: str + parameters, # type: "_models.DdosProtectionPlan" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DdosProtectionPlan"] + """Creates or updates a DDoS protection plan. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :param parameters: Parameters supplied to the create or update operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DdosProtectionPlan or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + lro_delay = kwargs.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, + ddos_protection_plan_name=ddos_protection_plan_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('DdosProtectionPlan', 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'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_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': 'azure-async-operation'}, 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.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + ddos_protection_plan_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.DdosProtectionPlan" + """Update a DDoS protection plan tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ddos_protection_plan_name: The name of the DDoS protection plan. + :type ddos_protection_plan_name: str + :param parameters: Parameters supplied to the update DDoS protection plan resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DdosProtectionPlan, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ddosProtectionPlanName': self._serialize.url("ddos_protection_plan_name", ddos_protection_plan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('DdosProtectionPlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ddosProtectionPlans/{ddosProtectionPlanName}'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DdosProtectionPlanListResult"] + """Gets all DDoS protection plans 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 DdosProtectionPlanListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlanListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlanListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('DdosProtectionPlanListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ddosProtectionPlans'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DdosProtectionPlanListResult"] + """Gets all the DDoS protection plans in a 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 DdosProtectionPlanListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.DdosProtectionPlanListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DdosProtectionPlanListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('DdosProtectionPlanListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ddosProtectionPlans'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_default_security_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_default_security_rules_operations.py new file mode 100644 index 000000000000..e6cd4b564a79 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_default_security_rules_operations.py @@ -0,0 +1,184 @@ +# 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 DefaultSecurityRulesOperations(object): + """DefaultSecurityRulesOperations 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.network.v2020_08_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_group_name, # type: str + network_security_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SecurityRuleListResult"] + """Gets all default security rules in a network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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 SecurityRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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('SecurityRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + default_security_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityRule" + """Get the specified default network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param default_security_rule_name: The name of the default security rule. + :type default_security_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'defaultSecurityRuleName': self._serialize.url("default_security_rule_name", default_security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/defaultSecurityRules/{defaultSecurityRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_dscp_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_dscp_configuration_operations.py new file mode 100644 index 000000000000..d9babe7edb9c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_dscp_configuration_operations.py @@ -0,0 +1,485 @@ +# 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 DscpConfigurationOperations(object): + """DscpConfigurationOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + dscp_configuration_name, # type: str + parameters, # type: "_models.DscpConfiguration" + **kwargs # type: Any + ): + # type: (...) -> "_models.DscpConfiguration" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'DscpConfiguration') + 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('DscpConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DscpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + dscp_configuration_name, # type: str + parameters, # type: "_models.DscpConfiguration" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DscpConfiguration"] + """Creates or updates a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_name: str + :param parameters: Parameters supplied to the create or update dscp configuration operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.DscpConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 DscpConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.DscpConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + lro_delay = kwargs.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, + dscp_configuration_name=dscp_configuration_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('DscpConfiguration', 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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_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.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + dscp_configuration_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-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + dscp_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_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, + dscp_configuration_name=dscp_configuration_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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_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.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + dscp_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DscpConfiguration" + """Gets a DSCP Configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param dscp_configuration_name: The name of the resource. + :type dscp_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DscpConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DscpConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'dscpConfigurationName': self._serialize.url("dscp_configuration_name", dscp_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('DscpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/dscpConfigurations/{dscpConfigurationName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DscpConfigurationListResult"] + """Gets a DSCP Configuration. + + :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 DscpConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.DscpConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DscpConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/dscpConfigurations'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DscpConfigurationListResult"] + """Gets all dscp configurations 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 DscpConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.DscpConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DscpConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('DscpConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/dscpConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_authorizations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_authorizations_operations.py new file mode 100644 index 000000000000..368eee3f4d9c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_authorizations_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 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 ExpressRouteCircuitAuthorizationsOperations(object): + """ExpressRouteCircuitAuthorizationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + authorization_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + circuit_name, # type: str + authorization_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified authorization from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_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, + circuit_name=circuit_name, + authorization_name=authorization_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_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.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + circuit_name, # type: str + authorization_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitAuthorization" + """Gets the specified authorization from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitAuthorization, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitAuthorization', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + authorization_name, # type: str + authorization_parameters, # type: "_models.ExpressRouteCircuitAuthorization" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitAuthorization" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(authorization_parameters, 'ExpressRouteCircuitAuthorization') + 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('ExpressRouteCircuitAuthorization', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitAuthorization', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + circuit_name, # type: str + authorization_name, # type: str + authorization_parameters, # type: "_models.ExpressRouteCircuitAuthorization" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitAuthorization"] + """Creates or updates an authorization in the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param authorization_name: The name of the authorization. + :type authorization_name: str + :param authorization_parameters: Parameters supplied to the create or update express route + circuit authorization operation. + :type authorization_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitAuthorization or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitAuthorization] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitAuthorization"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + authorization_name=authorization_name, + authorization_parameters=authorization_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('ExpressRouteCircuitAuthorization', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'authorizationName': self._serialize.url("authorization_name", authorization_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/authorizations/{authorizationName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + circuit_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AuthorizationListResult"] + """Gets all authorizations in an express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AuthorizationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AuthorizationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AuthorizationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AuthorizationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/authorizations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_connections_operations.py new file mode 100644 index 000000000000..5d2612776e49 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_connections_operations.py @@ -0,0 +1,465 @@ +# 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 ExpressRouteCircuitConnectionsOperations(object): + """ExpressRouteCircuitConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Express Route Circuit Connection from the specified express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type 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 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, + circuit_name=circuit_name, + peering_name=peering_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitConnection" + """Gets the specified Express Route Circuit Connection from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_name, # type: str + express_route_circuit_connection_parameters, # type: "_models.ExpressRouteCircuitConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(express_route_circuit_connection_parameters, 'ExpressRouteCircuitConnection') + 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('ExpressRouteCircuitConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_name, # type: str + express_route_circuit_connection_parameters, # type: "_models.ExpressRouteCircuitConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitConnection"] + """Creates or updates a Express Route Circuit Connection in the specified express route circuits. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the express route circuit connection. + :type connection_name: str + :param express_route_circuit_connection_parameters: Parameters supplied to the create or update + express route circuit connection operation. + :type express_route_circuit_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnection"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + peering_name=peering_name, + connection_name=connection_name, + express_route_circuit_connection_parameters=express_route_circuit_connection_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('ExpressRouteCircuitConnection', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCircuitConnectionListResult"] + """Gets all global reach connections associated with a private peering in an express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCircuitConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/connections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_peerings_operations.py new file mode 100644 index 000000000000..7be0860a6691 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuit_peerings_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 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 ExpressRouteCircuitPeeringsOperations(object): + """ExpressRouteCircuitPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified peering from the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_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, + circuit_name=circuit_name, + peering_name=peering_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitPeering" + """Gets the specified peering for the express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + peering_parameters, # type: "_models.ExpressRouteCircuitPeering" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitPeering" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(peering_parameters, 'ExpressRouteCircuitPeering') + 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('ExpressRouteCircuitPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuitPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + peering_parameters, # type: "_models.ExpressRouteCircuitPeering" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitPeering"] + """Creates or updates a peering in the specified express route circuits. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param peering_parameters: Parameters supplied to the create or update express route circuit + peering operation. + :type peering_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuitPeering or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeering"] + lro_delay = kwargs.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, + circuit_name=circuit_name, + peering_name=peering_name, + peering_parameters=peering_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('ExpressRouteCircuitPeering', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + circuit_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCircuitPeeringListResult"] + """Gets all peerings in a specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCircuitPeeringListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuits_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuits_operations.py new file mode 100644 index 000000000000..0e33b5353fc0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_circuits_operations.py @@ -0,0 +1,1073 @@ +# 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 ExpressRouteCircuitsOperations(object): + """ExpressRouteCircuitsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + circuit_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-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + circuit_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_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, + circuit_name=circuit_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'), + 'circuitName': self._serialize.url("circuit_name", circuit_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.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + circuit_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuit" + """Gets information about the specified express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuit, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + parameters, # type: "_models.ExpressRouteCircuit" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuit" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ExpressRouteCircuit') + 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('ExpressRouteCircuit', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + circuit_name, # type: str + parameters, # type: "_models.ExpressRouteCircuit" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuit"] + """Creates or updates an express route circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param parameters: Parameters supplied to the create or update express route circuit operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCircuit or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + lro_delay = kwargs.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, + circuit_name=circuit_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('ExpressRouteCircuit', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_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': 'azure-async-operation'}, 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.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + circuit_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuit" + """Updates an express route circuit tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param parameters: Parameters supplied to update express route circuit tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuit, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuit + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuit"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ExpressRouteCircuit', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}'} # type: ignore + + def _list_arp_table_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCircuitsArpTableListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsArpTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_arp_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsArpTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_arp_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + def begin_list_arp_table( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitsArpTableListResult"] + """Gets the currently advertised ARP table associated with the express route circuit in a resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsArpTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsArpTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsArpTableListResult"] + lro_delay = kwargs.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_arp_table_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsArpTableListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_arp_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + def _list_routes_table_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCircuitsRoutesTableListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + def begin_list_routes_table( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitsRoutesTableListResult"] + """Gets the currently advertised routes table associated with the express route circuit in a + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableListResult"] + lro_delay = kwargs.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_routes_table_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + def _list_routes_table_summary_initial( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_summary_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableSummaryListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_summary_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + def begin_list_routes_table_summary( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"] + """Gets the currently advertised routes table summary associated with the express route circuit in + a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableSummaryListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableSummaryListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableSummaryListResult"] + lro_delay = kwargs.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_routes_table_summary_initial( + resource_group_name=resource_group_name, + circuit_name=circuit_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableSummaryListResult', 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table_summary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + def get_stats( + self, + resource_group_name, # type: str + circuit_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitStats" + """Gets all the stats from an express route circuit in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitStats, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitStats"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_stats.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitStats', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_stats.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/stats'} # type: ignore + + def get_peering_stats( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCircuitStats" + """Gets all stats from an express route circuit in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCircuitStats, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitStats + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitStats"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_peering_stats.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCircuitStats', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_peering_stats.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/stats'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCircuitListResult"] + """Gets all the express route circuits in a 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 ExpressRouteCircuitListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCircuitListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCircuits'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCircuitListResult"] + """Gets all the express route circuits 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 ExpressRouteCircuitListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('ExpressRouteCircuitListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/expressRouteCircuits'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_connections_operations.py new file mode 100644 index 000000000000..82ee3c5c7635 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_connections_operations.py @@ -0,0 +1,424 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ExpressRouteConnectionsOperations(object): + """ExpressRouteConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + connection_name, # type: str + put_express_route_connection_parameters, # type: "_models.ExpressRouteConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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(put_express_route_connection_parameters, 'ExpressRouteConnection') + 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('ExpressRouteConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + connection_name, # type: str + put_express_route_connection_parameters, # type: "_models.ExpressRouteConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteConnection"] + """Creates a connection between an ExpressRoute gateway and an ExpressRoute circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the connection subresource. + :type connection_name: str + :param put_express_route_connection_parameters: Parameters required in an + ExpressRouteConnection PUT operation. + :type put_express_route_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + lro_delay = kwargs.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, + express_route_gateway_name=express_route_gateway_name, + connection_name=connection_name, + put_express_route_connection_parameters=put_express_route_connection_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('ExpressRouteConnection', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteConnection" + """Gets the specified ExpressRouteConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the ExpressRoute connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + connection_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-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a connection to a ExpressRoute circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param connection_name: The name of the connection subresource. + :type 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 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, + express_route_gateway_name=express_route_gateway_name, + connection_name=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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteConnectionList" + """Lists ExpressRouteConnections. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteConnectionList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteConnectionList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteConnectionList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteConnectionList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}/expressRouteConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connection_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connection_peerings_operations.py new file mode 100644 index 000000000000..32115652322d --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connection_peerings_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 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 ExpressRouteCrossConnectionPeeringsOperations(object): + """ExpressRouteCrossConnectionPeeringsOperations 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.network.v2020_08_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_group_name, # type: str + cross_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCrossConnectionPeeringList"] + """Gets all peerings in a specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteCrossConnectionPeeringList or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeeringList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeeringList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ExpressRouteCrossConnectionPeeringList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_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-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified peering from the ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_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, + cross_connection_name=cross_connection_name, + peering_name=peering_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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCrossConnectionPeering" + """Gets the specified peering for the ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnectionPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteCrossConnectionPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + peering_parameters, # type: "_models.ExpressRouteCrossConnectionPeering" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCrossConnectionPeering" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(peering_parameters, 'ExpressRouteCrossConnectionPeering') + 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('ExpressRouteCrossConnectionPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteCrossConnectionPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + peering_parameters, # type: "_models.ExpressRouteCrossConnectionPeering" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCrossConnectionPeering"] + """Creates or updates a peering in the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param peering_parameters: Parameters supplied to the create or update + ExpressRouteCrossConnection peering operation. + :type peering_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCrossConnectionPeering or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionPeering"] + lro_delay = kwargs.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, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + peering_parameters=peering_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('ExpressRouteCrossConnectionPeering', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connections_operations.py new file mode 100644 index 000000000000..2a20f4c43db1 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_cross_connections_operations.py @@ -0,0 +1,839 @@ +# 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 ExpressRouteCrossConnectionsOperations(object): + """ExpressRouteCrossConnectionsOperations 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.network.v2020_08_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.ExpressRouteCrossConnectionListResult"] + """Retrieves all the ExpressRouteCrossConnections 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 ExpressRouteCrossConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteCrossConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/expressRouteCrossConnections'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteCrossConnectionListResult"] + """Retrieves all the ExpressRouteCrossConnections in a 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 ExpressRouteCrossConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteCrossConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/expressRouteCrossConnections'} # type: ignore + + def get( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCrossConnection" + """Gets details about the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group (peering location of the circuit). + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection (service key of the + circuit). + :type cross_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + parameters, # type: "_models.ExpressRouteCrossConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCrossConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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(parameters, 'ExpressRouteCrossConnection') + 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('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + parameters, # type: "_models.ExpressRouteCrossConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCrossConnection"] + """Update the specified ExpressRouteCrossConnection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param parameters: Parameters supplied to the update express route crossConnection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteCrossConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + lro_delay = kwargs.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, + cross_connection_name=cross_connection_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('ExpressRouteCrossConnection', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + cross_connection_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteCrossConnection" + """Updates an express route cross connection tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the cross connection. + :type cross_connection_name: str + :param cross_connection_parameters: Parameters supplied to update express route cross + connection tags. + :type cross_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteCrossConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_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(cross_connection_parameters, 'TagsObject') + 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('ExpressRouteCrossConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}'} # type: ignore + + def _list_arp_table_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCircuitsArpTableListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsArpTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_arp_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsArpTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_arp_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + def begin_list_arp_table( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitsArpTableListResult"] + """Gets the currently advertised ARP table associated with the express route cross connection in a + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsArpTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsArpTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsArpTableListResult"] + lro_delay = kwargs.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_arp_table_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsArpTableListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_arp_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/arpTables/{devicePath}'} # type: ignore + + def _list_routes_table_summary_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_summary_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCrossConnectionsRoutesTableSummaryListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_summary_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + def begin_list_routes_table_summary( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"] + """Gets the route table summary associated with the express route cross connection in a resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCrossConnectionsRoutesTableSummaryListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCrossConnectionsRoutesTableSummaryListResult"] + lro_delay = kwargs.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_routes_table_summary_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCrossConnectionsRoutesTableSummaryListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table_summary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTablesSummary/{devicePath}'} # type: ignore + + def _list_routes_table_initial( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteCircuitsRoutesTableListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteCircuitsRoutesTableListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_routes_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ExpressRouteCircuitsRoutesTableListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_routes_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore + + def begin_list_routes_table( + self, + resource_group_name, # type: str + cross_connection_name, # type: str + peering_name, # type: str + device_path, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteCircuitsRoutesTableListResult"] + """Gets the currently advertised routes table associated with the express route cross connection + in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cross_connection_name: The name of the ExpressRouteCrossConnection. + :type cross_connection_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param device_path: The path of the device. + :type device_path: 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 ExpressRouteCircuitsRoutesTableListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteCircuitsRoutesTableListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteCircuitsRoutesTableListResult"] + lro_delay = kwargs.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_routes_table_initial( + resource_group_name=resource_group_name, + cross_connection_name=cross_connection_name, + peering_name=peering_name, + device_path=device_path, + 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('ExpressRouteCircuitsRoutesTableListResult', 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'), + 'crossConnectionName': self._serialize.url("cross_connection_name", cross_connection_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'devicePath': self._serialize.url("device_path", device_path, '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_list_routes_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCrossConnections/{crossConnectionName}/peerings/{peeringName}/routeTables/{devicePath}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_gateways_operations.py new file mode 100644 index 000000000000..3ff154fab66a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_gateways_operations.py @@ -0,0 +1,583 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ExpressRouteGatewaysOperations(object): + """ExpressRouteGatewaysOperations 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.network.v2020_08_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_subscription( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteGatewayList" + """Lists ExpressRoute gateways under a given subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteGatewayList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGatewayList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # 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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteGatewayList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_by_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/expressRouteGateways'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteGatewayList" + """Lists ExpressRoute gateways in a given 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: ExpressRouteGatewayList, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGatewayList + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGatewayList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # 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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ExpressRouteGatewayList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + put_express_route_gateway_parameters, # type: "_models.ExpressRouteGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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(put_express_route_gateway_parameters, 'ExpressRouteGateway') + 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('ExpressRouteGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + put_express_route_gateway_parameters, # type: "_models.ExpressRouteGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteGateway"] + """Creates or updates a ExpressRoute gateway in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :param put_express_route_gateway_parameters: Parameters required in an ExpressRoute gateway PUT + operation. + :type put_express_route_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + lro_delay = kwargs.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, + express_route_gateway_name=express_route_gateway_name, + put_express_route_gateway_parameters=put_express_route_gateway_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('ExpressRouteGateway', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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': 'azure-async-operation'}, 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.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + express_route_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ExpressRouteGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ExpressRouteGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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(express_route_gateway_parameters, 'TagsObject') + 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('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + express_route_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRouteGateway"] + """Updates express route gateway tags. + + :param resource_group_name: The resource group name of the ExpressRouteGateway. + :type resource_group_name: str + :param express_route_gateway_name: The name of the gateway. + :type express_route_gateway_name: str + :param express_route_gateway_parameters: Parameters supplied to update a virtual wan express + route gateway tags. + :type express_route_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRouteGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + express_route_gateway_name=express_route_gateway_name, + express_route_gateway_parameters=express_route_gateway_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('ExpressRouteGateway', 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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteGateway" + """Fetches the details of a ExpressRoute gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ExpressRouteGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + express_route_gateway_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-08-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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_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.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/Microsoft.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + express_route_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified ExpressRoute gateway in a resource group. An ExpressRoute gateway + resource can only be deleted when there are no connection subresources. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_gateway_name: The name of the ExpressRoute gateway. + :type express_route_gateway_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, + express_route_gateway_name=express_route_gateway_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'), + 'expressRouteGatewayName': self._serialize.url("express_route_gateway_name", express_route_gateway_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.Network/expressRouteGateways/{expressRouteGatewayName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_links_operations.py new file mode 100644 index 000000000000..7e86fb47b612 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_links_operations.py @@ -0,0 +1,184 @@ +# 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 ExpressRouteLinksOperations(object): + """ExpressRouteLinksOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + link_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRouteLink" + """Retrieves the specified ExpressRouteLink resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param link_name: The name of the ExpressRouteLink resource. + :type link_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRouteLink, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRouteLink + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteLink"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_name, 'str'), + 'linkName': self._serialize.url("link_name", link_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('ExpressRouteLink', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}/links/{linkName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRouteLinkListResult"] + """Retrieve the ExpressRouteLink sub-resources of the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteLinkListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteLinkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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('ExpressRouteLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}/links'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_locations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_locations_operations.py new file mode 100644 index 000000000000..31a7b0bd0e3a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_locations_operations.py @@ -0,0 +1,171 @@ +# 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 ExpressRoutePortsLocationsOperations(object): + """ExpressRoutePortsLocationsOperations 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.network.v2020_08_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.ExpressRoutePortsLocationListResult"] + """Retrieves all ExpressRoutePort peering locations. Does not return available bandwidths for each + location. Available bandwidths can only be obtained when retrieving a specific peering + location. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRoutePortsLocationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortsLocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRoutePortsLocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ExpressRoutePortsLocations'} # type: ignore + + def get( + self, + location_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRoutePortsLocation" + """Retrieves a single ExpressRoutePort peering location, including the list of available + bandwidths available at said peering location. + + :param location_name: Name of the requested ExpressRoutePort peering location. + :type location_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePortsLocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortsLocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortsLocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'locationName': self._serialize.url("location_name", location_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('ExpressRoutePortsLocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/ExpressRoutePortsLocations/{locationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_operations.py new file mode 100644 index 000000000000..b392736f288a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_ports_operations.py @@ -0,0 +1,619 @@ +# 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 ExpressRoutePortsOperations(object): + """ExpressRoutePortsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + express_route_port_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-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_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, + express_route_port_name=express_route_port_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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRoutePort" + """Retrieves the requested ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of ExpressRoutePort. + :type express_route_port_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePort, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + parameters, # type: "_models.ExpressRoutePort" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRoutePort" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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, 'ExpressRoutePort') + 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('ExpressRoutePort', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + parameters, # type: "_models.ExpressRoutePort" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ExpressRoutePort"] + """Creates or updates the specified ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param parameters: Parameters supplied to the create ExpressRoutePort operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ExpressRoutePort or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + lro_delay = kwargs.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, + express_route_port_name=express_route_port_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('ExpressRoutePort', 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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ExpressRoutePort" + """Update ExpressRoutePort tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of the ExpressRoutePort resource. + :type express_route_port_name: str + :param parameters: Parameters supplied to update ExpressRoutePort resource tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ExpressRoutePort, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ExpressRoutePort + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePort"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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, 'TagsObject') + 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('ExpressRoutePort', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ExpressRoutePorts/{expressRoutePortName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRoutePortListResult"] + """List all the ExpressRoutePort resources in the specified 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 ExpressRoutePortListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ExpressRoutePortListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ExpressRoutePorts'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ExpressRoutePortListResult"] + """List all the ExpressRoutePort resources in the specified subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRoutePortListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRoutePortListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRoutePortListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRoutePortListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ExpressRoutePorts'} # type: ignore + + def generate_loa( + self, + resource_group_name, # type: str + express_route_port_name, # type: str + request, # type: "_models.GenerateExpressRoutePortsLOARequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.GenerateExpressRoutePortsLOAResult" + """Generate a letter of authorization for the requested ExpressRoutePort resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param express_route_port_name: The name of ExpressRoutePort. + :type express_route_port_name: str + :param request: Request parameters supplied to generate a letter of authorization. + :type request: ~azure.mgmt.network.v2020_08_01.models.GenerateExpressRoutePortsLOARequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenerateExpressRoutePortsLOAResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.GenerateExpressRoutePortsLOAResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenerateExpressRoutePortsLOAResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.generate_loa.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'), + 'expressRoutePortName': self._serialize.url("express_route_port_name", express_route_port_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(request, 'GenerateExpressRoutePortsLOARequest') + 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('GenerateExpressRoutePortsLOAResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + generate_loa.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRoutePorts/{expressRoutePortName}/generateLoa'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_service_providers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_service_providers_operations.py new file mode 100644 index 000000000000..910a3047e28e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_express_route_service_providers_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 ExpressRouteServiceProvidersOperations(object): + """ExpressRouteServiceProvidersOperations 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.network.v2020_08_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.ExpressRouteServiceProviderListResult"] + """Gets all the available express route service providers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ExpressRouteServiceProviderListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ExpressRouteServiceProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ExpressRouteServiceProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ExpressRouteServiceProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/expressRouteServiceProviders'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policies_operations.py new file mode 100644 index 000000000000..e909dab45f1c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policies_operations.py @@ -0,0 +1,490 @@ +# 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 FirewallPoliciesOperations(object): + """FirewallPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + firewall_policy_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-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_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, + firewall_policy_name=firewall_policy_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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_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.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.FirewallPolicy" + """Gets the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + parameters, # type: "_models.FirewallPolicy" + **kwargs # type: Any + ): + # type: (...) -> "_models.FirewallPolicy" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FirewallPolicy') + 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('FirewallPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + parameters, # type: "_models.FirewallPolicy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FirewallPolicy"] + """Creates or updates the specified Firewall Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param parameters: Parameters supplied to the create or update Firewall Policy operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FirewallPolicy or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.FirewallPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicy"] + lro_delay = kwargs.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, + firewall_policy_name=firewall_policy_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('FirewallPolicy', 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_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': 'azure-async-operation'}, 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.Network/firewallPolicies/{firewallPolicyName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FirewallPolicyListResult"] + """Lists all Firewall Policies in a 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 FirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/firewallPolicies'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FirewallPolicyListResult"] + """Gets all the Firewall Policies 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 FirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('FirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/firewallPolicies'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policy_rule_collection_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policy_rule_collection_groups_operations.py new file mode 100644 index 000000000000..02551cbc9c9b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_firewall_policy_rule_collection_groups_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 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 FirewallPolicyRuleCollectionGroupsOperations(object): + """FirewallPolicyRuleCollectionGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + rule_collection_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-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + rule_collection_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_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, + firewall_policy_name=firewall_policy_name, + rule_collection_group_name=rule_collection_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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_group_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.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + rule_collection_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FirewallPolicyRuleCollectionGroup" + """Gets the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FirewallPolicyRuleCollectionGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + rule_collection_group_name, # type: str + parameters, # type: "_models.FirewallPolicyRuleCollectionGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.FirewallPolicyRuleCollectionGroup" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FirewallPolicyRuleCollectionGroup') + 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('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FirewallPolicyRuleCollectionGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + rule_collection_group_name, # type: str + parameters, # type: "_models.FirewallPolicyRuleCollectionGroup" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FirewallPolicyRuleCollectionGroup"] + """Creates or updates the specified FirewallPolicyRuleCollectionGroup. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :param rule_collection_group_name: The name of the FirewallPolicyRuleCollectionGroup. + :type rule_collection_group_name: str + :param parameters: Parameters supplied to the create or update + FirewallPolicyRuleCollectionGroup operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FirewallPolicyRuleCollectionGroup or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroup"] + lro_delay = kwargs.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, + firewall_policy_name=firewall_policy_name, + rule_collection_group_name=rule_collection_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('FirewallPolicyRuleCollectionGroup', 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'ruleCollectionGroupName': self._serialize.url("rule_collection_group_name", rule_collection_group_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': 'azure-async-operation'}, 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.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups/{ruleCollectionGroupName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + firewall_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FirewallPolicyRuleCollectionGroupListResult"] + """Lists all FirewallPolicyRuleCollectionGroups in a FirewallPolicy resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param firewall_policy_name: The name of the Firewall Policy. + :type firewall_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FirewallPolicyRuleCollectionGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.FirewallPolicyRuleCollectionGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FirewallPolicyRuleCollectionGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'firewallPolicyName': self._serialize.url("firewall_policy_name", firewall_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FirewallPolicyRuleCollectionGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/firewallPolicies/{firewallPolicyName}/ruleCollectionGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_flow_logs_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_flow_logs_operations.py new file mode 100644 index 000000000000..6eb347648dd5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_flow_logs_operations.py @@ -0,0 +1,516 @@ +# 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 FlowLogsOperations(object): + """FlowLogsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_name, # type: str + parameters, # type: "_models.FlowLog" + **kwargs # type: Any + ): + # type: (...) -> "_models.FlowLog" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLog') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLog', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_name, # type: str + parameters, # type: "_models.FlowLog" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FlowLog"] + """Create or update a flow log for the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log. + :type flow_log_name: str + :param parameters: Parameters that define the create or update flow log resource. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLog or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLog] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + lro_delay = kwargs.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, + network_watcher_name=network_watcher_name, + flow_log_name=flow_log_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('FlowLog', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_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': 'azure-async-operation'}, 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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.FlowLog" + """Update tags of the specified flow log. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log. + :type flow_log_name: str + :param parameters: Parameters supplied to update flow log tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FlowLog, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FlowLog" + """Gets a flow log resource by name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log resource. + :type flow_log_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FlowLog, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FlowLog + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLog"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FlowLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + flow_log_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified flow log resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param flow_log_name: The name of the flow log resource. + :type flow_log_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, + network_watcher_name=network_watcher_name, + flow_log_name=flow_log_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'flowLogName': self._serialize.url("flow_log_name", flow_log_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.Network/networkWatchers/{networkWatcherName}/flowLogs/{flowLogName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FlowLogListResult"] + """Lists all flow log resources for the specified Network Watcher. + + :param resource_group_name: The name of the resource group containing Network Watcher. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FlowLogListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.FlowLogListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FlowLogListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/flowLogs'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_route_tables_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_route_tables_operations.py new file mode 100644 index 000000000000..2d3baf332e38 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_route_tables_operations.py @@ -0,0 +1,440 @@ +# 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 HubRouteTablesOperations(object): + """HubRouteTablesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + route_table_parameters, # type: "_models.HubRouteTable" + **kwargs # type: Any + ): + # type: (...) -> "_models.HubRouteTable" + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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(route_table_parameters, 'HubRouteTable') + 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('HubRouteTable', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubRouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + route_table_parameters, # type: "_models.HubRouteTable" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.HubRouteTable"] + """Creates a RouteTable resource if it doesn't exist else updates the existing RouteTable. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_name: str + :param route_table_parameters: Parameters supplied to create or update RouteTable. + :type route_table_parameters: ~azure.mgmt.network.v2020_08_01.models.HubRouteTable + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubRouteTable or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.HubRouteTable] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_name, + route_table_parameters=route_table_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('HubRouteTable', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HubRouteTable" + """Retrieves the details of a RouteTable. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubRouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubRouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubRouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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('HubRouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a RouteTable. + + :param resource_group_name: The resource group name of the RouteTable. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the RouteTable. + :type route_table_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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/virtualHubs/{virtualHubName}/hubRouteTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListHubRouteTablesResult"] + """Retrieves the details of all RouteTables. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListHubRouteTablesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListHubRouteTablesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListHubRouteTablesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListHubRouteTablesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubRouteTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_virtual_network_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_virtual_network_connections_operations.py new file mode 100644 index 000000000000..d6ae19448ab0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_hub_virtual_network_connections_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 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 HubVirtualNetworkConnectionsOperations(object): + """HubVirtualNetworkConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + hub_virtual_network_connection_parameters, # type: "_models.HubVirtualNetworkConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HubVirtualNetworkConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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(hub_virtual_network_connection_parameters, 'HubVirtualNetworkConnection') + 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('HubVirtualNetworkConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubVirtualNetworkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + hub_virtual_network_connection_parameters, # type: "_models.HubVirtualNetworkConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.HubVirtualNetworkConnection"] + """Creates a hub virtual network connection if it doesn't exist else updates the existing one. + + :param resource_group_name: The resource group name of the HubVirtualNetworkConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the HubVirtualNetworkConnection. + :type connection_name: str + :param hub_virtual_network_connection_parameters: Parameters supplied to create or update a hub + virtual network connection. + :type hub_virtual_network_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubVirtualNetworkConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + connection_name=connection_name, + hub_virtual_network_connection_parameters=hub_virtual_network_connection_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('HubVirtualNetworkConnection', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a HubVirtualNetworkConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the HubVirtualNetworkConnection. + :type 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 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, + virtual_hub_name=virtual_hub_name, + connection_name=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): + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HubVirtualNetworkConnection" + """Retrieves the details of a HubVirtualNetworkConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubVirtualNetworkConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubVirtualNetworkConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubVirtualNetworkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('HubVirtualNetworkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListHubVirtualNetworkConnectionsResult"] + """Retrieves the details of all HubVirtualNetworkConnections. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListHubVirtualNetworkConnectionsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListHubVirtualNetworkConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListHubVirtualNetworkConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListHubVirtualNetworkConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/hubVirtualNetworkConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_nat_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_nat_rules_operations.py new file mode 100644 index 000000000000..ef640998c494 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_nat_rules_operations.py @@ -0,0 +1,446 @@ +# 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 InboundNatRulesOperations(object): + """InboundNatRulesOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.InboundNatRuleListResult"] + """Gets all the inbound nat rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundNatRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.InboundNatRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('InboundNatRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + inbound_nat_rule_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + inbound_nat_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_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, + load_balancer_name=load_balancer_name, + inbound_nat_rule_name=inbound_nat_rule_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_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.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + inbound_nat_rule_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.InboundNatRule" + """Gets the specified load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: InboundNatRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.InboundNatRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('InboundNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + inbound_nat_rule_name, # type: str + inbound_nat_rule_parameters, # type: "_models.InboundNatRule" + **kwargs # type: Any + ): + # type: (...) -> "_models.InboundNatRule" + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(inbound_nat_rule_parameters, 'InboundNatRule') + 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('InboundNatRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('InboundNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + inbound_nat_rule_name, # type: str + inbound_nat_rule_parameters, # type: "_models.InboundNatRule" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.InboundNatRule"] + """Creates or updates a load balancer inbound nat rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param inbound_nat_rule_name: The name of the inbound nat rule. + :type inbound_nat_rule_name: str + :param inbound_nat_rule_parameters: Parameters supplied to the create or update inbound nat + rule operation. + :type inbound_nat_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.InboundNatRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 InboundNatRule or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.InboundNatRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundNatRule"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_name, + inbound_nat_rule_name=inbound_nat_rule_name, + inbound_nat_rule_parameters=inbound_nat_rule_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('InboundNatRule', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'inboundNatRuleName': self._serialize.url("inbound_nat_rule_name", inbound_nat_rule_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': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}/inboundNatRules/{inboundNatRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_security_rule_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_security_rule_operations.py new file mode 100644 index 000000000000..3d3066dada95 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_inbound_security_rule_operations.py @@ -0,0 +1,185 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class InboundSecurityRuleOperations(object): + """InboundSecurityRuleOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + rule_collection_name, # type: str + parameters, # type: "_models.InboundSecurityRule" + **kwargs # type: Any + ): + # type: (...) -> "_models.InboundSecurityRule" + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundSecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'ruleCollectionName': self._serialize.url("rule_collection_name", rule_collection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'InboundSecurityRule') + 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('InboundSecurityRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('InboundSecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/inboundSecurityRules/{ruleCollectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + rule_collection_name, # type: str + parameters, # type: "_models.InboundSecurityRule" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.InboundSecurityRule"] + """Creates or updates the specified Network Virtual Appliance Inbound Security Rules. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param rule_collection_name: The name of security rule collection. + :type rule_collection_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance + Inbound Security Rules operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.InboundSecurityRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 InboundSecurityRule or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.InboundSecurityRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundSecurityRule"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_name, + rule_collection_name=rule_collection_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('InboundSecurityRule', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'ruleCollectionName': self._serialize.url("rule_collection_name", rule_collection_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/inboundSecurityRules/{ruleCollectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_allocations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_allocations_operations.py new file mode 100644 index 000000000000..15bd54def618 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_allocations_operations.py @@ -0,0 +1,557 @@ +# 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 IpAllocationsOperations(object): + """IpAllocationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + ip_allocation_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-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + ip_allocation_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified IpAllocation. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_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, + ip_allocation_name=ip_allocation_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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_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.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + ip_allocation_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.IpAllocation" + """Gets the specified IpAllocation by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpAllocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + ip_allocation_name, # type: str + parameters, # type: "_models.IpAllocation" + **kwargs # type: Any + ): + # type: (...) -> "_models.IpAllocation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'IpAllocation') + 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('IpAllocation', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + ip_allocation_name, # type: str + parameters, # type: "_models.IpAllocation" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.IpAllocation"] + """Creates or updates an IpAllocation in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param parameters: Parameters supplied to the create or update virtual network operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 IpAllocation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.IpAllocation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + lro_delay = kwargs.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, + ip_allocation_name=ip_allocation_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('IpAllocation', 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'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_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': 'azure-async-operation'}, 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.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + ip_allocation_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.IpAllocation" + """Updates a IpAllocation tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_allocation_name: The name of the IpAllocation. + :type ip_allocation_name: str + :param parameters: Parameters supplied to update IpAllocation tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpAllocation, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpAllocation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ipAllocationName': self._serialize.url("ip_allocation_name", ip_allocation_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('IpAllocation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/IpAllocations/{ipAllocationName}'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IpAllocationListResult"] + """Gets all IpAllocations 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 IpAllocationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.IpAllocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpAllocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/IpAllocations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IpAllocationListResult"] + """Gets all IpAllocations in a 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 IpAllocationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.IpAllocationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpAllocationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpAllocationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/IpAllocations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_groups_operations.py new file mode 100644 index 000000000000..7e21b6d8abb4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_ip_groups_operations.py @@ -0,0 +1,564 @@ +# 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 IpGroupsOperations(object): + """IpGroupsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + ip_groups_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.IpGroup" + """Gets the specified ipGroups. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param expand: Expands resourceIds (of Firewalls/Network Security Groups etc.) back referenced + by the IpGroups resource. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + ip_groups_name, # type: str + parameters, # type: "_models.IpGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.IpGroup" + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'IpGroup') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('IpGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + ip_groups_name, # type: str + parameters, # type: "_models.IpGroup" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.IpGroup"] + """Creates or updates an ipGroups in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param parameters: Parameters supplied to the create or update IpGroups operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 IpGroup or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.IpGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + lro_delay = kwargs.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, + ip_groups_name=ip_groups_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('IpGroup', 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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_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': 'azure-async-operation'}, 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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def update_groups( + self, + resource_group_name, # type: str + ip_groups_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.IpGroup" + """Updates tags of an IpGroups resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_name: str + :param parameters: Parameters supplied to the update ipGroups operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IpGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IpGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_groups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('IpGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_groups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + ip_groups_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-08-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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + ip_groups_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified ipGroups. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param ip_groups_name: The name of the ipGroups. + :type ip_groups_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, + ip_groups_name=ip_groups_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'), + 'ipGroupsName': self._serialize.url("ip_groups_name", ip_groups_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.Network/ipGroups/{ipGroupsName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IpGroupListResult"] + """Gets all IpGroups in a 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 IpGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.IpGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/ipGroups'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IpGroupListResult"] + """Gets all IpGroups 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 IpGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.IpGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IpGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('IpGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/ipGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_backend_address_pools_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_backend_address_pools_operations.py new file mode 100644 index 000000000000..f779aa709fd3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_backend_address_pools_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 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 LoadBalancerBackendAddressPoolsOperations(object): + """LoadBalancerBackendAddressPoolsOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerBackendAddressPoolListResult"] + """Gets all the load balancer backed address pools. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerBackendAddressPoolListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerBackendAddressPoolListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerBackendAddressPoolListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerBackendAddressPoolListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + backend_address_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackendAddressPool" + """Gets load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackendAddressPool, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BackendAddressPool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackendAddressPool', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + backend_address_pool_name, # type: str + parameters, # type: "_models.BackendAddressPool" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackendAddressPool" + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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(parameters, 'BackendAddressPool') + 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('BackendAddressPool', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BackendAddressPool', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + backend_address_pool_name, # type: str + parameters, # type: "_models.BackendAddressPool" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.BackendAddressPool"] + """Creates or updates a load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_name: str + :param parameters: Parameters supplied to the create or update load balancer backend address + pool operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BackendAddressPool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BackendAddressPool or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.BackendAddressPool] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackendAddressPool"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_name, + backend_address_pool_name=backend_address_pool_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('BackendAddressPool', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + backend_address_pool_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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.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/Microsoft.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + backend_address_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified load balancer backend address pool. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param backend_address_pool_name: The name of the backend address pool. + :type backend_address_pool_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, + load_balancer_name=load_balancer_name, + backend_address_pool_name=backend_address_pool_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'backendAddressPoolName': self._serialize.url("backend_address_pool_name", backend_address_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, 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.Network/loadBalancers/{loadBalancerName}/backendAddressPools/{backendAddressPoolName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_frontend_ip_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_frontend_ip_configurations_operations.py new file mode 100644 index 000000000000..9bbeedeffac5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_frontend_ip_configurations_operations.py @@ -0,0 +1,184 @@ +# 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 LoadBalancerFrontendIPConfigurationsOperations(object): + """LoadBalancerFrontendIPConfigurationsOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerFrontendIPConfigurationListResult"] + """Gets all the load balancer frontend IP configurations. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerFrontendIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerFrontendIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerFrontendIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerFrontendIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/frontendIPConfigurations'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + frontend_ip_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FrontendIPConfiguration" + """Gets load balancer frontend IP configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param frontend_ip_configuration_name: The name of the frontend IP configuration. + :type frontend_ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FrontendIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.FrontendIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FrontendIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'frontendIPConfigurationName': self._serialize.url("frontend_ip_configuration_name", frontend_ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('FrontendIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/frontendIPConfigurations/{frontendIPConfigurationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_load_balancing_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_load_balancing_rules_operations.py new file mode 100644 index 000000000000..58cd2375be5e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_load_balancing_rules_operations.py @@ -0,0 +1,184 @@ +# 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 LoadBalancerLoadBalancingRulesOperations(object): + """LoadBalancerLoadBalancingRulesOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerLoadBalancingRuleListResult"] + """Gets all the load balancing rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerLoadBalancingRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerLoadBalancingRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerLoadBalancingRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerLoadBalancingRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/loadBalancingRules'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + load_balancing_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.LoadBalancingRule" + """Gets the specified load balancer load balancing rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param load_balancing_rule_name: The name of the load balancing rule. + :type load_balancing_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancingRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancingRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancingRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'loadBalancingRuleName': self._serialize.url("load_balancing_rule_name", load_balancing_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LoadBalancingRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/loadBalancingRules/{loadBalancingRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_network_interfaces_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_network_interfaces_operations.py new file mode 100644 index 000000000000..56c62c144e6e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_network_interfaces_operations.py @@ -0,0 +1,121 @@ +# 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 LoadBalancerNetworkInterfacesOperations(object): + """LoadBalancerNetworkInterfacesOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets associated load balancer network interfaces. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/networkInterfaces'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_outbound_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_outbound_rules_operations.py new file mode 100644 index 000000000000..aaef91cc22fd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_outbound_rules_operations.py @@ -0,0 +1,184 @@ +# 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 LoadBalancerOutboundRulesOperations(object): + """LoadBalancerOutboundRulesOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerOutboundRuleListResult"] + """Gets all the outbound rules in a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerOutboundRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerOutboundRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerOutboundRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerOutboundRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/outboundRules'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + outbound_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.OutboundRule" + """Gets the specified load balancer outbound rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param outbound_rule_name: The name of the outbound rule. + :type outbound_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: OutboundRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.OutboundRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'outboundRuleName': self._serialize.url("outbound_rule_name", outbound_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('OutboundRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/outboundRules/{outboundRuleName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_probes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_probes_operations.py new file mode 100644 index 000000000000..17097e71eef3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancer_probes_operations.py @@ -0,0 +1,184 @@ +# 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 LoadBalancerProbesOperations(object): + """LoadBalancerProbesOperations 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.network.v2020_08_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_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerProbeListResult"] + """Gets all the load balancer probes. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either LoadBalancerProbeListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerProbeListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerProbeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerProbeListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + probe_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Probe" + """Gets load balancer probe. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param probe_name: The name of the probe. + :type probe_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Probe, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Probe + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Probe"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'probeName': self._serialize.url("probe_name", probe_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('Probe', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancers_operations.py new file mode 100644 index 000000000000..423c20420363 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_load_balancers_operations.py @@ -0,0 +1,557 @@ +# 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 LoadBalancersOperations(object): + """LoadBalancersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + load_balancer_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-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_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, + load_balancer_name=load_balancer_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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_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.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.LoadBalancer" + """Gets the specified load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancer, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + parameters, # type: "_models.LoadBalancer" + **kwargs # type: Any + ): + # type: (...) -> "_models.LoadBalancer" + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'LoadBalancer') + 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('LoadBalancer', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + parameters, # type: "_models.LoadBalancer" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.LoadBalancer"] + """Creates or updates a load balancer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param parameters: Parameters supplied to the create or update load balancer operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 LoadBalancer or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.LoadBalancer] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + lro_delay = kwargs.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, + load_balancer_name=load_balancer_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('LoadBalancer', 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'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_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': 'azure-async-operation'}, 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.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + load_balancer_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.LoadBalancer" + """Updates a load balancer tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param load_balancer_name: The name of the load balancer. + :type load_balancer_name: str + :param parameters: Parameters supplied to update load balancer tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LoadBalancer, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LoadBalancer + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancer"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'loadBalancerName': self._serialize.url("load_balancer_name", load_balancer_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('LoadBalancer', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerListResult"] + """Gets all the load balancers 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 LoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('LoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/loadBalancers'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LoadBalancerListResult"] + """Gets all the load balancers in a 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 LoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/loadBalancers'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_local_network_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_local_network_gateways_operations.py new file mode 100644 index 000000000000..2016b93555f8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_local_network_gateways_operations.py @@ -0,0 +1,485 @@ +# 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 LocalNetworkGatewaysOperations(object): + """LocalNetworkGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + local_network_gateway_name, # type: str + parameters, # type: "_models.LocalNetworkGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.LocalNetworkGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'LocalNetworkGateway') + 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('LocalNetworkGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + local_network_gateway_name, # type: str + parameters, # type: "_models.LocalNetworkGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.LocalNetworkGateway"] + """Creates or updates a local network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :param parameters: Parameters supplied to the create or update local network gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 LocalNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + lro_delay = kwargs.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, + local_network_gateway_name=local_network_gateway_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('LocalNetworkGateway', 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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + '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': 'azure-async-operation'}, 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.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + local_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.LocalNetworkGateway" + """Gets the specified local network gateway in a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LocalNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + local_network_gateway_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-08-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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + local_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified local network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_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, + local_network_gateway_name=local_network_gateway_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'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + '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.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + local_network_gateway_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.LocalNetworkGateway" + """Updates a local network gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param local_network_gateway_name: The name of the local network gateway. + :type local_network_gateway_name: str + :param parameters: Parameters supplied to update local network gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: LocalNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.LocalNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'localNetworkGatewayName': self._serialize.url("local_network_gateway_name", local_network_gateway_name, 'str', min_length=1), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('LocalNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/localNetworkGateways/{localNetworkGatewayName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.LocalNetworkGatewayListResult"] + """Gets all the local network gateways in a 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 LocalNetworkGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.LocalNetworkGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocalNetworkGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('LocalNetworkGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/localNetworkGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_gateways_operations.py new file mode 100644 index 000000000000..f35cca8facbf --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_gateways_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 NatGatewaysOperations(object): + """NatGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + nat_gateway_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-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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.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/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + nat_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified nat gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_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, + nat_gateway_name=nat_gateway_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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_gateway_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.Network/natGateways/{natGatewayName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + nat_gateway_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NatGateway" + """Gets the specified nat gateway in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NatGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + nat_gateway_name, # type: str + parameters, # type: "_models.NatGateway" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.NatGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NatGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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(parameters, 'NatGateway') + 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('NatGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + nat_gateway_name, # type: str + parameters, # type: "_models.NatGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NatGateway"] + """Creates or updates a nat gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param parameters: Parameters supplied to the create or update nat gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NatGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NatGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + lro_delay = kwargs.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, + nat_gateway_name=nat_gateway_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('NatGateway', 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'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_gateway_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': 'azure-async-operation'}, 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.Network/natGateways/{natGatewayName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + nat_gateway_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NatGateway" + """Updates nat gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param nat_gateway_name: The name of the nat gateway. + :type nat_gateway_name: str + :param parameters: Parameters supplied to update nat gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NatGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NatGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'natGatewayName': self._serialize.url("nat_gateway_name", nat_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(parameters, 'TagsObject') + 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('NatGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/natGateways/{natGatewayName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NatGatewayListResult"] + """Gets all the Nat Gateways 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 NatGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NatGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NatGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/natGateways'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NatGatewayListResult"] + """Gets all nat gateways in a 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 NatGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NatGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NatGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NatGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/natGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_rules_operations.py new file mode 100644 index 000000000000..5d59993ceb36 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_nat_rules_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 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 NatRulesOperations(object): + """NatRulesOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + gateway_name, # type: str + nat_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnGatewayNatRule" + """Retrieves the details of a nat ruleGet. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnGatewayNatRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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('VpnGatewayNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + nat_rule_name, # type: str + nat_rule_parameters, # type: "_models.VpnGatewayNatRule" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnGatewayNatRule" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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(nat_rule_parameters, 'VpnGatewayNatRule') + 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('VpnGatewayNatRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnGatewayNatRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + gateway_name, # type: str + nat_rule_name, # type: str + nat_rule_parameters, # type: "_models.VpnGatewayNatRule" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnGatewayNatRule"] + """Creates a nat rule to a scalable vpn gateway if it doesn't exist else updates the existing nat + rules. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_name: str + :param nat_rule_parameters: Parameters supplied to create or Update a Nat Rule. + :type nat_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGatewayNatRule or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGatewayNatRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGatewayNatRule"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + nat_rule_name=nat_rule_name, + nat_rule_parameters=nat_rule_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('VpnGatewayNatRule', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + nat_rule_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + gateway_name, # type: str + nat_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a nat rule. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param nat_rule_name: The name of the nat rule. + :type nat_rule_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, + gateway_name=gateway_name, + nat_rule_name=nat_rule_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'natRuleName': self._serialize.url("nat_rule_name", nat_rule_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.Network/vpnGateways/{gatewayName}/natRules/{natRuleName}'} # type: ignore + + def list_by_vpn_gateway( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnGatewayNatRulesResult"] + """Retrieves all nat rules for a particular virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnGatewayNatRulesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewayNatRulesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewayNatRulesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_gateway.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('ListVpnGatewayNatRulesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_vpn_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/natRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_ip_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_ip_configurations_operations.py new file mode 100644 index 000000000000..0203a793e6d2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_ip_configurations_operations.py @@ -0,0 +1,184 @@ +# 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 NetworkInterfaceIPConfigurationsOperations(object): + """NetworkInterfaceIPConfigurationsOperations 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.network.v2020_08_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_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceIPConfigurationListResult"] + """Get all ip configurations in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/ipConfigurations'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterfaceIPConfiguration" + """Gets the specified network interface ip configuration. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the ip configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/ipConfigurations/{ipConfigurationName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_load_balancers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_load_balancers_operations.py new file mode 100644 index 000000000000..86a83f560bcd --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_load_balancers_operations.py @@ -0,0 +1,121 @@ +# 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 NetworkInterfaceLoadBalancersOperations(object): + """NetworkInterfaceLoadBalancersOperations 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.network.v2020_08_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_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceLoadBalancerListResult"] + """List all load balancers in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceLoadBalancerListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceLoadBalancerListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceLoadBalancerListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceLoadBalancerListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/loadBalancers'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_tap_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_tap_configurations_operations.py new file mode 100644 index 000000000000..b4ba4def11da --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interface_tap_configurations_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 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 NetworkInterfaceTapConfigurationsOperations(object): + """NetworkInterfaceTapConfigurationsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_interface_name, # type: str + tap_configuration_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-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_interface_name, # type: str + tap_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified tap configuration from the NetworkInterface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_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, + network_interface_name=network_interface_name, + tap_configuration_name=tap_configuration_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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_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.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_interface_name, # type: str + tap_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterfaceTapConfiguration" + """Get the specified tap configuration on a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceTapConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceTapConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_interface_name, # type: str + tap_configuration_name, # type: str + tap_configuration_parameters, # type: "_models.NetworkInterfaceTapConfiguration" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterfaceTapConfiguration" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(tap_configuration_parameters, 'NetworkInterfaceTapConfiguration') + 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('NetworkInterfaceTapConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkInterfaceTapConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_interface_name, # type: str + tap_configuration_name, # type: str + tap_configuration_parameters, # type: "_models.NetworkInterfaceTapConfiguration" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NetworkInterfaceTapConfiguration"] + """Creates or updates a Tap configuration in the specified NetworkInterface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param tap_configuration_name: The name of the tap configuration. + :type tap_configuration_name: str + :param tap_configuration_parameters: Parameters supplied to the create or update tap + configuration operation. + :type tap_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkInterfaceTapConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfiguration"] + lro_delay = kwargs.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, + network_interface_name=network_interface_name, + tap_configuration_name=tap_configuration_name, + tap_configuration_parameters=tap_configuration_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('NetworkInterfaceTapConfiguration', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'tapConfigurationName': self._serialize.url("tap_configuration_name", tap_configuration_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': 'azure-async-operation'}, 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.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations/{tapConfigurationName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceTapConfigurationListResult"] + """Get all Tap configurations in a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceTapConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceTapConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceTapConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceTapConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/tapConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interfaces_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interfaces_operations.py new file mode 100644 index 000000000000..8c7da850dcf5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_interfaces_operations.py @@ -0,0 +1,1410 @@ +# 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 NetworkInterfacesOperations(object): + """NetworkInterfacesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_interface_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-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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, + network_interface_name=network_interface_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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_interface_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterface" + """Gets information about the specified network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_interface_name, # type: str + parameters, # type: "_models.NetworkInterface" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterface" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkInterface') + 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('NetworkInterface', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_interface_name, # type: str + parameters, # type: "_models.NetworkInterface" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NetworkInterface"] + """Creates or updates a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param parameters: Parameters supplied to the create or update network interface operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkInterface or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkInterface] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + lro_delay = kwargs.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, + network_interface_name=network_interface_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('NetworkInterface', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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': 'azure-async-operation'}, 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.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_interface_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterface" + """Updates a network interface tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param parameters: Parameters supplied to update network interface tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets all network interfaces 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 NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkInterfaces'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets all network interfaces in a 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 NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkInterfaces'} # type: ignore + + def _get_effective_route_table_initial( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.EffectiveRouteListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.EffectiveRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_effective_route_table_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('EffectiveRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_effective_route_table_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveRouteTable'} # type: ignore + + def begin_get_effective_route_table( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.EffectiveRouteListResult"] + """Gets all route tables applied to a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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 EffectiveRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.EffectiveRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.EffectiveRouteListResult"] + lro_delay = kwargs.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._get_effective_route_table_initial( + resource_group_name=resource_group_name, + network_interface_name=network_interface_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('EffectiveRouteListResult', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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_get_effective_route_table.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveRouteTable'} # type: ignore + + def _list_effective_network_security_groups_initial( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.EffectiveNetworkSecurityGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.EffectiveNetworkSecurityGroupListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_effective_network_security_groups_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('EffectiveNetworkSecurityGroupListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_effective_network_security_groups_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveNetworkSecurityGroups'} # type: ignore + + def begin_list_effective_network_security_groups( + self, + resource_group_name, # type: str + network_interface_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.EffectiveNetworkSecurityGroupListResult"] + """Gets all network security groups applied to a network interface. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_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 EffectiveNetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.EffectiveNetworkSecurityGroupListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.EffectiveNetworkSecurityGroupListResult"] + lro_delay = kwargs.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_effective_network_security_groups_initial( + resource_group_name=resource_group_name, + network_interface_name=network_interface_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('EffectiveNetworkSecurityGroupListResult', 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'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_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_list_effective_network_security_groups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkInterfaces/{networkInterfaceName}/effectiveNetworkSecurityGroups'} # type: ignore + + def list_virtual_machine_scale_set_vm_network_interfaces( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets information about all network interfaces in a virtual machine in a virtual machine scale + set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_vm_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_virtual_machine_scale_set_vm_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces'} # type: ignore + + def list_virtual_machine_scale_set_network_interfaces( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets all network interfaces in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_virtual_machine_scale_set_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/networkInterfaces'} # type: ignore + + def get_virtual_machine_scale_set_network_interface( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + network_interface_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterface" + """Get the specified network interface in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_network_interface.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_network_interface.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}'} # type: ignore + + def list_virtual_machine_scale_set_ip_configurations( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + network_interface_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceIPConfigurationListResult"] + """Get the specified network interface ip configuration in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :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 NetworkInterfaceIPConfigurationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfigurationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfigurationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_ip_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceIPConfigurationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_virtual_machine_scale_set_ip_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipConfigurations'} # type: ignore + + def get_virtual_machine_scale_set_ip_configuration( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterfaceIPConfiguration" + """Get the specified network interface ip configuration in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the ip configuration. + :type ip_configuration_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterfaceIPConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceIPConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceIPConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_ip_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterfaceIPConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_ip_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipConfigurations/{ipConfigurationName}'} # type: ignore + + def list_cloud_service_role_instance_network_interfaces( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + role_instance_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets information about all network interfaces in a role instance in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_role_instance_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_cloud_service_role_instance_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces'} # type: ignore + + def list_cloud_service_network_interfaces( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkInterfaceListResult"] + """Gets all network interfaces in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkInterfaceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkInterfaceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterfaceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_network_interfaces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkInterfaceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_cloud_service_network_interfaces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/networkInterfaces'} # type: ignore + + def get_cloud_service_network_interface( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + role_instance_name, # type: str + network_interface_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkInterface" + """Get the specified network interface in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkInterface, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkInterface + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkInterface"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_cloud_service_network_interface.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkInterface', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_cloud_service_network_interface.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_management_client_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_management_client_operations.py new file mode 100644 index 000000000000..232d93f3d28c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_management_client_operations.py @@ -0,0 +1,933 @@ +# 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 NetworkManagementClientOperationsMixin(object): + + def _put_bastion_shareable_link_initial( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + bsl_request, # type: "_models.BastionShareableLinkListRequest" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.BastionShareableLinkListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BastionShareableLinkListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._put_bastion_shareable_link_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _put_bastion_shareable_link_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/createShareableLinks'} # type: ignore + + def begin_put_bastion_shareable_link( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + bsl_request, # type: "_models.BastionShareableLinkListRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.BastionShareableLinkListResult"]] + """Creates a Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BastionShareableLinkListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.put_bastion_shareable_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(bsl_request, 'BastionShareableLinkListRequest') + 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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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 + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + lro_delay = kwargs.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._put_bastion_shareable_link_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_name, + bsl_request=bsl_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): + 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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_put_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/createShareableLinks'} # type: ignore + + def _delete_bastion_shareable_link_initial( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + bsl_request, # type: "_models.BastionShareableLinkListRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._delete_bastion_shareable_link_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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(bsl_request, 'BastionShareableLinkListRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_bastion_shareable_link_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/deleteShareableLinks'} # type: ignore + + def begin_delete_bastion_shareable_link( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + bsl_request, # type: "_models.BastionShareableLinkListRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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_bastion_shareable_link_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_name, + bsl_request=bsl_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/deleteShareableLinks'} # type: ignore + + def get_bastion_shareable_link( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + bsl_request, # type: "_models.BastionShareableLinkListRequest" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BastionShareableLinkListResult"] + """Return the Bastion Shareable Links for all the VMs specified in the request. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param bsl_request: Post request for all the Bastion Shareable Link endpoints. + :type bsl_request: ~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BastionShareableLinkListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionShareableLinkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionShareableLinkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.get_bastion_shareable_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(bsl_request, 'BastionShareableLinkListRequest') + 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(bsl_request, 'BastionShareableLinkListRequest') + 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('BastionShareableLinkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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 + ) + get_bastion_shareable_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getShareableLinks'} # type: ignore + + def _get_active_sessions_initial( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.BastionActiveSessionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BastionActiveSessionListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_active_sessions_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('BastionActiveSessionListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_active_sessions_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getActiveSessions'} # type: ignore + + def begin_get_active_sessions( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.BastionActiveSessionListResult"]] + """Returns the list of currently active sessions on the Bastion. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_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 BastionActiveSessionListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionActiveSessionListResult]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionActiveSessionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct 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_active_sessions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + 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('BastionActiveSessionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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 + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionActiveSessionListResult"] + lro_delay = kwargs.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._get_active_sessions_initial( + resource_group_name=resource_group_name, + bastion_host_name=bastion_host_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'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_host_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_get_active_sessions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/getActiveSessions'} # type: ignore + + def disconnect_active_sessions( + self, + resource_group_name, # type: str + bastion_host_name, # type: str + session_ids, # type: "_models.SessionIds" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BastionSessionDeleteResult"] + """Returns the list of currently active sessions on the Bastion. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param bastion_host_name: The name of the Bastion Host. + :type bastion_host_name: str + :param session_ids: The list of sessionids to disconnect. + :type session_ids: ~azure.mgmt.network.v2020_08_01.models.SessionIds + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BastionSessionDeleteResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.BastionSessionDeleteResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BastionSessionDeleteResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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.disconnect_active_sessions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'bastionHostName': self._serialize.url("bastion_host_name", bastion_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') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(session_ids, 'SessionIds') + 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(session_ids, 'SessionIds') + 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('BastionSessionDeleteResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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 + ) + disconnect_active_sessions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/bastionHosts/{bastionHostName}/disconnectActiveSessions'} # type: ignore + + def check_dns_name_availability( + self, + location, # type: str + domain_name_label, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DnsNameAvailabilityResult" + """Checks whether a domain name in the cloudapp.azure.com zone is available for use. + + :param location: The location of the domain name. + :type location: str + :param domain_name_label: The domain name to be verified. It must conform to the following + regular expression: ^[a-z][a-z0-9-]{1,61}[a-z0-9]$. + :type domain_name_label: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DnsNameAvailabilityResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.DnsNameAvailabilityResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DnsNameAvailabilityResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.check_dns_name_availability.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['domainNameLabel'] = self._serialize.query("domain_name_label", domain_name_label, '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('DnsNameAvailabilityResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_dns_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/CheckDnsNameAvailability'} # type: ignore + + def supported_security_providers( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualWanSecurityProviders" + """Gives the supported security providers for the virtual wan. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN for which supported security providers are + needed. + :type virtual_wan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWanSecurityProviders, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWanSecurityProviders + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWanSecurityProviders"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.supported_security_providers.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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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('VirtualWanSecurityProviders', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + supported_security_providers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/supportedSecurityProviders'} # type: ignore + + def _generatevirtualwanvpnserverconfigurationvpnprofile_initial( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + vpn_client_params, # type: "_models.VirtualWanVpnProfileParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnProfileResponse"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnProfileResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generatevirtualwanvpnserverconfigurationvpnprofile_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(vpn_client_params, 'VirtualWanVpnProfileParameters') + 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('VpnProfileResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generatevirtualwanvpnserverconfigurationvpnprofile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/GenerateVpnProfile'} # type: ignore + + def begin_generatevirtualwanvpnserverconfigurationvpnprofile( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + vpn_client_params, # type: "_models.VirtualWanVpnProfileParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnProfileResponse"] + """Generates a unique VPN profile for P2S clients for VirtualWan and associated + VpnServerConfiguration combination in the specified resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is + needed. + :type virtual_wan_name: str + :param vpn_client_params: Parameters supplied to the generate VirtualWan VPN profile generation + operation. + :type vpn_client_params: ~azure.mgmt.network.v2020_08_01.models.VirtualWanVpnProfileParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnProfileResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnProfileResponse"] + lro_delay = kwargs.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._generatevirtualwanvpnserverconfigurationvpnprofile_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_name, + vpn_client_params=vpn_client_params, + 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('VpnProfileResponse', 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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_generatevirtualwanvpnserverconfigurationvpnprofile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/GenerateVpnProfile'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_profiles_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_profiles_operations.py new file mode 100644 index 000000000000..1a189e3e1bfb --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_profiles_operations.py @@ -0,0 +1,498 @@ +# 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 NetworkProfilesOperations(object): + """NetworkProfilesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_profile_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-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_profile_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified network profile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the NetworkProfile. + :type network_profile_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, + network_profile_name=network_profile_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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_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.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_profile_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkProfile" + """Gets the specified network profile in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the public IP prefix. + :type network_profile_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + network_profile_name, # type: str + parameters, # type: "_models.NetworkProfile" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkProfile" + """Creates or updates a network profile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the network profile. + :type network_profile_name: str + :param parameters: Parameters supplied to the create or update network profile operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkProfile') + 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('NetworkProfile', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_profile_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkProfile" + """Updates network profile tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_profile_name: The name of the network profile. + :type network_profile_name: str + :param parameters: Parameters supplied to update network profile tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkProfile, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkProfile + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfile"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkProfileName': self._serialize.url("network_profile_name", network_profile_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkProfile', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkProfiles/{networkProfileName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkProfileListResult"] + """Gets all the network profiles 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 NetworkProfileListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkProfileListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfileListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkProfileListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkProfiles'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkProfileListResult"] + """Gets all network profiles in a 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 NetworkProfileListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkProfileListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkProfileListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkProfileListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkProfiles'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_security_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_security_groups_operations.py new file mode 100644 index 000000000000..469802b50917 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_security_groups_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 NetworkSecurityGroupsOperations(object): + """NetworkSecurityGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_security_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-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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, + network_security_group_name=network_security_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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_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.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkSecurityGroup" + """Gets the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + parameters, # type: "_models.NetworkSecurityGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkSecurityGroup" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkSecurityGroup') + 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('NetworkSecurityGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + parameters, # type: "_models.NetworkSecurityGroup" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NetworkSecurityGroup"] + """Creates or updates a network security group in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param parameters: Parameters supplied to the create or update network security group + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkSecurityGroup or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + lro_delay = kwargs.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, + network_security_group_name=network_security_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('NetworkSecurityGroup', 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_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': 'azure-async-operation'}, 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.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkSecurityGroup" + """Updates a network security group tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param parameters: Parameters supplied to update network security group tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkSecurityGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('NetworkSecurityGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkSecurityGroupListResult"] + """Gets all network security groups 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 NetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkSecurityGroups'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkSecurityGroupListResult"] + """Gets all network security groups in a 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 NetworkSecurityGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkSecurityGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkSecurityGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkSecurityGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkSecurityGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_virtual_appliances_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_virtual_appliances_operations.py new file mode 100644 index 000000000000..fbe7602cf6e2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_virtual_appliances_operations.py @@ -0,0 +1,557 @@ +# 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 NetworkVirtualAppliancesOperations(object): + """NetworkVirtualAppliancesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_virtual_appliance_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-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_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, + network_virtual_appliance_name=network_virtual_appliance_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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkVirtualAppliance" + """Gets the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualAppliance, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkVirtualAppliance" + """Updates a Network Virtual Appliance. + + :param resource_group_name: The resource group name of Network Virtual Appliance. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance being updated. + :type network_virtual_appliance_name: str + :param parameters: Parameters supplied to Update Network Virtual Appliance Tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualAppliance, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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, 'TagsObject') + 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('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + parameters, # type: "_models.NetworkVirtualAppliance" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkVirtualAppliance" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkVirtualAppliance') + 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('NetworkVirtualAppliance', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkVirtualAppliance', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + parameters, # type: "_models.NetworkVirtualAppliance" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NetworkVirtualAppliance"] + """Creates or updates the specified Network Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkVirtualAppliance or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualAppliance] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualAppliance"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_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('NetworkVirtualAppliance', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkVirtualApplianceListResult"] + """Lists all Network Virtual Appliances in a 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 NetworkVirtualApplianceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/networkVirtualAppliances'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkVirtualApplianceListResult"] + """Gets all Network Virtual Appliances 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 NetworkVirtualApplianceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/networkVirtualAppliances'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_watchers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_watchers_operations.py new file mode 100644 index 000000000000..acb2d48c9ab9 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_network_watchers_operations.py @@ -0,0 +1,2017 @@ +# 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 NetworkWatchersOperations(object): + """NetworkWatchersOperations 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.network.v2020_08_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, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.NetworkWatcher" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkWatcher" + """Creates or updates a network watcher in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the network watcher resource. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkWatcher') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkWatcher" + """Gets the specified network watcher by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + network_watcher_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified network watcher resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_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, + network_watcher_name=network_watcher_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkWatcher" + """Updates a network watcher tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters supplied to update network watcher tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkWatcher, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkWatcher + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcher"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NetworkWatcher', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkWatcherListResult"] + """Gets all network watchers by 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 NetworkWatcherListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkWatcherListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcherListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkWatcherListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkWatcherListResult"] + """Gets all network watchers by subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkWatcherListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkWatcherListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkWatcherListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('NetworkWatcherListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.ErrorResponse, response) + map_error(status_code=response.status_code, 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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkWatchers'} # type: ignore + + def get_topology( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.TopologyParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.Topology" + """Gets the current network topology by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the representation of topology. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TopologyParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Topology, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Topology + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Topology"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.get_topology.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TopologyParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Topology', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_topology.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/topology'} # type: ignore + + def _verify_ip_flow_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.VerificationIPFlowParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.VerificationIPFlowResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VerificationIPFlowResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._verify_ip_flow_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VerificationIPFlowParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VerificationIPFlowResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('VerificationIPFlowResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _verify_ip_flow_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/ipFlowVerify'} # type: ignore + + def begin_verify_ip_flow( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.VerificationIPFlowParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VerificationIPFlowResult"] + """Verify IP flow from the specified VM to a location given the currently configured NSG rules. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the IP flow to be verified. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VerificationIPFlowParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VerificationIPFlowResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VerificationIPFlowResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VerificationIPFlowResult"] + lro_delay = kwargs.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._verify_ip_flow_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('VerificationIPFlowResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_verify_ip_flow.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/ipFlowVerify'} # type: ignore + + def _get_next_hop_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.NextHopParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.NextHopResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NextHopResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_next_hop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NextHopParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NextHopResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NextHopResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_next_hop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/nextHop'} # type: ignore + + def begin_get_next_hop( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.NextHopParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NextHopResult"] + """Gets the next hop from the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the source and destination endpoint. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NextHopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NextHopResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NextHopResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NextHopResult"] + lro_delay = kwargs.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._get_next_hop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('NextHopResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_next_hop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/nextHop'} # type: ignore + + def _get_vm_security_rules_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.SecurityGroupViewParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityGroupViewResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityGroupViewResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_vm_security_rules_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'SecurityGroupViewParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SecurityGroupViewResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SecurityGroupViewResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vm_security_rules_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/securityGroupView'} # type: ignore + + def begin_get_vm_security_rules( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.SecurityGroupViewParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SecurityGroupViewResult"] + """Gets the configured and effective security group rules on the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters that define the VM to check security groups for. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityGroupViewParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityGroupViewResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityGroupViewResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityGroupViewResult"] + lro_delay = kwargs.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._get_vm_security_rules_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('SecurityGroupViewResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_vm_security_rules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/securityGroupView'} # type: ignore + + def _get_troubleshooting_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.TroubleshootingParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.TroubleshootingResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_troubleshooting_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TroubleshootingParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_troubleshooting_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/troubleshoot'} # type: ignore + + def begin_get_troubleshooting( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.TroubleshootingParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.TroubleshootingResult"] + """Initiate troubleshooting on a specified resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the resource to troubleshoot. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TroubleshootingParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 TroubleshootingResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.TroubleshootingResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + lro_delay = kwargs.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._get_troubleshooting_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('TroubleshootingResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_troubleshooting.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/troubleshoot'} # type: ignore + + def _get_troubleshooting_result_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.QueryTroubleshootingParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.TroubleshootingResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_troubleshooting_result_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'QueryTroubleshootingParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('TroubleshootingResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_troubleshooting_result_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryTroubleshootResult'} # type: ignore + + def begin_get_troubleshooting_result( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.QueryTroubleshootingParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.TroubleshootingResult"] + """Get the last completed troubleshooting result on a specified resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the resource to query the troubleshooting result. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.QueryTroubleshootingParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 TroubleshootingResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.TroubleshootingResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TroubleshootingResult"] + lro_delay = kwargs.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._get_troubleshooting_result_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('TroubleshootingResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_troubleshooting_result.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryTroubleshootResult'} # type: ignore + + def _set_flow_log_configuration_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.FlowLogInformation" + **kwargs # type: Any + ): + # type: (...) -> "_models.FlowLogInformation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_flow_log_configuration_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLogInformation') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_flow_log_configuration_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/configureFlowLog'} # type: ignore + + def begin_set_flow_log_configuration( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.FlowLogInformation" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FlowLogInformation"] + """Configures flow log and traffic analytics (optional) on a specified resource. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define the configuration of flow log. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLogInformation + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLogInformation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLogInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + lro_delay = kwargs.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._set_flow_log_configuration_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('FlowLogInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_set_flow_log_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/configureFlowLog'} # type: ignore + + def _get_flow_log_status_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.FlowLogStatusParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.FlowLogInformation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_flow_log_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'FlowLogStatusParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('FlowLogInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_flow_log_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryFlowLogStatus'} # type: ignore + + def begin_get_flow_log_status( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.FlowLogStatusParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FlowLogInformation"] + """Queries status of flow log and traffic analytics (optional) on a specified resource. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that define a resource to query flow log and traffic analytics + (optional) status. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.FlowLogStatusParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 FlowLogInformation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.FlowLogInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FlowLogInformation"] + lro_delay = kwargs.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._get_flow_log_status_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('FlowLogInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_flow_log_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/queryFlowLogStatus'} # type: ignore + + def _check_connectivity_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.ConnectivityParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectivityInformation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectivityInformation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_connectivity_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ConnectivityParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ConnectivityInformation', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ConnectivityInformation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_connectivity_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectivityCheck'} # type: ignore + + def begin_check_connectivity( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.ConnectivityParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ConnectivityInformation"] + """Verifies the possibility of establishing a direct TCP connection from a virtual machine to a + given endpoint including another VM or an arbitrary remote server. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that determine how the connectivity check will be performed. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectivityParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectivityInformation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectivityInformation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectivityInformation"] + lro_delay = kwargs.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._check_connectivity_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('ConnectivityInformation', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_check_connectivity.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/connectivityCheck'} # type: ignore + + def _get_azure_reachability_report_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.AzureReachabilityReportParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureReachabilityReport" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureReachabilityReport"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_azure_reachability_report_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AzureReachabilityReportParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AzureReachabilityReport', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AzureReachabilityReport', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_azure_reachability_report_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/azureReachabilityReport'} # type: ignore + + def begin_get_azure_reachability_report( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.AzureReachabilityReportParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AzureReachabilityReport"] + """NOTE: This feature is currently in preview and still being tested for stability. Gets the + relative latency score for internet service providers from a specified location to Azure + regions. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that determine Azure reachability report configuration. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReportParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AzureReachabilityReport or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.AzureReachabilityReport] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureReachabilityReport"] + lro_delay = kwargs.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._get_azure_reachability_report_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('AzureReachabilityReport', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_azure_reachability_report.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/azureReachabilityReport'} # type: ignore + + def _list_available_providers_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.AvailableProvidersListParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.AvailableProvidersList" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableProvidersList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._list_available_providers_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'AvailableProvidersListParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AvailableProvidersList', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AvailableProvidersList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_available_providers_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/availableProvidersList'} # type: ignore + + def begin_list_available_providers( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.AvailableProvidersListParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AvailableProvidersList"] + """NOTE: This feature is currently in preview and still being tested for stability. Lists all + available internet service providers for a specified Azure region. + + :param resource_group_name: The name of the network watcher resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher resource. + :type network_watcher_name: str + :param parameters: Parameters that scope the list of available providers. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.AvailableProvidersListParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 AvailableProvidersList or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.AvailableProvidersList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AvailableProvidersList"] + lro_delay = kwargs.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_available_providers_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('AvailableProvidersList', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_list_available_providers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/availableProvidersList'} # type: ignore + + def _get_network_configuration_diagnostic_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.NetworkConfigurationDiagnosticParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkConfigurationDiagnosticResponse" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkConfigurationDiagnosticResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_network_configuration_diagnostic_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'NetworkConfigurationDiagnosticParameters') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NetworkConfigurationDiagnosticResponse', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NetworkConfigurationDiagnosticResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_network_configuration_diagnostic_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/networkConfigurationDiagnostic'} # type: ignore + + def begin_get_network_configuration_diagnostic( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + parameters, # type: "_models.NetworkConfigurationDiagnosticParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NetworkConfigurationDiagnosticResponse"] + """Gets Network Configuration Diagnostic data to help customers understand and debug network + behavior. It provides detailed information on what security rules were applied to a specified + traffic flow and the result of evaluating these rules. Customers must provide details of a flow + like source, destination, protocol, etc. The API returns whether traffic was allowed or denied, + the rules evaluated for the specified flow and the evaluation results. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param parameters: Parameters to get network configuration diagnostic. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 NetworkConfigurationDiagnosticResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.NetworkConfigurationDiagnosticResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkConfigurationDiagnosticResponse"] + lro_delay = kwargs.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._get_network_configuration_diagnostic_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_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('NetworkConfigurationDiagnosticResponse', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_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_get_network_configuration_diagnostic.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/networkConfigurationDiagnostic'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_operations.py new file mode 100644 index 000000000000..1478c46d490b --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_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.network.v2020_08_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 Network 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.network.v2020_08_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-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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.Network/operations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_p2_svpn_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_p2_svpn_gateways_operations.py new file mode 100644 index 000000000000..cec4a3997fd2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_p2_svpn_gateways_operations.py @@ -0,0 +1,1231 @@ +# 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 P2SVpnGatewaysOperations(object): + """P2SVpnGatewaysOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.P2SVpnGateway" + """Retrieves the details of a virtual wan p2s vpn gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: P2SVpnGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + p2_s_vpn_gateway_parameters, # type: "_models.P2SVpnGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.P2SVpnGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(p2_s_vpn_gateway_parameters, 'P2SVpnGateway') + 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('P2SVpnGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + gateway_name, # type: str + p2_s_vpn_gateway_parameters, # type: "_models.P2SVpnGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.P2SVpnGateway"] + """Creates a virtual wan p2s vpn gateway if it doesn't exist else updates the existing gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param p2_s_vpn_gateway_parameters: Parameters supplied to create or Update a virtual wan p2s + vpn gateway. + :type p2_s_vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + p2_s_vpn_gateway_parameters=p2_s_vpn_gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + p2_s_vpn_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.P2SVpnGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(p2_s_vpn_gateway_parameters, 'TagsObject') + 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('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + gateway_name, # type: str + p2_s_vpn_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.P2SVpnGateway"] + """Updates virtual wan p2s vpn gateway tags. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param p2_s_vpn_gateway_parameters: Parameters supplied to update a virtual wan p2s vpn gateway + tags. + :type p2_s_vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + p2_s_vpn_gateway_parameters=p2_s_vpn_gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + gateway_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a virtual wan p2s vpn gateway. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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, + gateway_name=gateway_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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.Network/p2svpnGateways/{gatewayName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListP2SVpnGatewaysResult"] + """Lists all the P2SVpnGateways in a resource group. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :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 ListP2SVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListP2SVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListP2SVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListP2SVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/p2svpnGateways'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListP2SVpnGatewaysResult"] + """Lists all the P2SVpnGateways 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 ListP2SVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListP2SVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListP2SVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListP2SVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/p2svpnGateways'} # type: ignore + + def _reset_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.P2SVpnGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/reset'} # type: ignore + + def begin_reset( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.P2SVpnGateway"] + """Resets the primary of the p2s vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the P2SVpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/reset'} # type: ignore + + def _generate_vpn_profile_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters, # type: "_models.P2SVpnProfileParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnProfileResponse"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnProfileResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generate_vpn_profile_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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(parameters, 'P2SVpnProfileParameters') + 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('VpnProfileResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generate_vpn_profile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/generatevpnprofile'} # type: ignore + + def begin_generate_vpn_profile( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters, # type: "_models.P2SVpnProfileParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnProfileResponse"] + """Generates VPN profile for P2S client of the P2SVpnGateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_name: str + :param parameters: Parameters supplied to the generate P2SVpnGateway VPN client package + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.P2SVpnProfileParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnProfileResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnProfileResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnProfileResponse"] + lro_delay = kwargs.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._generate_vpn_profile_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('VpnProfileResponse', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_generate_vpn_profile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/generatevpnprofile'} # type: ignore + + def _get_p2_s_vpn_connection_health_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.P2SVpnGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_p2_s_vpn_connection_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('P2SVpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_p2_s_vpn_connection_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealth'} # type: ignore + + def begin_get_p2_s_vpn_connection_health( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.P2SVpnGateway"] + """Gets the connection health of P2S clients of the virtual wan P2SVpnGateway in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_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 P2SVpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnGateway"] + lro_delay = kwargs.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._get_p2_s_vpn_connection_health_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('P2SVpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_get_p2_s_vpn_connection_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealth'} # type: ignore + + def _get_p2_s_vpn_connection_health_detailed_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionHealthRequest" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.P2SVpnConnectionHealth"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.P2SVpnConnectionHealth"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_p2_s_vpn_connection_health_detailed_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(request, 'P2SVpnConnectionHealthRequest') + 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('P2SVpnConnectionHealth', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_p2_s_vpn_connection_health_detailed_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealthDetailed'} # type: ignore + + def begin_get_p2_s_vpn_connection_health_detailed( + self, + resource_group_name, # type: str + gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionHealthRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.P2SVpnConnectionHealth"] + """Gets the sas url to get the connection health detail of P2S clients of the virtual wan + P2SVpnGateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the P2SVpnGateway. + :type gateway_name: str + :param request: Request parameters supplied to get p2s vpn connections detailed health. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionHealthRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 P2SVpnConnectionHealth or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionHealth] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.P2SVpnConnectionHealth"] + lro_delay = kwargs.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._get_p2_s_vpn_connection_health_detailed_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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): + deserialized = self._deserialize('P2SVpnConnectionHealth', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_get_p2_s_vpn_connection_health_detailed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{gatewayName}/getP2sVpnConnectionHealthDetailed'} # type: ignore + + def _disconnect_p2_s_vpn_connections_initial( + self, + resource_group_name, # type: str + p2_s_vpn_gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._disconnect_p2_s_vpn_connections_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'), + 'p2sVpnGatewayName': self._serialize.url("p2_s_vpn_gateway_name", p2_s_vpn_gateway_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(request, 'P2SVpnConnectionRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _disconnect_p2_s_vpn_connections_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{p2sVpnGatewayName}/disconnectP2sVpnConnections'} # type: ignore + + def begin_disconnect_p2_s_vpn_connections( + self, + resource_group_name, # type: str + p2_s_vpn_gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Disconnect P2S vpn connections of the virtual wan P2SVpnGateway in the specified resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param p2_s_vpn_gateway_name: The name of the P2S Vpn Gateway. + :type p2_s_vpn_gateway_name: str + :param request: The parameters are supplied to disconnect p2s vpn connections. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._disconnect_p2_s_vpn_connections_initial( + resource_group_name=resource_group_name, + p2_s_vpn_gateway_name=p2_s_vpn_gateway_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'p2sVpnGatewayName': self._serialize.url("p2_s_vpn_gateway_name", p2_s_vpn_gateway_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_disconnect_p2_s_vpn_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/p2svpnGateways/{p2sVpnGatewayName}/disconnectP2sVpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_packet_captures_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_packet_captures_operations.py new file mode 100644 index 000000000000..6587cb36a9c3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_packet_captures_operations.py @@ -0,0 +1,686 @@ +# 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 PacketCapturesOperations(object): + """PacketCapturesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + parameters, # type: "_models.PacketCapture" + **kwargs # type: Any + ): + # type: (...) -> "_models.PacketCaptureResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PacketCapture') + 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PacketCaptureResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + def begin_create( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + parameters, # type: "_models.PacketCapture" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PacketCaptureResult"] + """Create and start a packet capture on the specified VM. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_name: str + :param parameters: Parameters that define the create packet capture operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PacketCapture + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PacketCaptureResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + lro_delay = kwargs.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_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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('PacketCaptureResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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': 'azure-async-operation'}, 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.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PacketCaptureResult" + """Gets a packet capture session by name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PacketCaptureResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PacketCaptureResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + 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) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PacketCaptureResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_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-08-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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, 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.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_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, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}'} # type: ignore + + def _stop_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_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-08-01" + accept = "application/json" + + # Construct URL + url = self._stop_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _stop_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/stop'} # type: ignore + + def begin_stop( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Stops a specified packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the network watcher. + :type network_watcher_name: str + :param packet_capture_name: The name of the packet capture session. + :type packet_capture_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._stop_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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_stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/stop'} # type: ignore + + def _get_status_initial( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PacketCaptureQueryStatusResult" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureQueryStatusResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PacketCaptureQueryStatusResult', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PacketCaptureQueryStatusResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/queryStatus'} # type: ignore + + def begin_get_status( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + packet_capture_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PacketCaptureQueryStatusResult"] + """Query the status of a running packet capture session. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :param packet_capture_name: The name given to the packet capture session. + :type packet_capture_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 PacketCaptureQueryStatusResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PacketCaptureQueryStatusResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureQueryStatusResult"] + lro_delay = kwargs.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._get_status_initial( + resource_group_name=resource_group_name, + network_watcher_name=network_watcher_name, + packet_capture_name=packet_capture_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('PacketCaptureQueryStatusResult', 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'packetCaptureName': self._serialize.url("packet_capture_name", packet_capture_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_get_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkWatchers/{networkWatcherName}/packetCaptures/{packetCaptureName}/queryStatus'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_watcher_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PacketCaptureListResult"] + """Lists all packet capture sessions within the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_watcher_name: The name of the Network Watcher resource. + :type network_watcher_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PacketCaptureListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PacketCaptureListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PacketCaptureListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkWatcherName': self._serialize.url("network_watcher_name", network_watcher_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PacketCaptureListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.ErrorResponse, response) + map_error(status_code=response.status_code, 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.Network/networkWatchers/{networkWatcherName}/packetCaptures'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_peer_express_route_circuit_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_peer_express_route_circuit_connections_operations.py new file mode 100644 index 000000000000..2b34d35d79b2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_peer_express_route_circuit_connections_operations.py @@ -0,0 +1,194 @@ +# 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 PeerExpressRouteCircuitConnectionsOperations(object): + """PeerExpressRouteCircuitConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PeerExpressRouteCircuitConnection" + """Gets the specified Peer Express Route Circuit Connection from the specified express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the express route circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :param connection_name: The name of the peer express route circuit connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PeerExpressRouteCircuitConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerExpressRouteCircuitConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PeerExpressRouteCircuitConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/peerConnections/{connectionName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + circuit_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PeerExpressRouteCircuitConnectionListResult"] + """Gets all global reach peer connections associated with a private peering in an express route + circuit. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param circuit_name: The name of the circuit. + :type circuit_name: str + :param peering_name: The name of the peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PeerExpressRouteCircuitConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PeerExpressRouteCircuitConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerExpressRouteCircuitConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'circuitName': self._serialize.url("circuit_name", circuit_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PeerExpressRouteCircuitConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/expressRouteCircuits/{circuitName}/peerings/{peeringName}/peerConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_dns_zone_groups_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_dns_zone_groups_operations.py new file mode 100644 index 000000000000..15a1f66f5fe8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_dns_zone_groups_operations.py @@ -0,0 +1,442 @@ +# 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 PrivateDnsZoneGroupsOperations(object): + """PrivateDnsZoneGroupsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + private_dns_zone_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-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + private_dns_zone_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified private dns zone group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_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, + private_endpoint_name=private_endpoint_name, + private_dns_zone_group_name=private_dns_zone_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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_group_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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + private_dns_zone_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateDnsZoneGroup" + """Gets the private dns zone group resource by specified private dns zone group name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateDnsZoneGroup, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PrivateDnsZoneGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + private_dns_zone_group_name, # type: str + parameters, # type: "_models.PrivateDnsZoneGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateDnsZoneGroup" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateDnsZoneGroup') + 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('PrivateDnsZoneGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateDnsZoneGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + private_dns_zone_group_name, # type: str + parameters, # type: "_models.PrivateDnsZoneGroup" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateDnsZoneGroup"] + """Creates or updates a private dns zone group in the specified private endpoint. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param private_dns_zone_group_name: The name of the private dns zone group. + :type private_dns_zone_group_name: str + :param parameters: Parameters supplied to the create or update private dns zone group + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateDnsZoneGroup or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroup] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroup"] + lro_delay = kwargs.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, + private_endpoint_name=private_endpoint_name, + private_dns_zone_group_name=private_dns_zone_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('PrivateDnsZoneGroup', 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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'privateDnsZoneGroupName': self._serialize.url("private_dns_zone_group_name", private_dns_zone_group_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': 'azure-async-operation'}, 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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups/{privateDnsZoneGroupName}'} # type: ignore + + def list( + self, + private_endpoint_name, # type: str + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateDnsZoneGroupListResult"] + """Gets all private dns zone groups in a private endpoint. + + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :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 PrivateDnsZoneGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateDnsZoneGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateDnsZoneGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + '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('PrivateDnsZoneGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints/{privateEndpointName}/privateDnsZoneGroups'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_endpoints_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_endpoints_operations.py new file mode 100644 index 000000000000..639a08dc379f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_endpoints_operations.py @@ -0,0 +1,495 @@ +# 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 PrivateEndpointsOperations(object): + """PrivateEndpointsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + private_endpoint_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-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified private endpoint. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_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, + private_endpoint_name=private_endpoint_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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpoint" + """Gets the specified private endpoint by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpoint, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + parameters, # type: "_models.PrivateEndpoint" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpoint" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateEndpoint') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateEndpoint', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + private_endpoint_name, # type: str + parameters, # type: "_models.PrivateEndpoint" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateEndpoint"] + """Creates or updates an private endpoint in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param private_endpoint_name: The name of the private endpoint. + :type private_endpoint_name: str + :param parameters: Parameters supplied to the create or update private endpoint operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateEndpoint or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateEndpoint] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpoint"] + lro_delay = kwargs.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, + private_endpoint_name=private_endpoint_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('PrivateEndpoint', 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'), + 'privateEndpointName': self._serialize.url("private_endpoint_name", private_endpoint_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': 'azure-async-operation'}, 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.Network/privateEndpoints/{privateEndpointName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateEndpointListResult"] + """Gets all private endpoints in a 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 PrivateEndpointListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateEndpointListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints'} # type: ignore + + def list_by_subscription( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateEndpointListResult"] + """Gets all private endpoints 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 PrivateEndpointListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('PrivateEndpointListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateEndpoints'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_link_services_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_link_services_operations.py new file mode 100644 index 000000000000..d757fc4428c7 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_private_link_services_operations.py @@ -0,0 +1,1229 @@ +# 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 PrivateLinkServicesOperations(object): + """PrivateLinkServicesOperations 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.network.v2020_08_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_initial( + self, + resource_group_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 = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/privateLinkServices/{serviceName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified private link service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :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, + 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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_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.Network/privateLinkServices/{serviceName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + service_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateLinkService" + """Gets the specified private link service by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkService, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateLinkService + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + service_name, # type: str + parameters, # type: "_models.PrivateLinkService" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateLinkService" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PrivateLinkService') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PrivateLinkService', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + service_name, # type: str + parameters, # type: "_models.PrivateLinkService" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateLinkService"] + """Creates or updates an private link service in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param parameters: Parameters supplied to the create or update private link service operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateLinkService + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkService or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkService] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkService"] + lro_delay = kwargs.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, + 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('PrivateLinkService', 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'), + 'serviceName': self._serialize.url("service_name", service_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': 'azure-async-operation'}, 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.Network/privateLinkServices/{serviceName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateLinkServiceListResult"] + """Gets all private link services in a 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 PrivateLinkServiceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateLinkServiceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateLinkServices'} # type: ignore + + def list_by_subscription( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateLinkServiceListResult"] + """Gets all private link service 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 PrivateLinkServiceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('PrivateLinkServiceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/privateLinkServices'} # type: ignore + + def get_private_endpoint_connection( + self, + resource_group_name, # type: str + service_name, # type: str + pe_connection_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnection" + """Get the specific private end point connection by specific private link service in the resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_connection_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + def update_private_endpoint_connection( + self, + resource_group_name, # type: str + service_name, # type: str + pe_connection_name, # type: str + parameters, # type: "_models.PrivateEndpointConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnection" + """Approve or reject private end point connection for a private link service in a subscription. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_connection_name: str + :param parameters: Parameters supplied to approve or reject the private end point connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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(parameters, 'PrivateEndpointConnection') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + def _delete_private_endpoint_connection_initial( + self, + resource_group_name, # type: str + service_name, # type: str + pe_connection_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-08-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'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + def begin_delete_private_endpoint_connection( + self, + resource_group_name, # type: str + service_name, # type: str + pe_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Delete private end point connection for a private link service in a subscription. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :param pe_connection_name: The name of the private end point connection. + :type pe_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 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_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + service_name=service_name, + pe_connection_name=pe_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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'peConnectionName': self._serialize.url("pe_connection_name", pe_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, 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_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections/{peConnectionName}'} # type: ignore + + def list_private_endpoint_connections( + self, + resource_group_name, # type: str + service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PrivateEndpointConnectionListResult"] + """Gets all private end point connections for a specific private link service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_name: The name of the private link service. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PrivateEndpointConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PrivateEndpointConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_private_endpoint_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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_private_endpoint_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/privateLinkServices/{serviceName}/privateEndpointConnections'} # type: ignore + + def _check_private_link_service_visibility_initial( + self, + location, # type: str + parameters, # type: "_models.CheckPrivateLinkServiceVisibilityRequest" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PrivateLinkServiceVisibility"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PrivateLinkServiceVisibility"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_private_link_service_visibility_initial.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(parameters, 'CheckPrivateLinkServiceVisibilityRequest') + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_private_link_service_visibility_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + def begin_check_private_link_service_visibility( + self, + location, # type: str + parameters, # type: "_models.CheckPrivateLinkServiceVisibilityRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateLinkServiceVisibility"] + """Checks whether the subscription is visible to private link service. + + :param location: The location of the domain name. + :type location: str + :param parameters: The request body of CheckPrivateLinkService API call. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CheckPrivateLinkServiceVisibilityRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkServiceVisibility or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceVisibility] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceVisibility"] + lro_delay = kwargs.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._check_private_link_service_visibility_initial( + location=location, + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'location': self._serialize.url("location", location, '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_check_private_link_service_visibility.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + def _check_private_link_service_visibility_by_resource_group_initial( + self, + location, # type: str + resource_group_name, # type: str + parameters, # type: "_models.CheckPrivateLinkServiceVisibilityRequest" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PrivateLinkServiceVisibility"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PrivateLinkServiceVisibility"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._check_private_link_service_visibility_by_resource_group_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + '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') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'CheckPrivateLinkServiceVisibilityRequest') + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _check_private_link_service_visibility_by_resource_group_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + def begin_check_private_link_service_visibility_by_resource_group( + self, + location, # type: str + resource_group_name, # type: str + parameters, # type: "_models.CheckPrivateLinkServiceVisibilityRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateLinkServiceVisibility"] + """Checks whether the subscription is visible to private link service in the specified resource + group. + + :param location: The location of the domain name. + :type location: str + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param parameters: The request body of CheckPrivateLinkService API call. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.CheckPrivateLinkServiceVisibilityRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PrivateLinkServiceVisibility or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PrivateLinkServiceVisibility] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkServiceVisibility"] + lro_delay = kwargs.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._check_private_link_service_visibility_by_resource_group_initial( + location=location, + 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('PrivateLinkServiceVisibility', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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_check_private_link_service_visibility_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/checkPrivateLinkServiceVisibility'} # type: ignore + + def list_auto_approved_private_link_services( + self, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AutoApprovedPrivateLinkServicesResult"] + """Returns all of the private link service ids that can be linked to a Private Endpoint with auto + approved in this subscription in this region. + + :param location: The location of the domain name. + :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 AutoApprovedPrivateLinkServicesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkServicesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AutoApprovedPrivateLinkServicesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_auto_approved_private_link_services.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('AutoApprovedPrivateLinkServicesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_auto_approved_private_link_services.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/autoApprovedPrivateLinkServices'} # type: ignore + + def list_auto_approved_private_link_services_by_resource_group( + self, + location, # type: str + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AutoApprovedPrivateLinkServicesResult"] + """Returns all of the private link service ids that can be linked to a Private Endpoint with auto + approved in this subscription in this region. + + :param location: The location of the domain name. + :type location: str + :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 AutoApprovedPrivateLinkServicesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AutoApprovedPrivateLinkServicesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AutoApprovedPrivateLinkServicesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_auto_approved_private_link_services_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + '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('AutoApprovedPrivateLinkServicesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_auto_approved_private_link_services_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/locations/{location}/autoApprovedPrivateLinkServices'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_addresses_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_addresses_operations.py new file mode 100644 index 000000000000..6501f9c2d3ff --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_addresses_operations.py @@ -0,0 +1,1043 @@ +# 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 PublicIPAddressesOperations(object): + """PublicIPAddressesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + public_ip_address_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-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + public_ip_address_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified public IP address. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_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, + public_ip_address_name=public_ip_address_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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_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.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + public_ip_address_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPAddress" + """Gets the specified public IP address in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + public_ip_address_name, # type: str + parameters, # type: "_models.PublicIPAddress" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPAddress" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PublicIPAddress') + 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('PublicIPAddress', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + public_ip_address_name, # type: str + parameters, # type: "_models.PublicIPAddress" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PublicIPAddress"] + """Creates or updates a static or dynamic public IP address. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param parameters: Parameters supplied to the create or update public IP address operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PublicIPAddress or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PublicIPAddress] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + lro_delay = kwargs.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, + public_ip_address_name=public_ip_address_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('PublicIPAddress', 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'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_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': 'azure-async-operation'}, 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.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + public_ip_address_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPAddress" + """Updates public IP address tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_address_name: The name of the public IP address. + :type public_ip_address_name: str + :param parameters: Parameters supplied to update public IP address tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPAddresses/{publicIpAddressName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets all the public IP addresses 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 PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/publicIPAddresses'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets all public IP addresses in a 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 PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/publicIPAddresses'} # type: ignore + + def list_virtual_machine_scale_set_public_ip_addresses( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets information about all public IP addresses on a virtual machine scale set level. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_virtual_machine_scale_set_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/publicipaddresses'} # type: ignore + + def list_virtual_machine_scale_set_vm_public_ip_addresses( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets information about all public IP addresses in a virtual machine IP configuration in a + virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The network interface name. + :type network_interface_name: str + :param ip_configuration_name: The IP configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-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_virtual_machine_scale_set_vm_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_virtual_machine_scale_set_vm_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses'} # type: ignore + + def get_virtual_machine_scale_set_public_ip_address( + self, + resource_group_name, # type: str + virtual_machine_scale_set_name, # type: str + virtualmachine_index, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + public_ip_address_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPAddress" + """Get the specified public IP address in a virtual machine scale set. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_machine_scale_set_name: The name of the virtual machine scale set. + :type virtual_machine_scale_set_name: str + :param virtualmachine_index: The virtual machine index. + :type virtualmachine_index: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the IP configuration. + :type ip_configuration_name: str + :param public_ip_address_name: The name of the public IP Address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-10-01" + accept = "application/json" + + # Construct URL + url = self.get_virtual_machine_scale_set_public_ip_address.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualMachineScaleSetName': self._serialize.url("virtual_machine_scale_set_name", virtual_machine_scale_set_name, 'str'), + 'virtualmachineIndex': self._serialize.url("virtualmachine_index", virtualmachine_index, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_virtual_machine_scale_set_public_ip_address.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/virtualMachineScaleSets/{virtualMachineScaleSetName}/virtualMachines/{virtualmachineIndex}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses/{publicIpAddressName}'} # type: ignore + + def list_cloud_service_public_ip_addresses( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets information about all public IP addresses on a cloud service level. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_cloud_service_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/publicipaddresses'} # type: ignore + + def list_cloud_service_role_instance_public_ip_addresses( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + role_instance_name, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPAddressListResult"] + """Gets information about all public IP addresses in a role instance IP configuration in a cloud + service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The name of role instance. + :type role_instance_name: str + :param network_interface_name: The network interface name. + :type network_interface_name: str + :param ip_configuration_name: The IP configuration name. + :type ip_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicIPAddressListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPAddressListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddressListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_cloud_service_role_instance_public_ip_addresses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPAddressListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_cloud_service_role_instance_public_ip_addresses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses'} # type: ignore + + def get_cloud_service_public_ip_address( + self, + resource_group_name, # type: str + cloud_service_name, # type: str + role_instance_name, # type: str + network_interface_name, # type: str + ip_configuration_name, # type: str + public_ip_address_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPAddress" + """Get the specified public IP address in a cloud service. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cloud_service_name: The name of the cloud service. + :type cloud_service_name: str + :param role_instance_name: The role instance name. + :type role_instance_name: str + :param network_interface_name: The name of the network interface. + :type network_interface_name: str + :param ip_configuration_name: The name of the IP configuration. + :type ip_configuration_name: str + :param public_ip_address_name: The name of the public IP Address. + :type public_ip_address_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPAddress, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPAddress + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPAddress"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_cloud_service_public_ip_address.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'cloudServiceName': self._serialize.url("cloud_service_name", cloud_service_name, 'str'), + 'roleInstanceName': self._serialize.url("role_instance_name", role_instance_name, 'str'), + 'networkInterfaceName': self._serialize.url("network_interface_name", network_interface_name, 'str'), + 'ipConfigurationName': self._serialize.url("ip_configuration_name", ip_configuration_name, 'str'), + 'publicIpAddressName': self._serialize.url("public_ip_address_name", public_ip_address_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPAddress', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_cloud_service_public_ip_address.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/cloudServices/{cloudServiceName}/roleInstances/{roleInstanceName}/networkInterfaces/{networkInterfaceName}/ipconfigurations/{ipConfigurationName}/publicipaddresses/{publicIpAddressName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_prefixes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_prefixes_operations.py new file mode 100644 index 000000000000..0d234631fef4 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_public_ip_prefixes_operations.py @@ -0,0 +1,557 @@ +# 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 PublicIPPrefixesOperations(object): + """PublicIPPrefixesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + public_ip_prefix_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-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + public_ip_prefix_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified public IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the PublicIpPrefix. + :type public_ip_prefix_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, + public_ip_prefix_name=public_ip_prefix_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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_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.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + public_ip_prefix_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPPrefix" + """Gets the specified public IP prefix in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + public_ip_prefix_name, # type: str + parameters, # type: "_models.PublicIPPrefix" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPPrefix" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'PublicIPPrefix') + 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('PublicIPPrefix', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + public_ip_prefix_name, # type: str + parameters, # type: "_models.PublicIPPrefix" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PublicIPPrefix"] + """Creates or updates a static or dynamic public IP prefix. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param parameters: Parameters supplied to the create or update public IP prefix operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 PublicIPPrefix or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + lro_delay = kwargs.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, + public_ip_prefix_name=public_ip_prefix_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('PublicIPPrefix', 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'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_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.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + public_ip_prefix_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicIPPrefix" + """Updates public IP prefix tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param public_ip_prefix_name: The name of the public IP prefix. + :type public_ip_prefix_name: str + :param parameters: Parameters supplied to update public IP prefix tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicIPPrefix, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.PublicIPPrefix + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefix"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'publicIpPrefixName': self._serialize.url("public_ip_prefix_name", public_ip_prefix_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('PublicIPPrefix', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/publicIPPrefixes/{publicIpPrefixName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPPrefixListResult"] + """Gets all the public IP prefixes 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 PublicIPPrefixListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('PublicIPPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/publicIPPrefixes'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicIPPrefixListResult"] + """Gets all public IP prefixes in a 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 PublicIPPrefixListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.PublicIPPrefixListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicIPPrefixListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicIPPrefixListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/publicIPPrefixes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_resource_navigation_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_resource_navigation_links_operations.py new file mode 100644 index 000000000000..6fd61651dfa6 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_resource_navigation_links_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 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 ResourceNavigationLinksOperations(object): + """ResourceNavigationLinksOperations 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.network.v2020_08_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_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceNavigationLinksListResult" + """Gets a list of resource navigation links for a subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNavigationLinksListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ResourceNavigationLinksListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNavigationLinksListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ResourceNavigationLinksListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/ResourceNavigationLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filter_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filter_rules_operations.py new file mode 100644 index 000000000000..b5347d576f32 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filter_rules_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 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 RouteFilterRulesOperations(object): + """RouteFilterRulesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + route_filter_name, # type: str + rule_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-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + route_filter_name, # type: str + rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified rule from a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the rule. + :type rule_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, + route_filter_name=route_filter_name, + rule_name=rule_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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_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.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + route_filter_name, # type: str + rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteFilterRule" + """Gets the specified rule from a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the rule. + :type rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilterRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilterRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteFilterRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + route_filter_name, # type: str + rule_name, # type: str + route_filter_rule_parameters, # type: "_models.RouteFilterRule" + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteFilterRule" + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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_filter_rule_parameters, 'RouteFilterRule') + 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('RouteFilterRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteFilterRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + route_filter_name, # type: str + rule_name, # type: str + route_filter_rule_parameters, # type: "_models.RouteFilterRule" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.RouteFilterRule"] + """Creates or updates a route in the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param rule_name: The name of the route filter rule. + :type rule_name: str + :param route_filter_rule_parameters: Parameters supplied to the create or update route filter + rule operation. + :type route_filter_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.RouteFilterRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteFilterRule or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.RouteFilterRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRule"] + lro_delay = kwargs.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, + route_filter_name=route_filter_name, + rule_name=rule_name, + route_filter_rule_parameters=route_filter_rule_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('RouteFilterRule', 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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'ruleName': self._serialize.url("rule_name", rule_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': 'azure-async-operation'}, 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.Network/routeFilters/{routeFilterName}/routeFilterRules/{ruleName}'} # type: ignore + + def list_by_route_filter( + self, + resource_group_name, # type: str + route_filter_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteFilterRuleListResult"] + """Gets all RouteFilterRules in a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RouteFilterRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_route_filter.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RouteFilterRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_route_filter.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}/routeFilterRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filters_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filters_operations.py new file mode 100644 index 000000000000..b7855f9cf1d1 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_filters_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 RouteFiltersOperations(object): + """RouteFiltersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + route_filter_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-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + route_filter_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_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, + route_filter_name=route_filter_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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_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.Network/routeFilters/{routeFilterName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + route_filter_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteFilter" + """Gets the specified route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param expand: Expands referenced express route bgp peering resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + route_filter_name, # type: str + route_filter_parameters, # type: "_models.RouteFilter" + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteFilter" + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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_filter_parameters, 'RouteFilter') + 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('RouteFilter', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + route_filter_name, # type: str + route_filter_parameters, # type: "_models.RouteFilter" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.RouteFilter"] + """Creates or updates a route filter in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param route_filter_parameters: Parameters supplied to the create or update route filter + operation. + :type route_filter_parameters: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteFilter or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.RouteFilter] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + lro_delay = kwargs.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, + route_filter_name=route_filter_name, + route_filter_parameters=route_filter_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('RouteFilter', 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'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_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': 'azure-async-operation'}, 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.Network/routeFilters/{routeFilterName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + route_filter_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteFilter" + """Updates tags of a route filter. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_filter_name: The name of the route filter. + :type route_filter_name: str + :param parameters: Parameters supplied to update route filter tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteFilter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteFilter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeFilterName': self._serialize.url("route_filter_name", route_filter_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('RouteFilter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeFilters/{routeFilterName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteFilterListResult"] + """Gets all route filters in a 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 RouteFilterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('RouteFilterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/routeFilters'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteFilterListResult"] + """Gets all route filters 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 RouteFilterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteFilterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteFilterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('RouteFilterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/routeFilters'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_tables_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_tables_operations.py new file mode 100644 index 000000000000..75a6c6c257cc --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_route_tables_operations.py @@ -0,0 +1,557 @@ +# 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 RouteTablesOperations(object): + """RouteTablesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + route_table_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-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_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, + route_table_name=route_table_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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/routeTables/{routeTableName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + route_table_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteTable" + """Gets the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + route_table_name, # type: str + parameters, # type: "_models.RouteTable" + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteTable" + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'RouteTable') + 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('RouteTable', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + route_table_name, # type: str + parameters, # type: "_models.RouteTable" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.RouteTable"] + """Create or updates a route table in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param parameters: Parameters supplied to the create or update route table operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 RouteTable or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.RouteTable] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + lro_delay = kwargs.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, + route_table_name=route_table_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('RouteTable', 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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': 'azure-async-operation'}, 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.Network/routeTables/{routeTableName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + route_table_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.RouteTable" + """Updates a route table tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param parameters: Parameters supplied to update route table tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RouteTable, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.RouteTable + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTable"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('RouteTable', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteTableListResult"] + """Gets all route tables in a 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 RouteTableListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteTableListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTableListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RouteTableListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/routeTables'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteTableListResult"] + """Gets all route tables 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 RouteTableListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteTableListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteTableListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('RouteTableListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/routeTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_routes_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_routes_operations.py new file mode 100644 index 000000000000..7907bf0fe2c3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_routes_operations.py @@ -0,0 +1,440 @@ +# 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 RoutesOperations(object): + """RoutesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + route_table_name, # type: str + route_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-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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, 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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + route_table_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified route from a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_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, + route_table_name=route_table_name, + route_name=route_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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'routeName': self._serialize.url("route_name", route_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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + route_table_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Route" + """Gets the specified route from a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Route, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Route + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Route', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + route_table_name, # type: str + route_name, # type: str + route_parameters, # type: "_models.Route" + **kwargs # type: Any + ): + # type: (...) -> "_models.Route" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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_parameters, 'Route') + 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('Route', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('Route', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + route_table_name, # type: str + route_name, # type: str + route_parameters, # type: "_models.Route" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Route"] + """Creates or updates a route in the specified route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :param route_name: The name of the route. + :type route_name: str + :param route_parameters: Parameters supplied to the create or update route operation. + :type route_parameters: ~azure.mgmt.network.v2020_08_01.models.Route + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 Route or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.Route] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Route"] + lro_delay = kwargs.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, + route_table_name=route_table_name, + route_name=route_name, + route_parameters=route_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('Route', 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'routeName': self._serialize.url("route_name", route_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': 'azure-async-operation'}, 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.Network/routeTables/{routeTableName}/routes/{routeName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RouteListResult"] + """Gets all routes in a route table. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param route_table_name: The name of the route table. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RouteListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.RouteListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RouteListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RouteListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/routeTables/{routeTableName}/routes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_partner_providers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_partner_providers_operations.py new file mode 100644 index 000000000000..5976bd88d90d --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_partner_providers_operations.py @@ -0,0 +1,553 @@ +# 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 SecurityPartnerProvidersOperations(object): + """SecurityPartnerProvidersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + security_partner_provider_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-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + security_partner_provider_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_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, + security_partner_provider_name=security_partner_provider_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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_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.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + security_partner_provider_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityPartnerProvider" + """Gets the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityPartnerProvider, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + security_partner_provider_name, # type: str + parameters, # type: "_models.SecurityPartnerProvider" + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityPartnerProvider" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'SecurityPartnerProvider') + 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('SecurityPartnerProvider', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + security_partner_provider_name, # type: str + parameters, # type: "_models.SecurityPartnerProvider" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SecurityPartnerProvider"] + """Creates or updates the specified Security Partner Provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :param parameters: Parameters supplied to the create or update Security Partner Provider + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityPartnerProvider or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + lro_delay = kwargs.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, + security_partner_provider_name=security_partner_provider_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('SecurityPartnerProvider', 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'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_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': 'azure-async-operation'}, 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.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + security_partner_provider_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityPartnerProvider" + """Updates tags of a Security Partner Provider resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param security_partner_provider_name: The name of the Security Partner Provider. + :type security_partner_provider_name: str + :param parameters: Parameters supplied to update Security Partner Provider tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityPartnerProvider, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProvider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProvider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'securityPartnerProviderName': self._serialize.url("security_partner_provider_name", security_partner_provider_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('SecurityPartnerProvider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/securityPartnerProviders/{securityPartnerProviderName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SecurityPartnerProviderListResult"] + """Lists all Security Partner Providers in a 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 SecurityPartnerProviderListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('SecurityPartnerProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/securityPartnerProviders'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SecurityPartnerProviderListResult"] + """Gets all the Security Partner Providers 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 SecurityPartnerProviderListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityPartnerProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityPartnerProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('SecurityPartnerProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/securityPartnerProviders'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_rules_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_rules_operations.py new file mode 100644 index 000000000000..1cf9070671aa --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_security_rules_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 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 SecurityRulesOperations(object): + """SecurityRulesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + security_rule_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-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + security_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_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, + network_security_group_name=network_security_group_name, + security_rule_name=security_rule_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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_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.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + security_rule_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityRule" + """Get the specified network security rule. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SecurityRule, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + security_rule_name, # type: str + security_rule_parameters, # type: "_models.SecurityRule" + **kwargs # type: Any + ): + # type: (...) -> "_models.SecurityRule" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(security_rule_parameters, 'SecurityRule') + 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('SecurityRule', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SecurityRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + security_rule_name, # type: str + security_rule_parameters, # type: "_models.SecurityRule" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SecurityRule"] + """Creates or updates a security rule in the specified network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_group_name: str + :param security_rule_name: The name of the security rule. + :type security_rule_name: str + :param security_rule_parameters: Parameters supplied to the create or update network security + rule operation. + :type security_rule_parameters: ~azure.mgmt.network.v2020_08_01.models.SecurityRule + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 SecurityRule or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.SecurityRule] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRule"] + lro_delay = kwargs.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, + network_security_group_name=network_security_group_name, + security_rule_name=security_rule_name, + security_rule_parameters=security_rule_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('SecurityRule', 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_group_name, 'str'), + 'securityRuleName': self._serialize.url("security_rule_name", security_rule_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': 'azure-async-operation'}, 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.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules/{securityRuleName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_security_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SecurityRuleListResult"] + """Gets all security rules in a network security group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_security_group_name: The name of the network security group. + :type network_security_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 SecurityRuleListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.SecurityRuleListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SecurityRuleListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkSecurityGroupName': self._serialize.url("network_security_group_name", network_security_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('SecurityRuleListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkSecurityGroups/{networkSecurityGroupName}/securityRules'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_association_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_association_links_operations.py new file mode 100644 index 000000000000..8c6b72217af1 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_association_links_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 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 ServiceAssociationLinksOperations(object): + """ServiceAssociationLinksOperations 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.network.v2020_08_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_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceAssociationLinksListResult" + """Gets a list of service association links for a subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceAssociationLinksListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceAssociationLinksListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceAssociationLinksListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceAssociationLinksListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/ServiceAssociationLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policies_operations.py new file mode 100644 index 000000000000..e2e7eedd2769 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policies_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 ServiceEndpointPoliciesOperations(object): + """ServiceEndpointPoliciesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + service_endpoint_policy_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-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_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, + service_endpoint_policy_name=service_endpoint_policy_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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceEndpointPolicy" + """Gets the specified service Endpoint Policies in a specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + parameters, # type: "_models.ServiceEndpointPolicy" + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceEndpointPolicy" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'ServiceEndpointPolicy') + 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('ServiceEndpointPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + parameters, # type: "_models.ServiceEndpointPolicy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ServiceEndpointPolicy"] + """Creates or updates a service Endpoint Policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param parameters: Parameters supplied to the create or update service endpoint policy + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ServiceEndpointPolicy or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + lro_delay = kwargs.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, + service_endpoint_policy_name=service_endpoint_policy_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('ServiceEndpointPolicy', 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_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': 'azure-async-operation'}, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceEndpointPolicy" + """Updates tags of a service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param parameters: Parameters supplied to update service endpoint policy tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('ServiceEndpointPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ServiceEndpointPolicyListResult"] + """Gets all the service endpoint policies 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 ServiceEndpointPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ServiceEndpointPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/ServiceEndpointPolicies'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ServiceEndpointPolicyListResult"] + """Gets all service endpoint Policies in a 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 ServiceEndpointPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ServiceEndpointPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/serviceEndpointPolicies'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policy_definitions_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policy_definitions_operations.py new file mode 100644 index 000000000000..930f0600eca3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_endpoint_policy_definitions_operations.py @@ -0,0 +1,445 @@ +# 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 ServiceEndpointPolicyDefinitionsOperations(object): + """ServiceEndpointPolicyDefinitionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + service_endpoint_policy_definition_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-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + service_endpoint_policy_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified ServiceEndpoint policy definitions. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the Service Endpoint Policy. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition. + :type service_endpoint_policy_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 + 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, + service_endpoint_policy_name=service_endpoint_policy_name, + service_endpoint_policy_definition_name=service_endpoint_policy_definition_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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_policy_definition_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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + service_endpoint_policy_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceEndpointPolicyDefinition" + """Get the specified service endpoint policy definitions from service endpoint policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy name. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition name. + :type service_endpoint_policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceEndpointPolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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('ServiceEndpointPolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + service_endpoint_policy_definition_name, # type: str + service_endpoint_policy_definitions, # type: "_models.ServiceEndpointPolicyDefinition" + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceEndpointPolicyDefinition" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_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(service_endpoint_policy_definitions, 'ServiceEndpointPolicyDefinition') + 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('ServiceEndpointPolicyDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ServiceEndpointPolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + service_endpoint_policy_definition_name, # type: str + service_endpoint_policy_definitions, # type: "_models.ServiceEndpointPolicyDefinition" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ServiceEndpointPolicyDefinition"] + """Creates or updates a service endpoint policy definition in the specified service endpoint + policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy. + :type service_endpoint_policy_name: str + :param service_endpoint_policy_definition_name: The name of the service endpoint policy + definition name. + :type service_endpoint_policy_definition_name: str + :param service_endpoint_policy_definitions: Parameters supplied to the create or update service + endpoint policy operation. + :type service_endpoint_policy_definitions: ~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ServiceEndpointPolicyDefinition or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinition] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinition"] + lro_delay = kwargs.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, + service_endpoint_policy_name=service_endpoint_policy_name, + service_endpoint_policy_definition_name=service_endpoint_policy_definition_name, + service_endpoint_policy_definitions=service_endpoint_policy_definitions, + 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('ServiceEndpointPolicyDefinition', 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'serviceEndpointPolicyDefinitionName': self._serialize.url("service_endpoint_policy_definition_name", service_endpoint_policy_definition_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': 'azure-async-operation'}, 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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions/{serviceEndpointPolicyDefinitionName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + service_endpoint_policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ServiceEndpointPolicyDefinitionListResult"] + """Gets all service endpoint policy definitions in a service end point policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param service_endpoint_policy_name: The name of the service endpoint policy name. + :type service_endpoint_policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ServiceEndpointPolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ServiceEndpointPolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceEndpointPolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'serviceEndpointPolicyName': self._serialize.url("service_endpoint_policy_name", service_endpoint_policy_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ServiceEndpointPolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/serviceEndpointPolicies/{serviceEndpointPolicyName}/serviceEndpointPolicyDefinitions'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_tags_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_tags_operations.py new file mode 100644 index 000000000000..272dad8555ef --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_service_tags_operations.py @@ -0,0 +1,102 @@ +# 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 ServiceTagsOperations(object): + """ServiceTagsOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceTagsListResult" + """Gets a list of service tag information resources. + + :param location: The location that will be used as a reference for version (not as a filter + based on location, you will get the list of service tags with prefix details across all regions + but limited to the cloud that your subscription belongs to). + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceTagsListResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ServiceTagsListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceTagsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.list.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['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('ServiceTagsListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/locations/{location}/serviceTags'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_subnets_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_subnets_operations.py new file mode 100644 index 000000000000..28b1dc33cc25 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_subnets_operations.py @@ -0,0 +1,701 @@ +# 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 SubnetsOperations(object): + """SubnetsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified subnet. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_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, + virtual_network_name=virtual_network_name, + subnet_name=subnet_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.Subnet" + """Gets the specified subnet by virtual network and resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Subnet, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.Subnet + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('Subnet', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + subnet_parameters, # type: "_models.Subnet" + **kwargs # type: Any + ): + # type: (...) -> "_models.Subnet" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(subnet_parameters, 'Subnet') + 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('Subnet', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('Subnet', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + subnet_parameters, # type: "_models.Subnet" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Subnet"] + """Creates or updates a subnet in the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param subnet_parameters: Parameters supplied to the create or update subnet operation. + :type subnet_parameters: ~azure.mgmt.network.v2020_08_01.models.Subnet + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 Subnet or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.Subnet] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subnet"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + subnet_parameters=subnet_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('Subnet', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}'} # type: ignore + + def _prepare_network_policies_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + prepare_network_policies_request_parameters, # type: "_models.PrepareNetworkPoliciesRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._prepare_network_policies_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(prepare_network_policies_request_parameters, 'PrepareNetworkPoliciesRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _prepare_network_policies_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/PrepareNetworkPolicies'} # type: ignore + + def begin_prepare_network_policies( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + prepare_network_policies_request_parameters, # type: "_models.PrepareNetworkPoliciesRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Prepares a subnet by applying network intent policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param prepare_network_policies_request_parameters: Parameters supplied to prepare subnet by + applying network intent policies. + :type prepare_network_policies_request_parameters: ~azure.mgmt.network.v2020_08_01.models.PrepareNetworkPoliciesRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._prepare_network_policies_initial( + resource_group_name=resource_group_name, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + prepare_network_policies_request_parameters=prepare_network_policies_request_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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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_prepare_network_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/PrepareNetworkPolicies'} # type: ignore + + def _unprepare_network_policies_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + unprepare_network_policies_request_parameters, # type: "_models.UnprepareNetworkPoliciesRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._unprepare_network_policies_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(unprepare_network_policies_request_parameters, 'UnprepareNetworkPoliciesRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _unprepare_network_policies_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/UnprepareNetworkPolicies'} # type: ignore + + def begin_unprepare_network_policies( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + subnet_name, # type: str + unprepare_network_policies_request_parameters, # type: "_models.UnprepareNetworkPoliciesRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Unprepares a subnet by removing network intent policies. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param subnet_name: The name of the subnet. + :type subnet_name: str + :param unprepare_network_policies_request_parameters: Parameters supplied to unprepare subnet + to remove network intent policies. + :type unprepare_network_policies_request_parameters: ~azure.mgmt.network.v2020_08_01.models.UnprepareNetworkPoliciesRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._unprepare_network_policies_initial( + resource_group_name=resource_group_name, + virtual_network_name=virtual_network_name, + subnet_name=subnet_name, + unprepare_network_policies_request_parameters=unprepare_network_policies_request_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 = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subnetName': self._serialize.url("subnet_name", subnet_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_unprepare_network_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets/{subnetName}/UnprepareNetworkPolicies'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SubnetListResult"] + """Gets all subnets in a virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SubnetListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.SubnetListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubnetListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SubnetListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_usages_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_usages_operations.py new file mode 100644 index 000000000000..8c8f407863fe --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_usages_operations.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. +# -------------------------------------------------------------------------- +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 UsagesOperations(object): + """UsagesOperations 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.network.v2020_08_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, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.UsagesListResult"] + """List network usages for a subscription. + + :param location: The location where resource usage is queried. + :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 UsagesListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.UsagesListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsagesListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'location': self._serialize.url("location", location, 'str', 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('UsagesListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/locations/{location}/usages'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_sites_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_sites_operations.py new file mode 100644 index 000000000000..6ab326236e8c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_sites_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 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 VirtualApplianceSitesOperations(object): + """VirtualApplianceSitesOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + site_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-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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.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/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified site from a Virtual Appliance. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_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, + network_virtual_appliance_name=network_virtual_appliance_name, + site_name=site_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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'siteName': self._serialize.url("site_name", site_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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualApplianceSite" + """Gets the specified Virtual Appliance Site. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualApplianceSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualApplianceSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + site_name, # type: str + parameters, # type: "_models.VirtualApplianceSite" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualApplianceSite" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + '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['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualApplianceSite') + 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('VirtualApplianceSite', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualApplianceSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + site_name, # type: str + parameters, # type: "_models.VirtualApplianceSite" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualApplianceSite"] + """Creates or updates the specified Network Virtual Appliance Site. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :param site_name: The name of the site. + :type site_name: str + :param parameters: Parameters supplied to the create or update Network Virtual Appliance Site + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualApplianceSite or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualApplianceSite] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualApplianceSite"] + lro_delay = kwargs.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, + network_virtual_appliance_name=network_virtual_appliance_name, + site_name=site_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('VirtualApplianceSite', 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'siteName': self._serialize.url("site_name", site_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': 'azure-async-operation'}, 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.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites/{siteName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + network_virtual_appliance_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NetworkVirtualApplianceSiteListResult"] + """Lists all Network Virtual Appliance Sites in a Network Virtual Appliance resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param network_virtual_appliance_name: The name of the Network Virtual Appliance. + :type network_virtual_appliance_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkVirtualApplianceSiteListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSiteListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSiteListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'networkVirtualApplianceName': self._serialize.url("network_virtual_appliance_name", network_virtual_appliance_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NetworkVirtualApplianceSiteListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/networkVirtualAppliances/{networkVirtualApplianceName}/virtualApplianceSites'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_skus_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_skus_operations.py new file mode 100644 index 000000000000..f41629889e1c --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_appliance_skus_operations.py @@ -0,0 +1,168 @@ +# 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 VirtualApplianceSkusOperations(object): + """VirtualApplianceSkusOperations 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.network.v2020_08_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.NetworkVirtualApplianceSkuListResult"] + """List all SKUs available for a virtual appliance. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NetworkVirtualApplianceSkuListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSkuListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSkuListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('NetworkVirtualApplianceSkuListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/networkVirtualApplianceSkus'} # type: ignore + + def get( + self, + sku_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.NetworkVirtualApplianceSku" + """Retrieves a single available sku for network virtual appliance. + + :param sku_name: Name of the Sku. + :type sku_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkVirtualApplianceSku, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.NetworkVirtualApplianceSku + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NetworkVirtualApplianceSku"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'skuName': self._serialize.url("sku_name", sku_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('NetworkVirtualApplianceSku', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/networkVirtualApplianceSkus/{skuName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connection_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connection_operations.py new file mode 100644 index 000000000000..8e7fdc43a8df --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connection_operations.py @@ -0,0 +1,365 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class VirtualHubBgpConnectionOperations(object): + """VirtualHubBgpConnectionOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BgpConnection" + """Retrieves the details of a Virtual Hub Bgp Connection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BgpConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.BgpConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('BgpConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + parameters, # type: "_models.BgpConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.BgpConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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, 'BgpConnection') + 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('BgpConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('BgpConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + parameters, # type: "_models.BgpConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.BgpConnection"] + """Creates a VirtualHubBgpConnection resource if it doesn't exist else updates the existing + VirtualHubBgpConnection. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :param parameters: Parameters of Bgp connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.BgpConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 BgpConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.BgpConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpConnection"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + connection_name=connection_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('BgpConnection', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VirtualHubBgpConnection. + + :param resource_group_name: The resource group name of the VirtualHubBgpConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param connection_name: The name of the connection. + :type 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 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, + virtual_hub_name=virtual_hub_name, + connection_name=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): + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/virtualHubs/{virtualHubName}/bgpConnections/{connectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connections_operations.py new file mode 100644 index 000000000000..dce376267e53 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_bgp_connections_operations.py @@ -0,0 +1,373 @@ +# 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 VirtualHubBgpConnectionsOperations(object): + """VirtualHubBgpConnectionsOperations 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.network.v2020_08_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_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualHubBgpConnectionResults"] + """Retrieves the details of all VirtualHubBgpConnections. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubBgpConnectionResults or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubBgpConnectionResults] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubBgpConnectionResults"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubBgpConnectionResults', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/bgpConnections'} # type: ignore + + def _list_learned_routes_initial( + self, + resource_group_name, # type: str + hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PeerRouteList"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PeerRouteList"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_learned_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PeerRouteList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_learned_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/learnedRoutes'} # type: ignore + + def begin_list_learned_routes( + self, + resource_group_name, # type: str + hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PeerRouteList"] + """Retrieves a list of routes the virtual hub bgp connection has learned. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param hub_name: The name of the virtual hub. + :type hub_name: str + :param connection_name: The name of the virtual hub bgp connection. + :type 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 PeerRouteList or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PeerRouteList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerRouteList"] + lro_delay = kwargs.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_learned_routes_initial( + resource_group_name=resource_group_name, + hub_name=hub_name, + connection_name=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('PeerRouteList', 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'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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_list_learned_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/learnedRoutes'} # type: ignore + + def _list_advertised_routes_initial( + self, + resource_group_name, # type: str + hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PeerRouteList"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PeerRouteList"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_advertised_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PeerRouteList', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_advertised_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/advertisedRoutes'} # type: ignore + + def begin_list_advertised_routes( + self, + resource_group_name, # type: str + hub_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PeerRouteList"] + """Retrieves a list of routes the virtual hub bgp connection is advertising to the specified peer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param hub_name: The name of the virtual hub. + :type hub_name: str + :param connection_name: The name of the virtual hub bgp connection. + :type 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 PeerRouteList or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.PeerRouteList] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PeerRouteList"] + lro_delay = kwargs.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_advertised_routes_initial( + resource_group_name=resource_group_name, + hub_name=hub_name, + connection_name=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('PeerRouteList', 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'), + 'hubName': self._serialize.url("hub_name", hub_name, 'str'), + 'connectionName': self._serialize.url("connection_name", 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, 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_list_advertised_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{hubName}/bgpConnections/{connectionName}/advertisedRoutes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_ip_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_ip_configuration_operations.py new file mode 100644 index 000000000000..fc9d4f5f12fb --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_ip_configuration_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 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 VirtualHubIpConfigurationOperations(object): + """VirtualHubIpConfigurationOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + ip_config_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HubIpConfiguration" + """Retrieves the details of a Virtual Hub Ip configuration. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HubIpConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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('HubIpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + ip_config_name, # type: str + parameters, # type: "_models.HubIpConfiguration" + **kwargs # type: Any + ): + # type: (...) -> "_models.HubIpConfiguration" + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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, 'HubIpConfiguration') + 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('HubIpConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('HubIpConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + ip_config_name, # type: str + parameters, # type: "_models.HubIpConfiguration" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.HubIpConfiguration"] + """Creates a VirtualHubIpConfiguration resource if it doesn't exist else updates the existing + VirtualHubIpConfiguration. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_name: str + :param parameters: Hub Ip Configuration parameters. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 HubIpConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.HubIpConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.HubIpConfiguration"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + ip_config_name=ip_config_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('HubIpConfiguration', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + ip_config_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + ip_config_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VirtualHubIpConfiguration. + + :param resource_group_name: The resource group name of the VirtualHubBgpConnection. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param ip_config_name: The name of the ipconfig. + :type ip_config_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, + virtual_hub_name=virtual_hub_name, + ip_config_name=ip_config_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'ipConfigName': self._serialize.url("ip_config_name", ip_config_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.Network/virtualHubs/{virtualHubName}/ipConfigurations/{ipConfigName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualHubIpConfigurationResults"] + """Retrieves the details of all VirtualHubIpConfigurations. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubIpConfigurationResults or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubIpConfigurationResults] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubIpConfigurationResults"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubIpConfigurationResults', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/ipConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_route_table_v2_s_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_route_table_v2_s_operations.py new file mode 100644 index 000000000000..2bb06fb8423a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hub_route_table_v2_s_operations.py @@ -0,0 +1,445 @@ +# 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 VirtualHubRouteTableV2SOperations(object): + """VirtualHubRouteTableV2SOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualHubRouteTableV2" + """Retrieves the details of a VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHubRouteTableV2. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHubRouteTableV2, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + virtual_hub_route_table_v2_parameters, # type: "_models.VirtualHubRouteTableV2" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualHubRouteTableV2" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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(virtual_hub_route_table_v2_parameters, 'VirtualHubRouteTableV2') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualHubRouteTableV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + virtual_hub_route_table_v2_parameters, # type: "_models.VirtualHubRouteTableV2" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualHubRouteTableV2"] + """Creates a VirtualHubRouteTableV2 resource if it doesn't exist else updates the existing + VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_name: str + :param virtual_hub_route_table_v2_parameters: Parameters supplied to create or update + VirtualHubRouteTableV2. + :type virtual_hub_route_table_v2_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualHubRouteTableV2 or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualHubRouteTableV2] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHubRouteTableV2"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_name, + virtual_hub_route_table_v2_parameters=virtual_hub_route_table_v2_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('VirtualHubRouteTableV2', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Error, 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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + route_table_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VirtualHubRouteTableV2. + + :param resource_group_name: The resource group name of the VirtualHubRouteTableV2. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param route_table_name: The name of the VirtualHubRouteTableV2. + :type route_table_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, + virtual_hub_name=virtual_hub_name, + route_table_name=route_table_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + 'routeTableName': self._serialize.url("route_table_name", route_table_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.Network/virtualHubs/{virtualHubName}/routeTables/{routeTableName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualHubRouteTableV2SResult"] + """Retrieves the details of all VirtualHubRouteTableV2s. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVirtualHubRouteTableV2SResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubRouteTableV2SResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubRouteTableV2SResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('ListVirtualHubRouteTableV2SResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/routeTables'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hubs_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hubs_operations.py new file mode 100644 index 000000000000..03adf1ff0f6f --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_hubs_operations.py @@ -0,0 +1,676 @@ +# 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 VirtualHubsOperations(object): + """VirtualHubsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualHub" + """Retrieves the details of a VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHub, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + virtual_hub_parameters, # type: "_models.VirtualHub" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualHub" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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(virtual_hub_parameters, 'VirtualHub') + 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('VirtualHub', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + virtual_hub_parameters, # type: "_models.VirtualHub" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualHub"] + """Creates a VirtualHub resource if it doesn't exist else updates the existing VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param virtual_hub_parameters: Parameters supplied to create or update VirtualHub. + :type virtual_hub_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualHub or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualHub] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + lro_delay = kwargs.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, + virtual_hub_name=virtual_hub_name, + virtual_hub_parameters=virtual_hub_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('VirtualHub', 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + virtual_hub_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualHub" + """Updates VirtualHub tags. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param virtual_hub_parameters: Parameters supplied to update VirtualHub tags. + :type virtual_hub_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualHub, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualHub + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualHub"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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(virtual_hub_parameters, 'TagsObject') + 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('VirtualHub', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_hub_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-08-01" + 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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VirtualHub. + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_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, + virtual_hub_name=virtual_hub_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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.Network/virtualHubs/{virtualHubName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualHubsResult"] + """Lists all the VirtualHubs in a resource group. + + :param resource_group_name: The resource group name of the VirtualHub. + :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 ListVirtualHubsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVirtualHubsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/virtualHubs'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualHubsResult"] + """Lists all the VirtualHubs 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 ListVirtualHubsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualHubsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualHubsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVirtualHubsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/virtualHubs'} # type: ignore + + def _get_effective_virtual_hub_routes_initial( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + effective_routes_parameters=None, # type: Optional["_models.EffectiveRoutesParameters"] + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._get_effective_virtual_hub_routes_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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] + if effective_routes_parameters is not None: + body_content = self._serialize.body(effective_routes_parameters, 'EffectiveRoutesParameters') + else: + body_content = None + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _get_effective_virtual_hub_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/effectiveRoutes'} # type: ignore + + def begin_get_effective_virtual_hub_routes( + self, + resource_group_name, # type: str + virtual_hub_name, # type: str + effective_routes_parameters=None, # type: Optional["_models.EffectiveRoutesParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Gets the effective routes configured for the Virtual Hub resource or the specified resource . + + :param resource_group_name: The resource group name of the VirtualHub. + :type resource_group_name: str + :param virtual_hub_name: The name of the VirtualHub. + :type virtual_hub_name: str + :param effective_routes_parameters: Parameters supplied to get the effective routes for a + specific resource. + :type effective_routes_parameters: ~azure.mgmt.network.v2020_08_01.models.EffectiveRoutesParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._get_effective_virtual_hub_routes_initial( + resource_group_name=resource_group_name, + virtual_hub_name=virtual_hub_name, + effective_routes_parameters=effective_routes_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'), + 'virtualHubName': self._serialize.url("virtual_hub_name", virtual_hub_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_get_effective_virtual_hub_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualHubs/{virtualHubName}/effectiveRoutes'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateway_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateway_connections_operations.py new file mode 100644 index 000000000000..5480601b0300 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateway_connections_operations.py @@ -0,0 +1,1264 @@ +# 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 VirtualNetworkGatewayConnectionsOperations(object): + """VirtualNetworkGatewayConnectionsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.VirtualNetworkGatewayConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkGatewayConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VirtualNetworkGatewayConnection') + 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('VirtualNetworkGatewayConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.VirtualNetworkGatewayConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkGatewayConnection"] + """Creates or updates a virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the create or update virtual network gateway + connection operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGatewayConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + lro_delay = kwargs.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, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('VirtualNetworkGatewayConnection', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkGatewayConnection" + """Gets the specified virtual network gateway connection by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkGatewayConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_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-08-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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified virtual network Gateway connection. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_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 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, + virtual_network_gateway_connection_name=virtual_network_gateway_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): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VirtualNetworkGatewayConnection"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGatewayConnection"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'TagsObject') + 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('VirtualNetworkGatewayConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkGatewayConnection"] + """Updates a virtual network gateway connection tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to update virtual network gateway connection tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGatewayConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnection"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('VirtualNetworkGatewayConnection', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}'} # type: ignore + + def _set_shared_key_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.ConnectionSharedKey" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionSharedKey" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'ConnectionSharedKey') + 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('ConnectionSharedKey', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ConnectionSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + def begin_set_shared_key( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.ConnectionSharedKey" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ConnectionSharedKey"] + """The Put VirtualNetworkGatewayConnectionSharedKey operation sets the virtual network gateway + connection shared key for passed virtual network gateway connection in the specified resource + group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection name. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the Begin Set Virtual Network Gateway connection + Shared key operation throughNetwork resource provider. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectionSharedKey or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + lro_delay = kwargs.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._set_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('ConnectionSharedKey', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, lro_options={'final-state-via': 'azure-async-operation'}, 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_set_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + def get_shared_key( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionSharedKey" + """The Get VirtualNetworkGatewayConnectionSharedKey operation retrieves information about the + specified virtual network gateway connection shared key through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection shared + key name. + :type virtual_network_gateway_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionSharedKey, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.ConnectionSharedKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionSharedKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.get_shared_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkGatewayConnectionListResult"] + """The List VirtualNetworkGatewayConnections operation retrieves all the virtual network gateways + connections created. + + :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 VirtualNetworkGatewayConnectionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayConnectionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayConnectionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayConnectionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/connections'} # type: ignore + + def _reset_shared_key_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.ConnectionResetSharedKey" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ConnectionResetSharedKey"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ConnectionResetSharedKey"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._reset_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'ConnectionResetSharedKey') + 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('ConnectionResetSharedKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey/reset'} # type: ignore + + def begin_reset_shared_key( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.ConnectionResetSharedKey" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ConnectionResetSharedKey"] + """The VirtualNetworkGatewayConnectionResetSharedKey operation resets the virtual network gateway + connection shared key for passed virtual network gateway connection in the specified resource + group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The virtual network gateway connection reset + shared key Name. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the begin reset virtual network gateway connection + shared key operation through network resource provider. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.ConnectionResetSharedKey + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 ConnectionResetSharedKey or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.ConnectionResetSharedKey] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionResetSharedKey"] + lro_delay = kwargs.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._reset_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('ConnectionResetSharedKey', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_reset_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/sharedkey/reset'} # type: ignore + + def _start_packet_capture_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnPacketCaptureStartParameters') + else: + body_content = None + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/startPacketCapture'} # type: ignore + + def begin_start_packet_capture( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Starts packet capture on virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to start packet + capture on gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/startPacketCapture'} # type: ignore + + def _stop_packet_capture_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.VpnPacketCaptureStopParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VpnPacketCaptureStopParameters') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/stopPacketCapture'} # type: ignore + + def begin_stop_packet_capture( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.VpnPacketCaptureStopParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Stops packet capture on virtual network gateway connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + Connection. + :type virtual_network_gateway_connection_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to stop packet + capture on gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_connection_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/stopPacketCapture'} # type: ignore + + def _get_ike_sas_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_ike_sas_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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.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.ErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_ike_sas_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/getikesas'} # type: ignore + + def begin_get_ike_sas( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Lists IKE Security Associations for the virtual network gateway connection in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + Connection. + :type virtual_network_gateway_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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._get_ike_sas_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_connection_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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, 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_get_ike_sas.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/getikesas'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateways_operations.py new file mode 100644 index 000000000000..a3fd8c1925f3 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_gateways_operations.py @@ -0,0 +1,2483 @@ +# 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 VirtualNetworkGatewaysOperations(object): + """VirtualNetworkGatewaysOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VirtualNetworkGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VirtualNetworkGateway') + 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('VirtualNetworkGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VirtualNetworkGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkGateway"] + """Creates or updates a virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to create or update virtual network gateway operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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, + virtual_network_gateway_name=virtual_network_gateway_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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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': 'azure-async-operation'}, 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.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkGateway" + """Gets the specified virtual network gateway by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_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-08-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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified virtual network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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, + virtual_network_gateway_name=virtual_network_gateway_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VirtualNetworkGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'TagsObject') + 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('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkGateway"] + """Updates a virtual network gateway tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to update virtual network gateway tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkGatewayListResult"] + """Gets all virtual network gateways by 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 VirtualNetworkGatewayListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualNetworkGateways'} # type: ignore + + def list_connections( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkGatewayListConnectionsResult"] + """Gets all the connections in a virtual network gateway. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkGatewayListConnectionsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGatewayListConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGatewayListConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkGatewayListConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/connections'} # type: ignore + + def _reset_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + gateway_vip=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VirtualNetworkGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VirtualNetworkGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if gateway_vip is not None: + query_parameters['gatewayVip'] = self._serialize.query("gateway_vip", gateway_vip, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VirtualNetworkGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/reset'} # type: ignore + + def begin_reset( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + gateway_vip=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkGateway"] + """Resets the primary of the virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param gateway_vip: Virtual network gateway vip address supplied to the begin reset of the + active-active feature enabled gateway. + :type gateway_vip: 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 VirtualNetworkGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + gateway_vip=gateway_vip, + 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('VirtualNetworkGateway', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/reset'} # type: ignore + + def _reset_vpn_client_shared_key_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_vpn_client_shared_key_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _reset_vpn_client_shared_key_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/resetvpnclientsharedkey'} # type: ignore + + def begin_reset_vpn_client_shared_key( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Resets the VPN client shared key of the virtual network gateway in the specified resource + group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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._reset_vpn_client_shared_key_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_reset_vpn_client_shared_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/resetvpnclientsharedkey'} # type: ignore + + def _generatevpnclientpackage_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnClientParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generatevpnclientpackage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnClientParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generatevpnclientpackage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'} # type: ignore + + def begin_generatevpnclientpackage( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnClientParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Generates VPN client package for P2S client of the virtual network gateway in the specified + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to the generate virtual network gateway VPN client + package operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnClientParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._generatevpnclientpackage_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_generatevpnclientpackage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'} # type: ignore + + def _generate_vpn_profile_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnClientParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._generate_vpn_profile_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnClientParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _generate_vpn_profile_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnprofile'} # type: ignore + + def begin_generate_vpn_profile( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnClientParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Generates VPN profile for P2S client of the virtual network gateway in the specified resource + group. Used for IKEV2 and radius based authentication. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Parameters supplied to the generate virtual network gateway VPN client + package operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnClientParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._generate_vpn_profile_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_generate_vpn_profile.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnprofile'} # type: ignore + + def _get_vpn_profile_package_url_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpn_profile_package_url_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpn_profile_package_url_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnprofilepackageurl'} # type: ignore + + def begin_get_vpn_profile_package_url( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Gets pre-generated VPN profile for P2S client of the virtual network gateway in the specified + resource group. The profile needs to be generated first using generateVpnProfile. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._get_vpn_profile_package_url_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpn_profile_package_url.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnprofilepackageurl'} # type: ignore + + def _get_bgp_peer_status_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + peer=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.BgpPeerStatusListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.BgpPeerStatusListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_bgp_peer_status_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if peer is not None: + query_parameters['peer'] = self._serialize.query("peer", peer, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('BgpPeerStatusListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_bgp_peer_status_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getBgpPeerStatus'} # type: ignore + + def begin_get_bgp_peer_status( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + peer=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.BgpPeerStatusListResult"] + """The GetBgpPeerStatus operation retrieves the status of all BGP peers. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param peer: The IP address of the peer to retrieve the status of. + :type peer: 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 BgpPeerStatusListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.BgpPeerStatusListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.BgpPeerStatusListResult"] + lro_delay = kwargs.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._get_bgp_peer_status_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + peer=peer, + 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('BgpPeerStatusListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_bgp_peer_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getBgpPeerStatus'} # type: ignore + + def supported_vpn_devices( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> str + """Gets a xml format representation for supported vpn devices. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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-08-01" + accept = "application/json" + + # Construct URL + url = self.supported_vpn_devices.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + supported_vpn_devices.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/supportedvpndevices'} # type: ignore + + def _get_learned_routes_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GatewayRouteListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GatewayRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_learned_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GatewayRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_learned_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getLearnedRoutes'} # type: ignore + + def begin_get_learned_routes( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GatewayRouteListResult"] + """This operation retrieves a list of routes the virtual network gateway has learned, including + routes learned from BGP peers. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 GatewayRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.GatewayRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GatewayRouteListResult"] + lro_delay = kwargs.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._get_learned_routes_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('GatewayRouteListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_learned_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getLearnedRoutes'} # type: ignore + + def _get_advertised_routes_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + peer, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GatewayRouteListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GatewayRouteListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_advertised_routes_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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['peer'] = self._serialize.query("peer", peer, '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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GatewayRouteListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_advertised_routes_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getAdvertisedRoutes'} # type: ignore + + def begin_get_advertised_routes( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + peer, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GatewayRouteListResult"] + """This operation retrieves a list of routes the virtual network gateway is advertising to the + specified peer. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param peer: The IP address of the peer. + :type peer: 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 GatewayRouteListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.GatewayRouteListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GatewayRouteListResult"] + lro_delay = kwargs.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._get_advertised_routes_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + peer=peer, + 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('GatewayRouteListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_advertised_routes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getAdvertisedRoutes'} # type: ignore + + def _set_vpnclient_ipsec_parameters_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + vpnclient_ipsec_params, # type: "_models.VpnClientIPsecParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnClientIPsecParameters"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnClientIPsecParameters"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._set_vpnclient_ipsec_parameters_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(vpnclient_ipsec_params, 'VpnClientIPsecParameters') + 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('VpnClientIPsecParameters', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _set_vpnclient_ipsec_parameters_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/setvpnclientipsecparameters'} # type: ignore + + def begin_set_vpnclient_ipsec_parameters( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + vpnclient_ipsec_params, # type: "_models.VpnClientIPsecParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnClientIPsecParameters"] + """The Set VpnclientIpsecParameters operation sets the vpnclient ipsec policy for P2S client of + virtual network gateway in the specified resource group through Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param vpnclient_ipsec_params: Parameters supplied to the Begin Set vpnclient ipsec parameters + of Virtual Network Gateway P2S client operation through Network resource provider. + :type vpnclient_ipsec_params: ~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnClientIPsecParameters or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + lro_delay = kwargs.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._set_vpnclient_ipsec_parameters_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_name, + vpnclient_ipsec_params=vpnclient_ipsec_params, + 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('VpnClientIPsecParameters', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_set_vpnclient_ipsec_parameters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/setvpnclientipsecparameters'} # type: ignore + + def _get_vpnclient_ipsec_parameters_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnClientIPsecParameters" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpnclient_ipsec_parameters_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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('VpnClientIPsecParameters', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpnclient_ipsec_parameters_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnclientipsecparameters'} # type: ignore + + def begin_get_vpnclient_ipsec_parameters( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnClientIPsecParameters"] + """The Get VpnclientIpsecParameters operation retrieves information about the vpnclient ipsec + policy for P2S client of virtual network gateway in the specified resource group through + Network resource provider. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The virtual network gateway name. + :type virtual_network_gateway_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 VpnClientIPsecParameters or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientIPsecParameters] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientIPsecParameters"] + lro_delay = kwargs.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._get_vpnclient_ipsec_parameters_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VpnClientIPsecParameters', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpnclient_ipsec_parameters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getvpnclientipsecparameters'} # type: ignore + + def vpn_device_configuration_script( + self, + resource_group_name, # type: str + virtual_network_gateway_connection_name, # type: str + parameters, # type: "_models.VpnDeviceScriptParameters" + **kwargs # type: Any + ): + # type: (...) -> str + """Gets a xml format representation for vpn device configuration script. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_connection_name: The name of the virtual network gateway + connection for which the configuration script is generated. + :type virtual_network_gateway_connection_name: str + :param parameters: Parameters supplied to the generate vpn device script operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnDeviceScriptParameters + :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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.vpn_device_configuration_script.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayConnectionName': self._serialize.url("virtual_network_gateway_connection_name", virtual_network_gateway_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(parameters, 'VpnDeviceScriptParameters') + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + vpn_device_configuration_script.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/connections/{virtualNetworkGatewayConnectionName}/vpndeviceconfigurationscript'} # type: ignore + + def _start_packet_capture_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnPacketCaptureStartParameters') + else: + body_content = None + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/startPacketCapture'} # type: ignore + + def begin_start_packet_capture( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Starts packet capture on virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to start packet + capture on gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/startPacketCapture'} # type: ignore + + def _stop_packet_capture_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnPacketCaptureStopParameters" + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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(parameters, 'VpnPacketCaptureStopParameters') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/stopPacketCapture'} # type: ignore + + def begin_stop_packet_capture( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + parameters, # type: "_models.VpnPacketCaptureStopParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Stops packet capture on virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param parameters: Virtual network gateway packet capture parameters supplied to stop packet + capture on gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('str', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/stopPacketCapture'} # type: ignore + + def _get_vpnclient_connection_health_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnClientConnectionHealthDetailListResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnClientConnectionHealthDetailListResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._get_vpnclient_connection_health_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnClientConnectionHealthDetailListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _get_vpnclient_connection_health_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getVpnClientConnectionHealth'} # type: ignore + + def begin_get_vpnclient_connection_health( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnClientConnectionHealthDetailListResult"] + """Get VPN client connection health detail per P2S client connection of the virtual network + gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_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 VpnClientConnectionHealthDetailListResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnClientConnectionHealthDetailListResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnClientConnectionHealthDetailListResult"] + lro_delay = kwargs.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._get_vpnclient_connection_health_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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('VpnClientConnectionHealthDetailListResult', 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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_get_vpnclient_connection_health.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/getVpnClientConnectionHealth'} # type: ignore + + def _disconnect_virtual_network_gateway_vpn_connections_initial( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._disconnect_virtual_network_gateway_vpn_connections_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'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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(request, 'P2SVpnConnectionRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _disconnect_virtual_network_gateway_vpn_connections_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/disconnectVirtualNetworkGatewayVpnConnections'} # type: ignore + + def begin_disconnect_virtual_network_gateway_vpn_connections( + self, + resource_group_name, # type: str + virtual_network_gateway_name, # type: str + request, # type: "_models.P2SVpnConnectionRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Disconnect vpn connections of virtual network gateway in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_gateway_name: The name of the virtual network gateway. + :type virtual_network_gateway_name: str + :param request: The parameters are supplied to disconnect vpn connections. + :type request: ~azure.mgmt.network.v2020_08_01.models.P2SVpnConnectionRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._disconnect_virtual_network_gateway_vpn_connections_initial( + resource_group_name=resource_group_name, + virtual_network_gateway_name=virtual_network_gateway_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkGatewayName': self._serialize.url("virtual_network_gateway_name", virtual_network_gateway_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_disconnect_virtual_network_gateway_vpn_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/disconnectVirtualNetworkGatewayVpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_peerings_operations.py new file mode 100644 index 000000000000..94c2a0a47fee --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_peerings_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 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 VirtualNetworkPeeringsOperations(object): + """VirtualNetworkPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + virtual_network_peering_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + virtual_network_peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified virtual network peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the virtual network peering. + :type virtual_network_peering_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, + virtual_network_name=virtual_network_name, + virtual_network_peering_name=virtual_network_peering_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_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.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + virtual_network_peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkPeering" + """Gets the specified virtual network peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the virtual network peering. + :type virtual_network_peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetworkPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + virtual_network_peering_name, # type: str + virtual_network_peering_parameters, # type: "_models.VirtualNetworkPeering" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkPeering" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(virtual_network_peering_parameters, 'VirtualNetworkPeering') + 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('VirtualNetworkPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + virtual_network_peering_name, # type: str + virtual_network_peering_parameters, # type: "_models.VirtualNetworkPeering" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkPeering"] + """Creates or updates a peering in the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param virtual_network_peering_name: The name of the peering. + :type virtual_network_peering_name: str + :param virtual_network_peering_parameters: Parameters supplied to the create or update virtual + network peering operation. + :type virtual_network_peering_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkPeering or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeering"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_name, + virtual_network_peering_name=virtual_network_peering_name, + virtual_network_peering_parameters=virtual_network_peering_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('VirtualNetworkPeering', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'virtualNetworkPeeringName': self._serialize.url("virtual_network_peering_name", virtual_network_peering_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings/{virtualNetworkPeeringName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkPeeringListResult"] + """Gets all virtual network peerings in a virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkPeeringListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/virtualNetworkPeerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_taps_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_taps_operations.py new file mode 100644 index 000000000000..ab0a365065b5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_network_taps_operations.py @@ -0,0 +1,552 @@ +# 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 VirtualNetworkTapsOperations(object): + """VirtualNetworkTapsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + tap_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-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + tap_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified virtual network tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the virtual network tap. + :type tap_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, + tap_name=tap_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'), + 'tapName': self._serialize.url("tap_name", tap_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.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + tap_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkTap" + """Gets information about the specified virtual network tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of virtual network tap. + :type tap_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkTap, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + tap_name, # type: str + parameters, # type: "_models.VirtualNetworkTap" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkTap" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualNetworkTap') + 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('VirtualNetworkTap', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + tap_name, # type: str + parameters, # type: "_models.VirtualNetworkTap" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetworkTap"] + """Creates or updates a Virtual Network Tap. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the virtual network tap. + :type tap_name: str + :param parameters: Parameters supplied to the create or update virtual network tap operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetworkTap or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + lro_delay = kwargs.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, + tap_name=tap_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('VirtualNetworkTap', 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'), + 'tapName': self._serialize.url("tap_name", tap_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': 'azure-async-operation'}, 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.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + tap_name, # type: str + tap_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetworkTap" + """Updates an VirtualNetworkTap tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param tap_name: The name of the tap. + :type tap_name: str + :param tap_parameters: Parameters supplied to update VirtualNetworkTap tags. + :type tap_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetworkTap, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTap + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTap"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'tapName': self._serialize.url("tap_name", tap_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(tap_parameters, 'TagsObject') + 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('VirtualNetworkTap', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkTaps/{tapName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkTapListResult"] + """Gets all the VirtualNetworkTaps 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 VirtualNetworkTapListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTapListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTapListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('VirtualNetworkTapListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/virtualNetworkTaps'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkTapListResult"] + """Gets all the VirtualNetworkTaps in a subscription. + + :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 VirtualNetworkTapListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkTapListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkTapListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualNetworkTapListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/virtualNetworkTaps'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_networks_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_networks_operations.py new file mode 100644 index 000000000000..d2af415c8a64 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_networks_operations.py @@ -0,0 +1,695 @@ +# 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 VirtualNetworksOperations(object): + """VirtualNetworksOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_network_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-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified virtual network. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_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, + virtual_network_name=virtual_network_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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_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.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetwork" + """Gets the specified virtual network by resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + parameters, # type: "_models.VirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetwork" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualNetwork') + 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('VirtualNetwork', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + parameters, # type: "_models.VirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualNetwork"] + """Creates or updates a virtual network in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param parameters: Parameters supplied to the create or update virtual network operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualNetwork or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualNetwork] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + lro_delay = kwargs.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, + virtual_network_name=virtual_network_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('VirtualNetwork', 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'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_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': 'azure-async-operation'}, 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.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualNetwork" + """Updates a virtual network tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param parameters: Parameters supplied to update virtual network tags. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'TagsObject') + 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('VirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkListResult"] + """Gets all virtual networks 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 VirtualNetworkListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('VirtualNetworkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/virtualNetworks'} # type: ignore + + def list( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkListResult"] + """Gets all virtual networks in a 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 VirtualNetworkListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/virtualNetworks'} # type: ignore + + def check_ip_address_availability( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + ip_address, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.IPAddressAvailabilityResult" + """Checks whether a private IP address is available for use. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :param ip_address: The private IP address to be verified. + :type ip_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IPAddressAvailabilityResult, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.IPAddressAvailabilityResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IPAddressAvailabilityResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self.check_ip_address_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['ipAddress'] = self._serialize.query("ip_address", ip_address, '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('IPAddressAvailabilityResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_ip_address_availability.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/CheckIPAddressAvailability'} # type: ignore + + def list_usage( + self, + resource_group_name, # type: str + virtual_network_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualNetworkListUsageResult"] + """Lists usage stats. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_network_name: The name of the virtual network. + :type virtual_network_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualNetworkListUsageResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualNetworkListUsageResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualNetworkListUsageResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usage.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualNetworkName': self._serialize.url("virtual_network_name", virtual_network_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualNetworkListUsageResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_usage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworks/{virtualNetworkName}/usages'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_router_peerings_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_router_peerings_operations.py new file mode 100644 index 000000000000..4bab9ab6bd10 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_router_peerings_operations.py @@ -0,0 +1,445 @@ +# 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 VirtualRouterPeeringsOperations(object): + """VirtualRouterPeeringsOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + peering_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-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified peering from a Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the peering. + :type peering_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, + virtual_router_name=virtual_router_name, + peering_name=peering_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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + peering_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualRouterPeering" + """Gets the specified Virtual Router Peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the Virtual Router Peering. + :type peering_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualRouterPeering, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + peering_name, # type: str + parameters, # type: "_models.VirtualRouterPeering" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualRouterPeering" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualRouterPeering') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualRouterPeering', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + peering_name, # type: str + parameters, # type: "_models.VirtualRouterPeering" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualRouterPeering"] + """Creates or updates the specified Virtual Router Peering. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param peering_name: The name of the Virtual Router Peering. + :type peering_name: str + :param parameters: Parameters supplied to the create or update Virtual Router Peering + operation. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualRouterPeering or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeering] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeering"] + lro_delay = kwargs.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, + virtual_router_name=virtual_router_name, + peering_name=peering_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('VirtualRouterPeering', 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'peeringName': self._serialize.url("peering_name", peering_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': 'azure-async-operation'}, 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.Network/virtualRouters/{virtualRouterName}/peerings/{peeringName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualRouterPeeringListResult"] + """Lists all Virtual Router Peerings in a Virtual Router resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either VirtualRouterPeeringListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterPeeringListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterPeeringListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('VirtualRouterPeeringListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters/{virtualRouterName}/peerings'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_routers_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_routers_operations.py new file mode 100644 index 000000000000..3f4ff6d8926a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_routers_operations.py @@ -0,0 +1,495 @@ +# 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 VirtualRoutersOperations(object): + """VirtualRoutersOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_router_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-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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.Error, 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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_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, + virtual_router_name=virtual_router_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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualRouter" + """Gets the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param expand: Expands referenced resources. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualRouter, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualRouter + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(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 expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + parameters, # type: "_models.VirtualRouter" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualRouter" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'VirtualRouter') + 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.Error, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualRouter', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_router_name, # type: str + parameters, # type: "_models.VirtualRouter" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualRouter"] + """Creates or updates the specified Virtual Router. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param virtual_router_name: The name of the Virtual Router. + :type virtual_router_name: str + :param parameters: Parameters supplied to the create or update Virtual Router. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualRouter + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualRouter or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualRouter] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouter"] + lro_delay = kwargs.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, + virtual_router_name=virtual_router_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('VirtualRouter', 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'), + 'virtualRouterName': self._serialize.url("virtual_router_name", virtual_router_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': 'azure-async-operation'}, 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.Network/virtualRouters/{virtualRouterName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualRouterListResult"] + """Lists all Virtual Routers in a 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 VirtualRouterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualRouterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.VirtualRouterListResult"] + """Gets all the Virtual Routers 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 VirtualRouterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.VirtualRouterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualRouterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('VirtualRouterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Error, response) + map_error(status_code=response.status_code, 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.Network/virtualRouters'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_wans_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_wans_operations.py new file mode 100644 index 000000000000..2b85b3e8420a --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_virtual_wans_operations.py @@ -0,0 +1,552 @@ +# 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 VirtualWansOperations(object): + """VirtualWansOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualWAN" + """Retrieves the details of a VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being retrieved. + :type virtual_wan_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWAN, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + wan_parameters, # type: "_models.VirtualWAN" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualWAN" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(wan_parameters, 'VirtualWAN') + 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('VirtualWAN', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + wan_parameters, # type: "_models.VirtualWAN" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VirtualWAN"] + """Creates a VirtualWAN resource if it doesn't exist else updates the existing VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being created or updated. + :type virtual_wan_name: str + :param wan_parameters: Parameters supplied to create or update VirtualWAN. + :type wan_parameters: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VirtualWAN or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VirtualWAN] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + lro_delay = kwargs.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, + virtual_wan_name=virtual_wan_name, + wan_parameters=wan_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('VirtualWAN', 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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + wan_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VirtualWAN" + """Updates a VirtualWAN tags. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being updated. + :type virtual_wan_name: str + :param wan_parameters: Parameters supplied to Update VirtualWAN tags. + :type wan_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VirtualWAN, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VirtualWAN + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VirtualWAN"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(wan_parameters, 'TagsObject') + 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('VirtualWAN', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + virtual_wan_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-08-01" + 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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VirtualWAN. + + :param resource_group_name: The resource group name of the VirtualWan. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN being deleted. + :type virtual_wan_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, + virtual_wan_name=virtual_wan_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'), + 'VirtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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.Network/virtualWans/{VirtualWANName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualWANsResult"] + """Lists all the VirtualWANs in a resource group. + + :param resource_group_name: The resource group name of the VirtualWan. + :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 ListVirtualWANsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualWANsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualWANsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVirtualWANsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/virtualWans'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVirtualWANsResult"] + """Lists all the VirtualWANs 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 ListVirtualWANsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVirtualWANsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVirtualWANsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVirtualWANsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/virtualWans'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_connections_operations.py new file mode 100644 index 000000000000..01bd7153b2f5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_connections_operations.py @@ -0,0 +1,719 @@ +# 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 VpnConnectionsOperations(object): + """VpnConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnConnection" + """Retrieves the details of a vpn connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('VpnConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + vpn_connection_parameters, # type: "_models.VpnConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnConnection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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(vpn_connection_parameters, 'VpnConnection') + 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('VpnConnection', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + vpn_connection_parameters, # type: "_models.VpnConnection" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnConnection"] + """Creates a vpn connection to a scalable vpn gateway if it doesn't exist else updates the + existing connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the connection. + :type connection_name: str + :param vpn_connection_parameters: Parameters supplied to create or Update a VPN Connection. + :type vpn_connection_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnConnection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnConnection] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnConnection"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + connection_name=connection_name, + vpn_connection_parameters=vpn_connection_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('VpnConnection', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a vpn connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the connection. + :type 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 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, + gateway_name=gateway_name, + connection_name=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): + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}'} # type: ignore + + def _start_packet_capture_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnConnectionPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnConnectionPacketCaptureStartParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/startpacketcapture'} # type: ignore + + def begin_start_packet_capture( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnConnectionPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Starts packet capture on Vpn connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_connection_name: The name of the vpn connection. + :type vpn_connection_name: str + :param parameters: Vpn Connection packet capture parameters supplied to start packet capture on + gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnectionPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_connection_name=vpn_connection_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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, 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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/startpacketcapture'} # type: ignore + + def _stop_packet_capture_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnConnectionPacketCaptureStopParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnConnectionPacketCaptureStopParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/stoppacketcapture'} # type: ignore + + def begin_stop_packet_capture( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_connection_name, # type: str + parameters=None, # type: Optional["_models.VpnConnectionPacketCaptureStopParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Stops packet capture on Vpn connection in the specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_connection_name: The name of the vpn connection. + :type vpn_connection_name: str + :param parameters: Vpn Connection packet capture parameters supplied to stop packet capture on + gateway connection. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnConnectionPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_connection_name=vpn_connection_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'vpnConnectionName': self._serialize.url("vpn_connection_name", vpn_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, 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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{vpnConnectionName}/stoppacketcapture'} # type: ignore + + def list_by_vpn_gateway( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnConnectionsResult"] + """Retrieves all vpn connections for a particular virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnConnectionsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_gateway.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('ListVpnConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_vpn_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_gateways_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_gateways_operations.py new file mode 100644 index 000000000000..a9512dc04bd5 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_gateways_operations.py @@ -0,0 +1,996 @@ +# 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 VpnGatewaysOperations(object): + """VpnGatewaysOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnGateway" + """Retrieves the details of a virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnGateway, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_gateway_parameters, # type: "_models.VpnGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnGateway" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(vpn_gateway_parameters, 'VpnGateway') + 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('VpnGateway', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_gateway_parameters, # type: "_models.VpnGateway" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnGateway"] + """Creates a virtual wan vpn gateway if it doesn't exist else updates the existing gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_gateway_parameters: Parameters supplied to create or Update a virtual wan vpn + gateway. + :type vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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, + gateway_name=gateway_name, + vpn_gateway_parameters=vpn_gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnGateways/{gatewayName}'} # type: ignore + + def _update_tags_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_tags_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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(vpn_gateway_parameters, 'TagsObject') + 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('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_tags_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + def begin_update_tags( + self, + resource_group_name, # type: str + gateway_name, # type: str + vpn_gateway_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnGateway"] + """Updates virtual wan vpn gateway tags. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param vpn_gateway_parameters: Parameters supplied to update a virtual wan vpn gateway tags. + :type vpn_gateway_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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_tags_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_name, + vpn_gateway_parameters=vpn_gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + gateway_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-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a virtual wan vpn gateway. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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, + gateway_name=gateway_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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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.Network/vpnGateways/{gatewayName}'} # type: ignore + + def _reset_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnGateway"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._reset_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _reset_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/reset'} # type: ignore + + def begin_reset( + self, + resource_group_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnGateway"] + """Resets the primary of the vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_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 VpnGateway or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnGateway] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnGateway"] + lro_delay = kwargs.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._reset_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('VpnGateway', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_reset.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/reset'} # type: ignore + + def _start_packet_capture_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnGatewayPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._start_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnGatewayPacketCaptureStartParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/startpacketcapture'} # type: ignore + + def begin_start_packet_capture( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnGatewayPacketCaptureStartParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Starts packet capture on vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param parameters: Vpn gateway packet capture parameters supplied to start packet capture on + vpn gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayPacketCaptureStartParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_start_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/startpacketcapture'} # type: ignore + + def _stop_packet_capture_initial( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnGatewayPacketCaptureStopParameters"] + **kwargs # type: Any + ): + # type: (...) -> Optional[str] + cls = kwargs.pop('cls', None) # type: ClsType[Optional[str]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._stop_packet_capture_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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] + if parameters is not None: + body_content = self._serialize.body(parameters, 'VpnGatewayPacketCaptureStopParameters') + else: + body_content = None + 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('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _stop_packet_capture_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/stoppacketcapture'} # type: ignore + + def begin_stop_packet_capture( + self, + resource_group_name, # type: str + gateway_name, # type: str + parameters=None, # type: Optional["_models.VpnGatewayPacketCaptureStopParameters"] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[str] + """Stops packet capture on vpn gateway in the specified resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param parameters: Vpn gateway packet capture parameters supplied to stop packet capture on vpn + gateway. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.VpnGatewayPacketCaptureStopParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 str or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[str] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[str] + lro_delay = kwargs.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._stop_packet_capture_initial( + resource_group_name=resource_group_name, + gateway_name=gateway_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('str', 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_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_stop_packet_capture.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/stoppacketcapture'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnGatewaysResult"] + """Lists all the VpnGateways in a resource group. + + :param resource_group_name: The resource group name of the VpnGateway. + :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 ListVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnGateways'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnGatewaysResult"] + """Lists all the VpnGateways 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 ListVpnGatewaysResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnGatewaysResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnGatewaysResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnGatewaysResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnGateways'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_link_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_link_connections_operations.py new file mode 100644 index 000000000000..4655253b4869 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_link_connections_operations.py @@ -0,0 +1,126 @@ +# 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 VpnLinkConnectionsOperations(object): + """VpnLinkConnectionsOperations 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.network.v2020_08_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_vpn_connection( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnSiteLinkConnectionsResult"] + """Retrieves all vpn site link connections for a particular virtual wan vpn gateway vpn + connection. + + :param resource_group_name: The resource group name of the vpn gateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ListVpnSiteLinkConnectionsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSiteLinkConnectionsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSiteLinkConnectionsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_connection.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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_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('ListVpnSiteLinkConnectionsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_vpn_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}/vpnLinkConnections'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.py new file mode 100644 index 000000000000..2338de915322 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_associated_with_virtual_wan_operations.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 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class VpnServerConfigurationsAssociatedWithVirtualWanOperations(object): + """VpnServerConfigurationsAssociatedWithVirtualWanOperations 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.network.v2020_08_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_initial( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VpnServerConfigurationsResponse"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VpnServerConfigurationsResponse"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + # Construct URL + url = self._list_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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.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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VpnServerConfigurationsResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnServerConfigurations'} # type: ignore + + def begin_list( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnServerConfigurationsResponse"] + """Gives the list of VpnServerConfigurations associated with Virtual Wan in a resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN whose associated VpnServerConfigurations is + needed. + :type virtual_wan_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 VpnServerConfigurationsResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnServerConfigurationsResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfigurationsResponse"] + lro_delay = kwargs.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_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_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('VpnServerConfigurationsResponse', 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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnServerConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_operations.py new file mode 100644 index 000000000000..56385dc614c2 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_server_configurations_operations.py @@ -0,0 +1,556 @@ +# 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 VpnServerConfigurationsOperations(object): + """VpnServerConfigurationsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + vpn_server_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnServerConfiguration" + """Retrieves the details of a VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being retrieved. + :type vpn_server_configuration_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnServerConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + vpn_server_configuration_name, # type: str + vpn_server_configuration_parameters, # type: "_models.VpnServerConfiguration" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnServerConfiguration" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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(vpn_server_configuration_parameters, 'VpnServerConfiguration') + 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('VpnServerConfiguration', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + vpn_server_configuration_name, # type: str + vpn_server_configuration_parameters, # type: "_models.VpnServerConfiguration" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnServerConfiguration"] + """Creates a VpnServerConfiguration resource if it doesn't exist else updates the existing + VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being created or + updated. + :type vpn_server_configuration_name: str + :param vpn_server_configuration_parameters: Parameters supplied to create or update + VpnServerConfiguration. + :type vpn_server_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnServerConfiguration or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + lro_delay = kwargs.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, + vpn_server_configuration_name=vpn_server_configuration_name, + vpn_server_configuration_parameters=vpn_server_configuration_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('VpnServerConfiguration', 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + vpn_server_configuration_name, # type: str + vpn_server_configuration_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnServerConfiguration" + """Updates VpnServerConfiguration tags. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being updated. + :type vpn_server_configuration_name: str + :param vpn_server_configuration_parameters: Parameters supplied to update + VpnServerConfiguration tags. + :type vpn_server_configuration_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnServerConfiguration, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnServerConfiguration + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnServerConfiguration"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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(vpn_server_configuration_parameters, 'TagsObject') + 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('VpnServerConfiguration', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + vpn_server_configuration_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-08-01" + 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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + vpn_server_configuration_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VpnServerConfiguration. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :type resource_group_name: str + :param vpn_server_configuration_name: The name of the VpnServerConfiguration being deleted. + :type vpn_server_configuration_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, + vpn_server_configuration_name=vpn_server_configuration_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'), + 'vpnServerConfigurationName': self._serialize.url("vpn_server_configuration_name", vpn_server_configuration_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.Network/vpnServerConfigurations/{vpnServerConfigurationName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnServerConfigurationsResult"] + """Lists all the vpnServerConfigurations in a resource group. + + :param resource_group_name: The resource group name of the VpnServerConfiguration. + :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 ListVpnServerConfigurationsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnServerConfigurationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnServerConfigurationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnServerConfigurationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnServerConfigurations'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnServerConfigurationsResult"] + """Lists all the VpnServerConfigurations 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 ListVpnServerConfigurationsResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnServerConfigurationsResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnServerConfigurationsResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnServerConfigurationsResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnServerConfigurations'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_link_connections_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_link_connections_operations.py new file mode 100644 index 000000000000..ccca6e13ae09 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_link_connections_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.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 VpnSiteLinkConnectionsOperations(object): + """VpnSiteLinkConnectionsOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + gateway_name, # type: str + connection_name, # type: str + link_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnSiteLinkConnection" + """Retrieves the details of a vpn site link connection. + + :param resource_group_name: The resource group name of the VpnGateway. + :type resource_group_name: str + :param gateway_name: The name of the gateway. + :type gateway_name: str + :param connection_name: The name of the vpn connection. + :type connection_name: str + :param link_connection_name: The name of the vpn connection. + :type link_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSiteLinkConnection, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSiteLinkConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSiteLinkConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'connectionName': self._serialize.url("connection_name", connection_name, 'str'), + 'linkConnectionName': self._serialize.url("link_connection_name", link_connection_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('VpnSiteLinkConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnGateways/{gatewayName}/vpnConnections/{connectionName}/vpnLinkConnections/{linkConnectionName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_links_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_links_operations.py new file mode 100644 index 000000000000..e25eb38d8826 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_site_links_operations.py @@ -0,0 +1,184 @@ +# 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 VpnSiteLinksOperations(object): + """VpnSiteLinksOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + vpn_site_link_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnSiteLink" + """Retrieves the details of a VPN site link. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite. + :type vpn_site_name: str + :param vpn_site_link_name: The name of the VpnSiteLink being retrieved. + :type vpn_site_link_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSiteLink, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSiteLink + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSiteLink"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_name, 'str'), + 'vpnSiteLinkName': self._serialize.url("vpn_site_link_name", vpn_site_link_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('VpnSiteLink', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}/vpnSiteLinks/{vpnSiteLinkName}'} # type: ignore + + def list_by_vpn_site( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnSiteLinksResult"] + """Lists all the vpnSiteLinks in a resource group for a vpn site. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite. + :type vpn_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 ListVpnSiteLinksResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSiteLinksResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSiteLinksResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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_vpn_site.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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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('ListVpnSiteLinksResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_vpn_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}/vpnSiteLinks'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_configuration_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_configuration_operations.py new file mode 100644 index 000000000000..81eb38eae2a8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_configuration_operations.py @@ -0,0 +1,168 @@ +# 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.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, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class VpnSitesConfigurationOperations(object): + """VpnSitesConfigurationOperations 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.network.v2020_08_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 _download_initial( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + request, # type: "_models.GetVpnSitesConfigurationRequest" + **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-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._download_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'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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(request, 'GetVpnSitesConfigurationRequest') + 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) + + if cls: + return cls(pipeline_response, None, {}) + + _download_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnConfiguration'} # type: ignore + + def begin_download( + self, + resource_group_name, # type: str + virtual_wan_name, # type: str + request, # type: "_models.GetVpnSitesConfigurationRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Gives the sas-url to download the configurations for vpn-sites in a resource group. + + :param resource_group_name: The resource group name. + :type resource_group_name: str + :param virtual_wan_name: The name of the VirtualWAN for which configuration of all vpn-sites is + needed. + :type virtual_wan_name: str + :param request: Parameters supplied to download vpn-sites configuration. + :type request: ~azure.mgmt.network.v2020_08_01.models.GetVpnSitesConfigurationRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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._download_initial( + resource_group_name=resource_group_name, + virtual_wan_name=virtual_wan_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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'virtualWANName': self._serialize.url("virtual_wan_name", virtual_wan_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_download.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualWans/{virtualWANName}/vpnConfiguration'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_operations.py new file mode 100644 index 000000000000..42dbc36d4ea6 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_vpn_sites_operations.py @@ -0,0 +1,552 @@ +# 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 VpnSitesOperations(object): + """VpnSitesOperations 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.network.v2020_08_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( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnSite" + """Retrieves the details of a VPN site. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being retrieved. + :type vpn_site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + vpn_site_parameters, # type: "_models.VpnSite" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnSite" + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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(vpn_site_parameters, 'VpnSite') + 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('VpnSite', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + vpn_site_parameters, # type: "_models.VpnSite" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.VpnSite"] + """Creates a VpnSite resource if it doesn't exist else updates the existing VpnSite. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being created or updated. + :type vpn_site_name: str + :param vpn_site_parameters: Parameters supplied to create or update VpnSite. + :type vpn_site_parameters: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :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 VpnSite or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.network.v2020_08_01.models.VpnSite] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + lro_delay = kwargs.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, + vpn_site_name=vpn_site_name, + vpn_site_parameters=vpn_site_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('VpnSite', 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'azure-async-operation'}, 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.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def update_tags( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + vpn_site_parameters, # type: "_models.TagsObject" + **kwargs # type: Any + ): + # type: (...) -> "_models.VpnSite" + """Updates VpnSite tags. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being updated. + :type vpn_site_name: str + :param vpn_site_parameters: Parameters supplied to update VpnSite tags. + :type vpn_site_parameters: ~azure.mgmt.network.v2020_08_01.models.TagsObject + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VpnSite, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.VpnSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VpnSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_tags.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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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(vpn_site_parameters, 'TagsObject') + 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('VpnSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_tags.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + vpn_site_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-08-01" + 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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + vpn_site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a VpnSite. + + :param resource_group_name: The resource group name of the VpnSite. + :type resource_group_name: str + :param vpn_site_name: The name of the VpnSite being deleted. + :type vpn_site_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, + vpn_site_name=vpn_site_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'), + 'vpnSiteName': self._serialize.url("vpn_site_name", vpn_site_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.Network/vpnSites/{vpnSiteName}'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnSitesResult"] + """Lists all the vpnSites in a resource group. + + :param resource_group_name: The resource group name of the VpnSite. + :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 ListVpnSitesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSitesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSitesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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 = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_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('ListVpnSitesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnSites'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ListVpnSitesResult"] + """Lists all the VpnSites 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 ListVpnSitesResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.ListVpnSitesResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ListVpnSitesResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('ListVpnSitesResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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.Network/vpnSites'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_application_firewall_policies_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_application_firewall_policies_operations.py new file mode 100644 index 000000000000..5aca7798331e --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_application_firewall_policies_operations.py @@ -0,0 +1,426 @@ +# 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 WebApplicationFirewallPoliciesOperations(object): + """WebApplicationFirewallPoliciesOperations 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.network.v2020_08_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_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebApplicationFirewallPolicyListResult"] + """Lists all of the protection policies within a 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 WebApplicationFirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebApplicationFirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies'} # type: ignore + + def list_all( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebApplicationFirewallPolicyListResult"] + """Gets all the WAF policies 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 WebApplicationFirewallPolicyListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicyListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicyListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_all.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('WebApplicationFirewallPolicyListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_all.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies'} # type: ignore + + def get( + self, + resource_group_name, # type: str + policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebApplicationFirewallPolicy" + """Retrieve protection policy with specified name within a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebApplicationFirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('WebApplicationFirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + policy_name, # type: str + parameters, # type: "_models.WebApplicationFirewallPolicy" + **kwargs # type: Any + ): + # type: (...) -> "_models.WebApplicationFirewallPolicy" + """Creates or update policy with specified rule set name within a resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_name: str + :param parameters: Policy to be created. + :type parameters: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebApplicationFirewallPolicy, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.WebApplicationFirewallPolicy + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebApplicationFirewallPolicy"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", 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, 'WebApplicationFirewallPolicy') + 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('WebApplicationFirewallPolicy', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('WebApplicationFirewallPolicy', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + policy_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-08-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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # 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/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + policy_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes Policy. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param policy_name: The name of the policy. + :type policy_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, + policy_name=policy_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'), + 'policyName': self._serialize.url("policy_name", policy_name, 'str', max_length=128, min_length=0), + '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.Network/ApplicationGatewayWebApplicationFirewallPolicies/{policyName}'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_categories_operations.py b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_categories_operations.py new file mode 100644 index 000000000000..890bf81eb2a0 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/operations/_web_categories_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 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 WebCategoriesOperations(object): + """WebCategoriesOperations 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.network.v2020_08_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( + self, + name, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureWebCategory" + """Gets the specified Azure Web Category. + + :param name: The name of the azureWebCategory. + :type name: str + :param expand: Expands resourceIds back referenced by the azureWebCategory resource. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureWebCategory, or the result of cls(response) + :rtype: ~azure.mgmt.network.v2020_08_01.models.AzureWebCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureWebCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-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') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = 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('AzureWebCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureWebCategories/{name}'} # type: ignore + + def list_by_subscription( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AzureWebCategoryListResult"] + """Gets all the Azure Web Categories 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 AzureWebCategoryListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.network.v2020_08_01.models.AzureWebCategoryListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureWebCategoryListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-08-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + 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('AzureWebCategoryListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(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_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Network/azureWebCategories'} # type: ignore diff --git a/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/py.typed b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/network/azure-mgmt-network/azure/mgmt/network/v2020_08_01/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base.test_network.yaml index 1d1945205ed8..8aa2e961fb11 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base.test_network.yaml @@ -14,15 +14,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipname\"\ - ,\r\n \"etag\": \"W/\\\"b3dfd7f3-3924-4c49-8774-2db48ed8548b\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"be88a908-31ce-4eaa-abf2-4018d31ed675\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Updating\",\r\n \"resourceGuid\": \"9082b456-6314-4423-9215-b389c9eae7ea\"\ + : \"Updating\",\r\n \"resourceGuid\": \"bae34df0-94e7-4e75-a700-b22df3c23353\"\ ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ @@ -31,7 +31,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e809a661-7066-4a39-8fb4-2abbb61ec725?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/081f526f-d9be-49ef-8bb4-8b5cca130eab?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +39,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:28 GMT + - Tue, 26 Jan 2021 06:54:02 GMT expires: - '-1' pragma: @@ -52,9 +52,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4226743b-5dde-4940-81c8-daf607e24185 + - b433242d-4fa4-451e-ad64-cbef0de73f2c x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1195' status: code: 201 message: Created @@ -68,9 +68,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/e809a661-7066-4a39-8fb4-2abbb61ec725?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/081f526f-d9be-49ef-8bb4-8b5cca130eab?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +82,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:30 GMT + - Tue, 26 Jan 2021 06:54:04 GMT expires: - '-1' pragma: @@ -99,7 +99,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 54b175da-9fd2-4add-8d9e-4d7f97ed2945 + - 2df72ddf-8431-41c3-8a45-1442f2d2624e status: code: 200 message: OK @@ -113,15 +113,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipname\"\ - ,\r\n \"etag\": \"W/\\\"2a2e33b9-03f7-4b47-991b-3b4b6e045ac3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5bf81bb7-5a9b-45e4-b4dd-7116d8958687\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"9082b456-6314-4423-9215-b389c9eae7ea\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"bae34df0-94e7-4e75-a700-b22df3c23353\"\ ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ @@ -134,9 +134,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:30 GMT + - Tue, 26 Jan 2021 06:54:05 GMT etag: - - W/"2a2e33b9-03f7-4b47-991b-3b4b6e045ac3" + - W/"5bf81bb7-5a9b-45e4-b4dd-7116d8958687" expires: - '-1' pragma: @@ -153,7 +153,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 359b59cd-b314-4109-89fb-7e4ce30c2b8d + - 38c1b215-dc5d-4943-88c5-ce9212337501 status: code: 200 message: OK @@ -172,16 +172,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"187f3ffa-a9a0-497a-81a0-f4f8ff8a70ea\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"b9e88e20-850f-4b3e-a51b-dca41963fb9a\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"bb8fec76-42b2-4eec-94f3-a94335f1f91b\",\r\n \"\ + \ \"resourceGuid\": \"8c1b9d02-291c-4f75-9f08-9eddc3bdc691\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -190,7 +190,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d3c50801-ddaf-4792-a118-baeab8b2cb3c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/00828b48-3d40-4666-8763-fc83281041df?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -198,7 +198,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:35 GMT + - Tue, 26 Jan 2021 06:54:10 GMT expires: - '-1' pragma: @@ -211,9 +211,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2d7d4a0b-b2f7-49c2-b107-8b23b0dcec06 + - 004d34d1-398d-498c-ab4b-02f8e8630672 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1194' status: code: 201 message: Created @@ -227,9 +227,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d3c50801-ddaf-4792-a118-baeab8b2cb3c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/00828b48-3d40-4666-8763-fc83281041df?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -241,7 +241,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:38 GMT + - Tue, 26 Jan 2021 06:54:13 GMT expires: - '-1' pragma: @@ -258,7 +258,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fb0a7f13-80e4-406d-a95f-b90fa27671ab + - d52bfc16-9621-4f90-b3c6-415f6f0281d2 status: code: 200 message: OK @@ -272,16 +272,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"a436e624-67c9-44d7-ba6d-c9b5a6e55990\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"0601b21f-dbc2-4f64-8cb1-a3ceab094771\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"bb8fec76-42b2-4eec-94f3-a94335f1f91b\",\r\n \"\ + \ \"resourceGuid\": \"8c1b9d02-291c-4f75-9f08-9eddc3bdc691\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -294,9 +294,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:38 GMT + - Tue, 26 Jan 2021 06:54:14 GMT etag: - - W/"a436e624-67c9-44d7-ba6d-c9b5a6e55990" + - W/"0601b21f-dbc2-4f64-8cb1-a3ceab094771" expires: - '-1' pragma: @@ -313,7 +313,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c9f43560-36ac-4a39-a55f-01b6c3b00ead + - 7bb215e5-729f-4392-b66a-0eb7a33af60c status: code: 200 message: OK @@ -332,16 +332,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/rmvirtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"rmvirtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"17ffb36c-c239-4023-b1c5-0effe931389d\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"8d706ac4-8e69-4a7b-afb1-a6a7d26bb366\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"856f8b46-cb1b-4905-9b19-2423a964f0d5\",\r\n \"\ + \ \"resourceGuid\": \"36e2bf7c-b57d-453d-8cc8-300cf005cd3d\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.2.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -350,7 +350,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/baa30024-90a5-4db0-b259-008a0e142859?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ac2c2cbe-af04-402b-8542-792890f6ac75?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -358,7 +358,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:43 GMT + - Tue, 26 Jan 2021 06:54:18 GMT expires: - '-1' pragma: @@ -371,9 +371,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 42582513-ed17-4b46-ba50-6a7016b13a06 + - 58b527d0-9ea7-4b6f-ba44-a243a691dffc x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1193' status: code: 201 message: Created @@ -387,9 +387,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/baa30024-90a5-4db0-b259-008a0e142859?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ac2c2cbe-af04-402b-8542-792890f6ac75?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -401,7 +401,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:46 GMT + - Tue, 26 Jan 2021 06:54:22 GMT expires: - '-1' pragma: @@ -418,7 +418,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 40f7808b-40e2-4740-9037-19fd7a246e20 + - 1b87d06a-3f7d-4e8c-bc28-3a8f9f31e5e8 status: code: 200 message: OK @@ -432,16 +432,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/rmvirtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"rmvirtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"29e5286d-9a97-476d-be7f-caf5e11b7f10\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"15c0fd4b-97ea-410f-91fa-eda0b9a7a3f7\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"856f8b46-cb1b-4905-9b19-2423a964f0d5\",\r\n \"\ + \ \"resourceGuid\": \"36e2bf7c-b57d-453d-8cc8-300cf005cd3d\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.2.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -454,9 +454,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:46 GMT + - Tue, 26 Jan 2021 06:54:22 GMT etag: - - W/"29e5286d-9a97-476d-be7f-caf5e11b7f10" + - W/"15c0fd4b-97ea-410f-91fa-eda0b9a7a3f7" expires: - '-1' pragma: @@ -473,7 +473,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 429ead88-95f5-44c6-8486-3284af1267dc + - 07f56918-e612-40b7-a978-887d5f14c73b status: code: 200 message: OK @@ -491,20 +491,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ - ,\r\n \"etag\": \"W/\\\"3ce05d4b-4dac-473c-85fd-17bd9fe12f13\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"ca771654-615c-4866-ba42-41ad51a7c8ef\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3ea9e1e4-2cb1-4184-8d93-902ba058d7c3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2c047cb9-e059-4e7d-b657-3509ea5423e2?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -512,7 +512,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:47 GMT + - Tue, 26 Jan 2021 06:54:23 GMT expires: - '-1' pragma: @@ -525,9 +525,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1d897f98-2957-44a9-ad18-ba1c34644003 + - 93e2051a-b1f3-4a63-8095-476781208ecd x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1192' status: code: 201 message: Created @@ -541,9 +541,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3ea9e1e4-2cb1-4184-8d93-902ba058d7c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2c047cb9-e059-4e7d-b657-3509ea5423e2?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -555,7 +555,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:50 GMT + - Tue, 26 Jan 2021 06:54:26 GMT expires: - '-1' pragma: @@ -572,7 +572,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2a5141e0-4ab2-4fb7-a0e0-75a066a43721 + - 5399deaf-bbb2-4a14-ac45-9ae6459edc31 status: code: 200 message: OK @@ -586,13 +586,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ - ,\r\n \"etag\": \"W/\\\"94a5a6c0-c2d3-4241-901e-c6ca2e74f4dd\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"444be512-d7dc-400e-a676-162d2661dae1\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -605,9 +605,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:51 GMT + - Tue, 26 Jan 2021 06:54:26 GMT etag: - - W/"94a5a6c0-c2d3-4241-901e-c6ca2e74f4dd" + - W/"444be512-d7dc-400e-a676-162d2661dae1" expires: - '-1' pragma: @@ -624,7 +624,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 16357d12-2458-4818-9a6d-29b52cf712e9 + - 6ee8551a-d1a0-4bb7-b8d7-42034ac96931 status: code: 200 message: OK @@ -643,18 +643,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/networkinterfacename?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkinterfacename\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename\"\ - ,\r\n \"etag\": \"W/\\\"566de90c-3430-47c4-b332-9d18a256ab30\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9bb9ec09-e8bd-47a5-abfb-96803a2f7764\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"2e46cbb4-e08a-4b7b-a885-b03e1b29b18e\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"31afba93-6560-42f8-9038-c91e07f47d2e\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"ipconfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"566de90c-3430-47c4-b332-9d18a256ab30\\\"\"\ + ,\r\n \"etag\": \"W/\\\"9bb9ec09-e8bd-47a5-abfb-96803a2f7764\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -662,7 +662,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"o1wi5o3silwe3fhtvfbtl2pzdd.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"akorxda2ff0u5hyit1o2hpogsb.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -671,7 +671,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2d4c8e9c-2705-404e-8237-e9b17e11d9fb?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/9d0d60d9-3608-45a0-8ed8-eae78b6f9754?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -679,7 +679,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 01:59:54 GMT + - Tue, 26 Jan 2021 06:54:30 GMT expires: - '-1' pragma: @@ -692,9 +692,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2891f9e4-0a80-4f26-809f-b9a15468cebf + - 3990d83c-01b3-4876-a6ff-16e59090b827 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1191' status: code: 201 message: Created @@ -708,9 +708,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2d4c8e9c-2705-404e-8237-e9b17e11d9fb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/9d0d60d9-3608-45a0-8ed8-eae78b6f9754?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -722,7 +722,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:24 GMT + - Tue, 26 Jan 2021 06:55:00 GMT expires: - '-1' pragma: @@ -739,7 +739,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7c2589cd-b4b4-4ae8-8813-df606176597a + - 54097207-45b3-42ab-82c3-d5274b26f926 status: code: 200 message: OK @@ -753,18 +753,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/networkinterfacename?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkinterfacename\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename\"\ - ,\r\n \"etag\": \"W/\\\"566de90c-3430-47c4-b332-9d18a256ab30\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9bb9ec09-e8bd-47a5-abfb-96803a2f7764\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"2e46cbb4-e08a-4b7b-a885-b03e1b29b18e\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"31afba93-6560-42f8-9038-c91e07f47d2e\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"ipconfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"566de90c-3430-47c4-b332-9d18a256ab30\\\"\"\ + ,\r\n \"etag\": \"W/\\\"9bb9ec09-e8bd-47a5-abfb-96803a2f7764\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -772,7 +772,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"o1wi5o3silwe3fhtvfbtl2pzdd.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"akorxda2ff0u5hyit1o2hpogsb.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -785,9 +785,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:25 GMT + - Tue, 26 Jan 2021 06:55:00 GMT etag: - - W/"566de90c-3430-47c4-b332-9d18a256ab30" + - W/"9bb9ec09-e8bd-47a5-abfb-96803a2f7764" expires: - '-1' pragma: @@ -804,7 +804,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 43abba06-a94c-4890-9fbe-dc29d9d091c8 + - 3313208a-98a6-4087-86d7-cbb536855185 status: code: 200 message: OK @@ -822,20 +822,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"58621280-a63b-4161-9ff1-257b4d2c796b\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"58b2c7b0-d5e7-4323-bfd2-f6404f1a56fd\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.1.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5828bad4-9544-4761-8753-3b8b9066a1ac?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d0c3c5a0-d98d-4ffb-a5a2-a5c73231af04?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -843,7 +843,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:26 GMT + - Tue, 26 Jan 2021 06:55:01 GMT expires: - '-1' pragma: @@ -856,9 +856,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8404948a-ade6-4132-a766-9320241058f7 + - cf2108e1-d433-4b50-8808-5fe08341a82e x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1190' status: code: 201 message: Created @@ -872,9 +872,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/5828bad4-9544-4761-8753-3b8b9066a1ac?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d0c3c5a0-d98d-4ffb-a5a2-a5c73231af04?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -886,7 +886,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:30 GMT + - Tue, 26 Jan 2021 06:55:05 GMT expires: - '-1' pragma: @@ -903,7 +903,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b7c66edf-29b9-4b5d-87bd-2621a13350a5 + - b67090f7-fa2a-410f-a8bc-cca676a10032 status: code: 200 message: OK @@ -917,13 +917,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"4667f4b7-6c35-466e-ba32-04cacf4f12e3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"c835df60-2e68-4f4d-be86-1ce9aa87c37d\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.1.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -936,9 +936,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:30 GMT + - Tue, 26 Jan 2021 06:55:05 GMT etag: - - W/"4667f4b7-6c35-466e-ba32-04cacf4f12e3" + - W/"c835df60-2e68-4f4d-be86-1ce9aa87c37d" expires: - '-1' pragma: @@ -955,7 +955,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ffb235ac-5994-4737-997b-1d61711fe24a + - a661852d-4e2e-488a-a67a-f218e78a3391 status: code: 200 message: OK @@ -974,16 +974,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"localnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"fd6f02d0-5d96-4a3f-977a-34c95b4c6ac3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e34920d3-1270-4d21-95e6-1db9e3e9d7c2\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/localNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"aee59323-adb2-42bb-9218-cdcc6a501b83\",\r\n \ + ,\r\n \"resourceGuid\": \"4ff99297-313d-4f49-b657-aa02bfbd7f13\",\r\n \ \ \"localNetworkAddressSpace\": {\r\n \"addressPrefixes\": [\r\n \ \ \"10.1.0.0/16\"\r\n ]\r\n },\r\n \"gatewayIpAddress\": \"\ 11.12.13.14\"\r\n }\r\n}" @@ -991,7 +991,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ae671adf-fe7a-4205-afdc-d983383c83a8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/aef261af-d30d-484c-9b81-0678c7647769?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -999,7 +999,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:34 GMT + - Tue, 26 Jan 2021 06:55:10 GMT expires: - '-1' pragma: @@ -1012,9 +1012,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 696d0572-3c9b-45e2-a381-81337a2b6302 + - 292cfb5a-23cf-472d-a2db-edf0ced18601 x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1189' status: code: 201 message: Created @@ -1028,9 +1028,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/ae671adf-fe7a-4205-afdc-d983383c83a8?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/aef261af-d30d-484c-9b81-0678c7647769?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1042,7 +1042,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:44 GMT + - Tue, 26 Jan 2021 06:55:20 GMT expires: - '-1' pragma: @@ -1059,7 +1059,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e1682a44-6318-416c-b4b6-4f74f44f6a02 + - f45d05ca-1764-4ff4-a151-0922713f7ef8 status: code: 200 message: OK @@ -1073,16 +1073,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"localnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"bbf75a06-f7b2-4d4a-a452-2457a28de066\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"20998cef-5af6-4ff6-97b2-fe010f905380\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/localNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"aee59323-adb2-42bb-9218-cdcc6a501b83\",\r\n \ + ,\r\n \"resourceGuid\": \"4ff99297-313d-4f49-b657-aa02bfbd7f13\",\r\n \ \ \"localNetworkAddressSpace\": {\r\n \"addressPrefixes\": [\r\n \ \ \"10.1.0.0/16\"\r\n ]\r\n },\r\n \"gatewayIpAddress\": \"\ 11.12.13.14\"\r\n }\r\n}" @@ -1094,9 +1094,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:45 GMT + - Tue, 26 Jan 2021 06:55:21 GMT etag: - - W/"bbf75a06-f7b2-4d4a-a452-2457a28de066" + - W/"20998cef-5af6-4ff6-97b2-fe010f905380" expires: - '-1' pragma: @@ -1113,7 +1113,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 65c98ee5-f351-462b-8696-b0b78e58426c + - a26d0fe2-b602-4a17-b55e-03e47e1ccb71 status: code: 200 message: OK @@ -1137,20 +1137,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"c250b76a-7539-49e2-838d-999b4ee306c3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"bdbb8e57-eb58-45fa-92c8-d7079806eabe\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\",\r\n \ + ,\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"c250b76a-7539-49e2-838d-999b4ee306c3\\\"\"\ + ,\r\n \"etag\": \"W/\\\"bdbb8e57-eb58-45fa-92c8-d7079806eabe\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -1176,7 +1176,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1184,7 +1184,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:00:51 GMT + - Tue, 26 Jan 2021 06:55:25 GMT expires: - '-1' pragma: @@ -1197,9 +1197,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f5672564-3051-492f-9d90-ccca1370709a + - fdbb0ff1-4858-4990-b01c-2d2516b69546 x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1188' status: code: 201 message: Created @@ -1213,9 +1213,54 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 06:55:35 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 63db913b-a618-44a6-b76f-ab6d21c22432 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1227,7 +1272,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:01:01 GMT + - Tue, 26 Jan 2021 06:55:45 GMT expires: - '-1' pragma: @@ -1244,7 +1289,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - aec301d8-60c4-4af9-9726-8a8441f8bd0d + - d15078f5-94e1-468c-a18e-1c63c76f6628 status: code: 200 message: OK @@ -1258,9 +1303,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1272,7 +1317,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:01:11 GMT + - Tue, 26 Jan 2021 06:56:06 GMT expires: - '-1' pragma: @@ -1289,7 +1334,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2a90b194-626b-4b48-a18f-24d625bcc94f + - 0a772ce9-fa53-463c-b7ad-bc1e78ff1a95 status: code: 200 message: OK @@ -1303,9 +1348,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1317,7 +1362,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:01:32 GMT + - Tue, 26 Jan 2021 06:56:26 GMT expires: - '-1' pragma: @@ -1334,7 +1379,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4e36cf87-2f46-43fb-9f4b-4f88a2777e72 + - 62358c23-2e74-4983-a26c-161450ad1f69 status: code: 200 message: OK @@ -1348,9 +1393,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1362,7 +1407,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:01:53 GMT + - Tue, 26 Jan 2021 06:57:07 GMT expires: - '-1' pragma: @@ -1379,7 +1424,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - defb46b3-5091-4499-9150-ecdd402830e9 + - 423937a5-c85d-49c9-a6ca-d7cdd8903897 status: code: 200 message: OK @@ -1393,9 +1438,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1407,7 +1452,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:02:33 GMT + - Tue, 26 Jan 2021 06:57:48 GMT expires: - '-1' pragma: @@ -1424,7 +1469,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - eb5254b4-d290-46a3-bfa9-7b5f99e3fe07 + - f03209c5-2603-4af1-a0c9-3b8d5a6ab03b status: code: 200 message: OK @@ -1438,9 +1483,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1452,7 +1497,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:03:13 GMT + - Tue, 26 Jan 2021 06:59:09 GMT expires: - '-1' pragma: @@ -1469,7 +1514,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2f7a8829-1a8e-44ce-b10a-3e487268f6f0 + - f53ec8e0-b64c-434a-9c77-90f6ee4e2355 status: code: 200 message: OK @@ -1483,9 +1528,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1497,7 +1542,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:04:35 GMT + - Tue, 26 Jan 2021 07:01:50 GMT expires: - '-1' pragma: @@ -1514,7 +1559,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - be833e73-0d7d-499d-92bb-bfd223f34eb5 + - 1e4e5602-f269-41ed-a796-e658ac892e2e status: code: 200 message: OK @@ -1528,9 +1573,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1542,7 +1587,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:07:16 GMT + - Tue, 26 Jan 2021 07:03:30 GMT expires: - '-1' pragma: @@ -1559,7 +1604,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 53fccd3b-10c4-42d3-91e4-60fc8dc6e73a + - baa74826-e9de-4668-b6fc-1aabb7056f24 status: code: 200 message: OK @@ -1573,9 +1618,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1587,7 +1632,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:08:57 GMT + - Tue, 26 Jan 2021 07:05:11 GMT expires: - '-1' pragma: @@ -1604,7 +1649,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 166e9029-584c-474d-bdc4-af04d37093ca + - ecd6547b-bfa5-4a3b-9d2d-f02e6333a0f4 status: code: 200 message: OK @@ -1618,9 +1663,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1632,7 +1677,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:10:38 GMT + - Tue, 26 Jan 2021 07:06:52 GMT expires: - '-1' pragma: @@ -1649,7 +1694,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 32cd8abc-6932-48f9-8ba8-fb3aa75f1ed8 + - 23c96ee6-4a9a-48e9-bea7-154f8609de66 status: code: 200 message: OK @@ -1663,9 +1708,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1677,7 +1722,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:12:19 GMT + - Tue, 26 Jan 2021 07:08:32 GMT expires: - '-1' pragma: @@ -1694,7 +1739,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2233e401-054f-4cb6-be97-f4daa2c12c07 + - f4ce080c-af0d-4275-83e0-199ed0a367e5 status: code: 200 message: OK @@ -1708,9 +1753,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1722,7 +1767,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:14:00 GMT + - Tue, 26 Jan 2021 07:10:13 GMT expires: - '-1' pragma: @@ -1739,7 +1784,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 580a5321-c12e-4cf8-8899-6a9ca3e7d1cf + - 65ba397d-dbea-4053-8c6e-32fc3b53d29a status: code: 200 message: OK @@ -1753,9 +1798,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1767,7 +1812,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:15:41 GMT + - Tue, 26 Jan 2021 07:11:53 GMT expires: - '-1' pragma: @@ -1784,7 +1829,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a830ac5a-dc1f-4207-90ba-0f31ad596ce9 + - c86d360d-c019-45ee-aa89-0ff12f791e2e status: code: 200 message: OK @@ -1798,9 +1843,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1812,7 +1857,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:17:23 GMT + - Tue, 26 Jan 2021 07:13:33 GMT expires: - '-1' pragma: @@ -1829,7 +1874,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8d5fa7b4-eca1-4eb1-8f68-3893dd76feb2 + - 1e4ec366-4637-4511-9bd5-a7959032d9d5 status: code: 200 message: OK @@ -1843,9 +1888,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1857,7 +1902,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:19:04 GMT + - Tue, 26 Jan 2021 07:15:14 GMT expires: - '-1' pragma: @@ -1874,7 +1919,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bfa91dfa-4639-4e51-a018-d6b5b8445893 + - a437e743-0689-4eef-b496-ef5d4802c6c5 status: code: 200 message: OK @@ -1888,9 +1933,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a3e33a97-bcb2-4b96-8497-b1417e981711?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db288662-2c2d-4ad0-baee-8e7763c2a9f8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1902,7 +1947,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:20:44 GMT + - Tue, 26 Jan 2021 07:16:54 GMT expires: - '-1' pragma: @@ -1919,7 +1964,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5ce9f139-68f6-4cd8-bb55-3b235e16eb87 + - 6022524c-aab8-44e7-90a9-0ca498ec16f6 status: code: 200 message: OK @@ -1933,20 +1978,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"fc4ffc05-82f9-43b6-a8cf-e82b6438b905\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5d50f351-38a0-4bd6-8f60-a395f563b3eb\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\",\r\n \ + ,\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"fc4ffc05-82f9-43b6-a8cf-e82b6438b905\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d50f351-38a0-4bd6-8f60-a395f563b3eb\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -1961,7 +2006,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -1973,7 +2018,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:20:45 GMT + - Tue, 26 Jan 2021 07:16:54 GMT expires: - '-1' pragma: @@ -1990,7 +2035,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 51d4865c-9094-451a-96a7-5458939bfcb4 + - 3eb643c0-88cd-498e-86c0-752a8e400e9d status: code: 200 message: OK @@ -2010,15 +2055,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkpeeringname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname\"\ - ,\r\n \"etag\": \"W/\\\"b246a465-ac3b-4c9d-bca1-cc5bb9fb0a01\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"f7756b68-4031-4b56-a44e-514b3044ed9e\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ - resourceGuid\": \"3ee06730-89a9-07e9-0fea-8d609c9509ce\",\r\n \"peeringState\"\ + resourceGuid\": \"baf9227e-9c61-0a48-13c0-aed133b80bac\",\r\n \"peeringState\"\ : \"Initiated\",\r\n \"remoteVirtualNetwork\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ \r\n },\r\n \"allowVirtualNetworkAccess\": true,\r\n \"allowForwardedTraffic\"\ : true,\r\n \"allowGatewayTransit\": false,\r\n \"useRemoteGateways\"\ @@ -2028,7 +2073,7 @@ interactions: \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/27d1726c-d836-4c67-88fd-4102d38b4360?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/52cf08a3-1705-4397-8e26-99e6f0138072?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -2036,7 +2081,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:20:45 GMT + - Tue, 26 Jan 2021 07:16:55 GMT expires: - '-1' pragma: @@ -2049,9 +2094,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 19d4d264-2e29-41e6-ac15-1752b4be6fef + - 8aff5e2f-e26b-4588-9f4d-96c0cdc6ecc9 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1187' status: code: 201 message: Created @@ -2065,9 +2110,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/27d1726c-d836-4c67-88fd-4102d38b4360?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/52cf08a3-1705-4397-8e26-99e6f0138072?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2079,7 +2124,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:20:57 GMT + - Tue, 26 Jan 2021 07:17:05 GMT expires: - '-1' pragma: @@ -2096,7 +2141,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 84eee199-a71d-40fd-b7db-f9681e206b4c + - 60b1807b-f000-4222-8d9f-dc3ae0401ec9 status: code: 200 message: OK @@ -2110,15 +2155,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkpeeringname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname\"\ - ,\r\n \"etag\": \"W/\\\"d7c18eb9-2204-4174-8ced-b0be2f2678fb\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d8ae6208-9918-410c-a751-f0b1d47de050\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"3ee06730-89a9-07e9-0fea-8d609c9509ce\",\r\n \"peeringState\"\ + resourceGuid\": \"baf9227e-9c61-0a48-13c0-aed133b80bac\",\r\n \"peeringState\"\ : \"Initiated\",\r\n \"remoteVirtualNetwork\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ \r\n },\r\n \"allowVirtualNetworkAccess\": true,\r\n \"allowForwardedTraffic\"\ : true,\r\n \"allowGatewayTransit\": false,\r\n \"useRemoteGateways\"\ @@ -2134,9 +2179,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:20:57 GMT + - Tue, 26 Jan 2021 07:17:05 GMT etag: - - W/"d7c18eb9-2204-4174-8ced-b0be2f2678fb" + - W/"d8ae6208-9918-410c-a751-f0b1d47de050" expires: - '-1' pragma: @@ -2153,7 +2198,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ba624807-42bf-485b-885c-2fe4570e0516 + - 0576770d-ef08-40f7-b8d5-bedc191082a1 status: code: 200 message: OK @@ -2184,16 +2229,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname\"\ - ,\r\n \"etag\": \"W/\\\"b26e4f53-5834-435a-8f4e-285b03763481\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9098b325-ceac-402b-8209-2071d674e055\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/connections\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"22700540-3e87-4b27-af6a-2fe29916f639\",\r\n \"\ + \ \"resourceGuid\": \"313afaca-ea58-4f00-8257-6373069a96f7\",\r\n \"\ packetCaptureDiagnosticState\": \"None\",\r\n \"virtualNetworkGateway1\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ \r\n },\r\n \"localNetworkGateway2\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ @@ -2209,7 +2254,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/caffbe12-97ce-4bf5-8a83-7e35b6c74420?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad67d1ed-d741-42a9-93d2-441138541deb?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -2217,7 +2262,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:05 GMT + - Tue, 26 Jan 2021 07:17:13 GMT expires: - '-1' pragma: @@ -2230,9 +2275,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fcd235fa-a56e-4548-8133-11be22a3ac20 + - b29be8eb-42e7-48bf-b15c-0cf324eee719 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1186' status: code: 201 message: Created @@ -2246,9 +2291,99 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/ad67d1ed-d741-42a9-93d2-441138541deb?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:17:24 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - fd9df503-795f-42d5-a726-e0f0eb0d2dad + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/ad67d1ed-d741-42a9-93d2-441138541deb?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:17:35 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - ab2ed817-b077-4021-99d4-0213d3f69385 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/caffbe12-97ce-4bf5-8a83-7e35b6c74420?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad67d1ed-d741-42a9-93d2-441138541deb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2260,7 +2395,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:15 GMT + - Tue, 26 Jan 2021 07:17:56 GMT expires: - '-1' pragma: @@ -2277,7 +2412,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 51e594c6-311c-4c73-bc6e-f3b1ec71dd6a + - 796c27ec-7653-4a32-ad19-6b0e51e7b89f status: code: 200 message: OK @@ -2291,16 +2426,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname\"\ - ,\r\n \"etag\": \"W/\\\"6a885595-0172-4b24-a563-0c13870c50ca\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"654adb05-0af7-4b7f-b745-20a58a8b486f\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/connections\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"22700540-3e87-4b27-af6a-2fe29916f639\",\r\n \"\ + \ \"resourceGuid\": \"313afaca-ea58-4f00-8257-6373069a96f7\",\r\n \"\ packetCaptureDiagnosticState\": \"None\",\r\n \"virtualNetworkGateway1\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ \r\n },\r\n \"localNetworkGateway2\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ @@ -2320,7 +2455,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:16 GMT + - Tue, 26 Jan 2021 07:17:56 GMT expires: - '-1' pragma: @@ -2337,7 +2472,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ab51b994-5e5e-4764-b51e-9b9b754cd9e9 + - cb4a6249-b0d5-408c-896f-4093ec9ac52c status: code: 200 message: OK @@ -2355,21 +2490,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname/sharedkey?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname/sharedkey?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f303797b-a09b-4c57-9fd8-a3dfe62a7124?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/57c6a1d8-dab4-4fcf-b91e-db4a83461e8e?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:21:16 GMT + - Tue, 26 Jan 2021 07:17:57 GMT expires: - '-1' pragma: @@ -2382,9 +2517,99 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c4c55f03-9f23-4b2e-8e2a-82802b2ef7c0 + - 549f72a3-4ff7-4ce4-9245-4923df59a4ef x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1185' + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/57c6a1d8-dab4-4fcf-b91e-db4a83461e8e?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:18:07 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - a2080c17-807e-4a30-ada6-cff7e98654f0 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/57c6a1d8-dab4-4fcf-b91e-db4a83461e8e?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:18:18 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 63f9416b-353d-4cbc-ab2b-0036f7abe173 status: code: 200 message: OK @@ -2398,9 +2623,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f303797b-a09b-4c57-9fd8-a3dfe62a7124?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/57c6a1d8-dab4-4fcf-b91e-db4a83461e8e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2412,7 +2637,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:26 GMT + - Tue, 26 Jan 2021 07:18:38 GMT expires: - '-1' pragma: @@ -2429,7 +2654,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 48d3c759-bbd3-4512-8d60-93bbfe228754 + - 48adbe59-6e7d-459a-8ef3-cfb3bd38e977 status: code: 200 message: OK @@ -2443,9 +2668,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname/sharedkey?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname/sharedkey?api-version=2020-08-01 response: body: string: "{\r\n \"value\": \"AzureAbc123\"\r\n}" @@ -2457,7 +2682,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:27 GMT + - Tue, 26 Jan 2021 07:18:39 GMT expires: - '-1' pragma: @@ -2474,7 +2699,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ea0d7e83-6cf3-4425-a5ad-11c6b0a656dd + - 2ef549f4-10d9-4710-87b6-54c5555ca305 status: code: 200 message: OK @@ -2488,15 +2713,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkpeeringname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname\"\ - ,\r\n \"etag\": \"W/\\\"d7c18eb9-2204-4174-8ced-b0be2f2678fb\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d8ae6208-9918-410c-a751-f0b1d47de050\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"3ee06730-89a9-07e9-0fea-8d609c9509ce\",\r\n \"peeringState\"\ + resourceGuid\": \"baf9227e-9c61-0a48-13c0-aed133b80bac\",\r\n \"peeringState\"\ : \"Initiated\",\r\n \"remoteVirtualNetwork\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ \r\n },\r\n \"allowVirtualNetworkAccess\": true,\r\n \"allowForwardedTraffic\"\ : true,\r\n \"allowGatewayTransit\": false,\r\n \"useRemoteGateways\"\ @@ -2512,9 +2737,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:27 GMT + - Tue, 26 Jan 2021 07:18:40 GMT etag: - - W/"d7c18eb9-2204-4174-8ced-b0be2f2678fb" + - W/"d8ae6208-9918-410c-a751-f0b1d47de050" expires: - '-1' pragma: @@ -2531,7 +2756,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8511fd60-7486-41e3-9d4f-7482b14f7386 + - 3a26439a-99fc-421a-816f-ccc730df282a status: code: 200 message: OK @@ -2545,9 +2770,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname/ServiceAssociationLinks?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname/ServiceAssociationLinks?api-version=2020-08-01 response: body: string: "{\r\n \"value\": []\r\n}" @@ -2559,7 +2784,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:27 GMT + - Tue, 26 Jan 2021 07:18:40 GMT expires: - '-1' pragma: @@ -2576,7 +2801,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - dc07179c-3697-4940-b7e4-81aaadb1f70e + - 76e6b160-8bb8-4265-be6c-65c762205a41 status: code: 200 message: OK @@ -2590,9 +2815,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname/ResourceNavigationLinks?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname/ResourceNavigationLinks?api-version=2020-08-01 response: body: string: "{\r\n \"value\": []\r\n}" @@ -2604,7 +2829,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:28 GMT + - Tue, 26 Jan 2021 07:18:40 GMT expires: - '-1' pragma: @@ -2621,7 +2846,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 443782f3-b10c-4a60-942e-725ebd4910ea + - 1038dd4e-9e62-4e3e-a370-28e791ee333c status: code: 200 message: OK @@ -2635,9 +2860,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.1.4&api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.1.4&api-version=2020-08-01 response: body: string: "{\r\n \"available\": true,\r\n \"isPlatformReserved\": false\r\n}" @@ -2649,7 +2874,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:28 GMT + - Tue, 26 Jan 2021 07:18:41 GMT expires: - '-1' pragma: @@ -2666,7 +2891,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 381eaff0-5ccb-4f58-8827-153ef30fe744 + - 623adb12-d09e-431a-89a8-08e3c2440949 status: code: 200 message: OK @@ -2680,13 +2905,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ - ,\r\n \"etag\": \"W/\\\"1c68f7b2-ab9d-42e1-85b9-4a464b21646f\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f031866-bc75-4846-a8c3-ed36f184cb1a\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"networkSecurityGroup\": {\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/virtualnetworkname-subnetname-NRMS\"\ @@ -2703,9 +2928,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:28 GMT + - Tue, 26 Jan 2021 07:18:41 GMT etag: - - W/"1c68f7b2-ab9d-42e1-85b9-4a464b21646f" + - W/"1f031866-bc75-4846-a8c3-ed36f184cb1a" expires: - '-1' pragma: @@ -2722,7 +2947,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9830716d-f9db-4c08-8cd2-b94f2c26fd62 + - 9d15bed6-c839-46f2-939a-263830c955ab status: code: 200 message: OK @@ -2736,20 +2961,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"ac932b4b-1178-40b8-a4ef-afdb769b2e38\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"4879f9c2-5c1e-4d70-92d5-b5eba65f88a4\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\",\r\n \ + ,\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"ac932b4b-1178-40b8-a4ef-afdb769b2e38\\\"\"\ + ,\r\n \"etag\": \"W/\\\"4879f9c2-5c1e-4d70-92d5-b5eba65f88a4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -2764,7 +2989,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -2776,7 +3001,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:29 GMT + - Tue, 26 Jan 2021 07:18:41 GMT expires: - '-1' pragma: @@ -2793,7 +3018,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 691caecd-1159-45b5-b13a-d2864c13b9b6 + - 399c0656-7885-4859-8cb0-0199cc6e851a status: code: 200 message: OK @@ -2807,16 +3032,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"localnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"bbf75a06-f7b2-4d4a-a452-2457a28de066\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"20998cef-5af6-4ff6-97b2-fe010f905380\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/localNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"aee59323-adb2-42bb-9218-cdcc6a501b83\",\r\n \ + ,\r\n \"resourceGuid\": \"4ff99297-313d-4f49-b657-aa02bfbd7f13\",\r\n \ \ \"localNetworkAddressSpace\": {\r\n \"addressPrefixes\": [\r\n \ \ \"10.1.0.0/16\"\r\n ]\r\n },\r\n \"gatewayIpAddress\": \"\ 11.12.13.14\"\r\n }\r\n}" @@ -2828,9 +3053,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:29 GMT + - Tue, 26 Jan 2021 07:18:42 GMT etag: - - W/"bbf75a06-f7b2-4d4a-a452-2457a28de066" + - W/"20998cef-5af6-4ff6-97b2-fe010f905380" expires: - '-1' pragma: @@ -2847,7 +3072,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7d3807fc-6933-4468-a329-29d179e3499f + - 5c627094-7394-48af-ad46-eb74eb58e4f9 status: code: 200 message: OK @@ -2861,9 +3086,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname/sharedkey?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname/sharedkey?api-version=2020-08-01 response: body: string: "{\r\n \"value\": \"AzureAbc123\"\r\n}" @@ -2875,7 +3100,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:30 GMT + - Tue, 26 Jan 2021 07:18:42 GMT expires: - '-1' pragma: @@ -2892,7 +3117,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5cd8af5a-510e-4ba9-8af8-e1c579a5ee91 + - 91ca5b88-eb82-432e-adc2-914d44545443 status: code: 200 message: OK @@ -2906,20 +3131,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"1c68f7b2-ab9d-42e1-85b9-4a464b21646f\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f031866-bc75-4846-a8c3-ed36f184cb1a\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"bb8fec76-42b2-4eec-94f3-a94335f1f91b\",\r\n \"\ + \ \"resourceGuid\": \"8c1b9d02-291c-4f75-9f08-9eddc3bdc691\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [\r\n {\r\n \"name\"\ : \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"1c68f7b2-ab9d-42e1-85b9-4a464b21646f\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f031866-bc75-4846-a8c3-ed36f184cb1a\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"addressPrefix\": \"10.0.1.0/24\",\r\n \"ipConfigurations\"\ : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ @@ -2928,7 +3153,7 @@ interactions: privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n },\r\n\ \ {\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ - ,\r\n \"etag\": \"W/\\\"1c68f7b2-ab9d-42e1-85b9-4a464b21646f\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f031866-bc75-4846-a8c3-ed36f184cb1a\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n \"networkSecurityGroup\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/virtualnetworkname-subnetname-NRMS\"\ @@ -2940,9 +3165,9 @@ interactions: \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n }\r\n \ \ ],\r\n \"virtualNetworkPeerings\": [\r\n {\r\n \"name\"\ : \"virtualnetworkpeeringname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname\"\ - ,\r\n \"etag\": \"W/\\\"1c68f7b2-ab9d-42e1-85b9-4a464b21646f\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f031866-bc75-4846-a8c3-ed36f184cb1a\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"3ee06730-89a9-07e9-0fea-8d609c9509ce\"\ + ,\r\n \"resourceGuid\": \"baf9227e-9c61-0a48-13c0-aed133b80bac\"\ ,\r\n \"peeringState\": \"Initiated\",\r\n \"remoteVirtualNetwork\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ \r\n },\r\n \"allowVirtualNetworkAccess\": true,\r\n \ @@ -2962,9 +3187,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:30 GMT + - Tue, 26 Jan 2021 07:18:42 GMT etag: - - W/"1c68f7b2-ab9d-42e1-85b9-4a464b21646f" + - W/"1f031866-bc75-4846-a8c3-ed36f184cb1a" expires: - '-1' pragma: @@ -2981,7 +3206,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f171bea8-aa20-4dfa-82ef-734edf29c6a5 + - e01af9d2-5e3d-4300-b393-713f12f276e5 status: code: 200 message: OK @@ -2995,16 +3220,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname\"\ - ,\r\n \"etag\": \"W/\\\"3665fc83-4aa4-4284-a978-4a6bfad27aac\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7d04a450-154e-435a-8cc6-4201b408fa6b\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/connections\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"22700540-3e87-4b27-af6a-2fe29916f639\",\r\n \"\ + \ \"resourceGuid\": \"313afaca-ea58-4f00-8257-6373069a96f7\",\r\n \"\ packetCaptureDiagnosticState\": \"None\",\r\n \"virtualNetworkGateway1\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ \r\n },\r\n \"localNetworkGateway2\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ @@ -3024,7 +3249,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:31 GMT + - Tue, 26 Jan 2021 07:18:43 GMT expires: - '-1' pragma: @@ -3041,7 +3266,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d710ba97-879e-4540-bead-bd56246bcdeb + - 66acd127-9704-4c0e-ba99-4a200fddfc44 status: code: 200 message: OK @@ -3057,9 +3282,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname/getAdvertisedRoutes?peer=10.0.0.2&api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/getAdvertisedRoutes?peer=10.0.0.2&api-version=2020-08-01 response: body: string: 'null' @@ -3071,11 +3296,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:31 GMT + - Tue, 26 Jan 2021 07:18:43 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b7c2a9fc-6b67-4f55-ae1b-bc580a707d64?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8e8588e3-a25d-491a-a1d6-6aee1cf9f8db?api-version=2020-08-01 pragma: - no-cache server: @@ -3086,7 +3311,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c6c54da5-13ee-4d98-bb4c-6505fa36f1d4 + - 78989f54-9283-4cfa-b9fd-e5b362ce9766 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -3102,9 +3327,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/b7c2a9fc-6b67-4f55-ae1b-bc580a707d64?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8e8588e3-a25d-491a-a1d6-6aee1cf9f8db?api-version=2020-08-01 response: body: string: "{\r\n \"value\": [\r\n {\r\n \"localAddress\": \"\",\r\n \ @@ -3119,11 +3344,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:41 GMT + - Tue, 26 Jan 2021 07:18:54 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b7c2a9fc-6b67-4f55-ae1b-bc580a707d64?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8e8588e3-a25d-491a-a1d6-6aee1cf9f8db?api-version=2020-08-01 pragma: - no-cache server: @@ -3138,7 +3363,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c6c54da5-13ee-4d98-bb4c-6505fa36f1d4 + - 78989f54-9283-4cfa-b9fd-e5b362ce9766 status: code: 200 message: OK @@ -3154,9 +3379,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname/getBgpPeerStatus?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/getBgpPeerStatus?api-version=2020-08-01 response: body: string: 'null' @@ -3168,11 +3393,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:42 GMT + - Tue, 26 Jan 2021 07:18:55 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b0ea8191-7e3b-4ffb-80c3-f14da89f87a7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/25493c11-6ebc-4990-b143-706e1e4da35f?api-version=2020-08-01 pragma: - no-cache server: @@ -3183,7 +3408,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b4104edb-a690-4190-a55f-9f42c8cfcea4 + - d0f675d6-cddb-4b5a-a4a3-54d064815717 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -3199,9 +3424,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/b0ea8191-7e3b-4ffb-80c3-f14da89f87a7?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/25493c11-6ebc-4990-b143-706e1e4da35f?api-version=2020-08-01 response: body: string: "{\r\n \"value\": []\r\n}" @@ -3213,11 +3438,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:52 GMT + - Tue, 26 Jan 2021 07:19:05 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b0ea8191-7e3b-4ffb-80c3-f14da89f87a7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/25493c11-6ebc-4990-b143-706e1e4da35f?api-version=2020-08-01 pragma: - no-cache server: @@ -3232,7 +3457,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b4104edb-a690-4190-a55f-9f42c8cfcea4 + - d0f675d6-cddb-4b5a-a4a3-54d064815717 status: code: 200 message: OK @@ -3248,9 +3473,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname/getLearnedRoutes?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/getLearnedRoutes?api-version=2020-08-01 response: body: string: 'null' @@ -3262,11 +3487,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:21:53 GMT + - Tue, 26 Jan 2021 07:19:06 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/677f071b-8eb4-4436-bc02-3b6cea2379d1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/6d6f8b8f-6419-4b13-bffe-688dc7015d70?api-version=2020-08-01 pragma: - no-cache server: @@ -3277,7 +3502,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 954851b8-8519-4b2b-b025-88fe703c8c8b + - c3689613-339c-4a88-b8fb-cab1cf218a47 x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -3293,9 +3518,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/677f071b-8eb4-4436-bc02-3b6cea2379d1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/6d6f8b8f-6419-4b13-bffe-688dc7015d70?api-version=2020-08-01 response: body: string: "{\r\n \"value\": []\r\n}" @@ -3307,11 +3532,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:03 GMT + - Tue, 26 Jan 2021 07:19:16 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/677f071b-8eb4-4436-bc02-3b6cea2379d1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/6d6f8b8f-6419-4b13-bffe-688dc7015d70?api-version=2020-08-01 pragma: - no-cache server: @@ -3326,7 +3551,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 954851b8-8519-4b2b-b025-88fe703c8c8b + - c3689613-339c-4a88-b8fb-cab1cf218a47 status: code: 200 message: OK @@ -3344,25 +3569,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname/sharedkey/reset?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname/sharedkey/reset?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:22:04 GMT + - Tue, 26 Jan 2021 07:19:17 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 pragma: - no-cache server: @@ -3373,7 +3598,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 598a1216-b96a-4314-8a68-c6d07dcac6d0 + - fa284c48-b834-467d-af88-946d071cd206 x-ms-ratelimit-remaining-subscription-writes: - '1196' status: @@ -3389,9 +3614,99 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:19:27 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - e9f93d17-57ae-4964-9a2b-f6288cdcd34f + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:19:38 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 6c6efcc0-75ae-4026-ac81-58052f3b310f + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -3403,7 +3718,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:14 GMT + - Tue, 26 Jan 2021 07:19:59 GMT expires: - '-1' pragma: @@ -3420,7 +3735,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 16aed83f-27d3-41e9-86aa-632541728305 + - 6d8e6694-32dd-4c88-91b0-917cdcdf2af2 status: code: 200 message: OK @@ -3434,15 +3749,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -3450,11 +3765,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:15 GMT + - Tue, 26 Jan 2021 07:19:59 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/a8d5a59b-7c2c-4f22-bc66-a61ed09bab45?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f0669143-378f-4ebf-8352-da2c5a2fc968?api-version=2020-08-01 pragma: - no-cache server: @@ -3469,7 +3784,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 598a1216-b96a-4314-8a68-c6d07dcac6d0 + - fa284c48-b834-467d-af88-946d071cd206 status: code: 200 message: OK @@ -3485,25 +3800,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname/reset?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/reset?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:22:15 GMT + - Tue, 26 Jan 2021 07:20:00 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 pragma: - no-cache server: @@ -3514,7 +3829,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0b889b5c-25de-487d-ab03-44c808e945d9 + - eb2951a7-a906-48b9-ac09-bc315a0959ce x-ms-ratelimit-remaining-subscription-writes: - '1195' status: @@ -3530,9 +3845,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3544,7 +3859,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:25 GMT + - Tue, 26 Jan 2021 07:20:11 GMT expires: - '-1' pragma: @@ -3561,7 +3876,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8fd38731-3f84-4e15-8699-0a6ed0725011 + - ee22d1cb-6ca7-42ef-9392-3101ffecadd7 status: code: 200 message: OK @@ -3575,9 +3890,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3589,7 +3904,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:36 GMT + - Tue, 26 Jan 2021 07:20:21 GMT expires: - '-1' pragma: @@ -3606,7 +3921,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b87a2480-f2b1-48f2-ba01-67eb922e9b32 + - 05aca5dc-c539-4c73-95f3-9139dbc31f03 status: code: 200 message: OK @@ -3620,9 +3935,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3634,7 +3949,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:22:57 GMT + - Tue, 26 Jan 2021 07:20:41 GMT expires: - '-1' pragma: @@ -3651,7 +3966,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 88c25dd6-7884-432e-8d7c-49db36be6d64 + - e849ba18-15a2-4317-94a4-7133c6d3b881 status: code: 200 message: OK @@ -3665,9 +3980,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3679,7 +3994,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:23:37 GMT + - Tue, 26 Jan 2021 07:21:21 GMT expires: - '-1' pragma: @@ -3696,7 +4011,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3d5c285a-cb74-4260-bfd9-80bbaf8aa3ea + - f36120f4-2840-4482-afc1-5fffcfeddaa4 status: code: 200 message: OK @@ -3710,9 +4025,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3724,7 +4039,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:24:57 GMT + - Tue, 26 Jan 2021 07:22:41 GMT expires: - '-1' pragma: @@ -3741,7 +4056,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8a302906-a1e2-4223-a95b-633e293cfe58 + - 94dcbdc3-cf5b-49b0-9e72-0813b55e73e3 status: code: 200 message: OK @@ -3755,9 +4070,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3769,7 +4084,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:27:40 GMT + - Tue, 26 Jan 2021 07:25:24 GMT expires: - '-1' pragma: @@ -3786,7 +4101,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e22db997-1ff4-426a-a7d4-8b7f226b240f + - 86a6e6cb-7895-4cab-9c30-3417815849cc status: code: 200 message: OK @@ -3800,9 +4115,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3814,7 +4129,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:29:21 GMT + - Tue, 26 Jan 2021 07:27:04 GMT expires: - '-1' pragma: @@ -3831,7 +4146,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2a777f27-6736-4f07-914e-ee62be58171c + - 438e8b88-2d0b-40c4-98b8-7b4147209373 status: code: 200 message: OK @@ -3845,9 +4160,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3859,7 +4174,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:31:02 GMT + - Tue, 26 Jan 2021 07:28:44 GMT expires: - '-1' pragma: @@ -3876,7 +4191,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 25eb324b-bc30-42dc-a75d-5cb4102e4470 + - 83458fa1-7224-4a48-9eb2-a0af5a25206f status: code: 200 message: OK @@ -3890,9 +4205,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3904,7 +4219,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:32:43 GMT + - Tue, 26 Jan 2021 07:30:25 GMT expires: - '-1' pragma: @@ -3921,7 +4236,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 23eef7a3-553c-4a2f-a3a6-107c722e780b + - 9e1e84e2-6826-4c07-9e48-b65f25406669 status: code: 200 message: OK @@ -3935,9 +4250,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3949,7 +4264,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:34:24 GMT + - Tue, 26 Jan 2021 07:32:05 GMT expires: - '-1' pragma: @@ -3966,7 +4281,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 952919c6-8457-4474-a89d-fc592fd04e2e + - 568019b3-bee6-491b-bc46-93b081f71ce9 status: code: 200 message: OK @@ -3980,9 +4295,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -3994,7 +4309,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:36:06 GMT + - Tue, 26 Jan 2021 07:33:47 GMT expires: - '-1' pragma: @@ -4011,7 +4326,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cd9398e8-13e3-458a-b8b7-c814bba66fc0 + - 851bb996-6570-45ce-97dd-f6d12edcd4f0 status: code: 200 message: OK @@ -4025,15 +4340,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -4041,11 +4356,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:36:06 GMT + - Tue, 26 Jan 2021 07:33:48 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/3347aaae-9825-4253-9bea-af06398cff22?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/acf51501-3a17-4237-94d0-d47201106dd5?api-version=2020-08-01 pragma: - no-cache server: @@ -4060,7 +4375,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0b889b5c-25de-487d-ab03-44c808e945d9 + - eb2951a7-a906-48b9-ac09-bc315a0959ce status: code: 200 message: OK @@ -4078,21 +4393,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Updating\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Updating\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4111,7 +4426,7 @@ interactions: \n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4125,7 +4440,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:36:11 GMT + - Tue, 26 Jan 2021 07:33:53 GMT expires: - '-1' pragma: @@ -4142,9 +4457,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5a24ab51-72e5-411b-bc17-0942390c122f + - 03fe4388-f382-4432-ac94-e0fa70a1c554 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1193' status: code: 200 message: OK @@ -4158,21 +4473,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Updating\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Updating\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4187,7 +4502,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4199,7 +4514,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:36:22 GMT + - Tue, 26 Jan 2021 07:34:04 GMT expires: - '-1' pragma: @@ -4216,7 +4531,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 60a3895e-78d7-40f6-926f-c319212fc011 + - 86c8d6fd-fc22-4d90-a642-9c1b95b07f60 status: code: 200 message: OK @@ -4230,21 +4545,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Updating\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Updating\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4259,7 +4574,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4271,7 +4586,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:36:52 GMT + - Tue, 26 Jan 2021 07:34:34 GMT expires: - '-1' pragma: @@ -4288,7 +4603,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e5cbed28-1714-4532-a5e4-bdef29e6e9da + - 176b2c57-5dbf-47c4-a4fb-d1f9267faa2d status: code: 200 message: OK @@ -4302,21 +4617,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Updating\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Updating\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4331,7 +4646,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4343,7 +4658,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:37:23 GMT + - Tue, 26 Jan 2021 07:35:05 GMT expires: - '-1' pragma: @@ -4360,7 +4675,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4dcbdbcd-0f0b-48d2-9174-dfb795a1c4e2 + - 73423ee3-2569-44aa-8506-cb8bb9f1f3ed status: code: 200 message: OK @@ -4374,21 +4689,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Updating\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Updating\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"669b9c9a-0504-4cb2-8f9a-b3adff46eac8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5114b145-f627-419c-bd17-1e6a17f44c1c\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4403,7 +4718,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4415,7 +4730,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:37:53 GMT + - Tue, 26 Jan 2021 07:35:35 GMT expires: - '-1' pragma: @@ -4432,7 +4747,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 95f18949-66fa-4754-a3c9-a1e18a6c4766 + - 928a84fc-ab15-404f-9f44-0b0790557da5 status: code: 200 message: OK @@ -4446,21 +4761,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"f01e2540-7ffb-4a30-95da-eff62ca7b3a7\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e3aca6ca-9900-44aa-8639-a0c02893091b\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Succeeded\",\r\n \"resourceGuid\": \"f97871ed-8e8a-4b25-be56-eb1c5bab4010\"\ + \ \"Succeeded\",\r\n \"resourceGuid\": \"7b828c23-d3fd-4db2-8792-fbd9958f8e03\"\ ,\r\n \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ - ,\r\n \"etag\": \"W/\\\"f01e2540-7ffb-4a30-95da-eff62ca7b3a7\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e3aca6ca-9900-44aa-8639-a0c02893091b\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -4475,7 +4790,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"20.185.192.188\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.237.125\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -4487,7 +4802,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:23 GMT + - Tue, 26 Jan 2021 07:36:06 GMT expires: - '-1' pragma: @@ -4504,7 +4819,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 39a4f7a9-0be6-455d-b5e9-9377d8a5d66f + - 6ecd4899-5832-4739-a372-2d8145ebb629 status: code: 200 message: OK @@ -4522,17 +4837,17 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"localnetworkgatewayname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ - ,\r\n \"etag\": \"W/\\\"50c35ecf-ff93-41b2-9c8d-7627d229706c\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"004a86d1-744f-4631-8616-e3ec67276121\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/localNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Succeeded\",\r\n \"resourceGuid\": \"aee59323-adb2-42bb-9218-cdcc6a501b83\"\ + \ \"Succeeded\",\r\n \"resourceGuid\": \"4ff99297-313d-4f49-b657-aa02bfbd7f13\"\ ,\r\n \"localNetworkAddressSpace\": {\r\n \"addressPrefixes\": [\r\ \n \"10.1.0.0/16\"\r\n ]\r\n },\r\n \"gatewayIpAddress\"\ : \"11.12.13.14\"\r\n }\r\n}" @@ -4546,7 +4861,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:28 GMT + - Tue, 26 Jan 2021 07:36:10 GMT expires: - '-1' pragma: @@ -4563,9 +4878,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8bf4c0f1-ef56-41d0-81d8-595c16dbc0e2 + - 17028836-c78d-44d8-99e7-efe4b3833bbf x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1193' status: code: 200 message: OK @@ -4583,21 +4898,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ - ,\r\n \"etag\": \"W/\\\"c35944d9-9865-4691-821b-66dfcdb0f435\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"00abaa05-3b5a-438f-b0f0-cb404e925bb5\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"bb8fec76-42b2-4eec-94f3-a94335f1f91b\",\r\n \ + ,\r\n \"resourceGuid\": \"8c1b9d02-291c-4f75-9f08-9eddc3bdc691\",\r\n \ \ \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [\r\n {\r\n \"name\"\ : \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"c35944d9-9865-4691-821b-66dfcdb0f435\\\"\"\ + ,\r\n \"etag\": \"W/\\\"00abaa05-3b5a-438f-b0f0-cb404e925bb5\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"addressPrefix\": \"10.0.1.0/24\",\r\n \"ipConfigurations\"\ : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname/ipConfigurations/ipconfig\"\ @@ -4606,7 +4921,7 @@ interactions: privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n },\r\n\ \ {\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ - ,\r\n \"etag\": \"W/\\\"c35944d9-9865-4691-821b-66dfcdb0f435\\\"\"\ + ,\r\n \"etag\": \"W/\\\"00abaa05-3b5a-438f-b0f0-cb404e925bb5\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n \"networkSecurityGroup\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/virtualnetworkname-subnetname-NRMS\"\ @@ -4618,9 +4933,9 @@ interactions: \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n }\r\n \ \ ],\r\n \"virtualNetworkPeerings\": [\r\n {\r\n \"name\"\ : \"virtualnetworkpeeringname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname\"\ - ,\r\n \"etag\": \"W/\\\"c35944d9-9865-4691-821b-66dfcdb0f435\\\"\"\ + ,\r\n \"etag\": \"W/\\\"00abaa05-3b5a-438f-b0f0-cb404e925bb5\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"3ee06730-89a9-07e9-0fea-8d609c9509ce\"\ + ,\r\n \"resourceGuid\": \"baf9227e-9c61-0a48-13c0-aed133b80bac\"\ ,\r\n \"peeringState\": \"Initiated\",\r\n \"remoteVirtualNetwork\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ \r\n },\r\n \"allowVirtualNetworkAccess\": true,\r\n \ @@ -4642,7 +4957,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:32 GMT + - Tue, 26 Jan 2021 07:36:14 GMT expires: - '-1' pragma: @@ -4659,9 +4974,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 26418dbe-0574-47f3-aeb2-8363949d44e2 + - 1245244c-6f16-4927-ae02-7c9d37d8753f x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1192' status: code: 200 message: OK @@ -4679,21 +4994,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname\"\ - ,\r\n \"etag\": \"W/\\\"f62a8f4a-a56f-4957-b0f9-bffe214cfc6b\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3122d338-65b9-4b02-a13c-2d48cca35dc5\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/connections\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"22700540-3e87-4b27-af6a-2fe29916f639\",\r\n \"\ + \ \"resourceGuid\": \"313afaca-ea58-4f00-8257-6373069a96f7\",\r\n \"\ packetCaptureDiagnosticState\": \"None\",\r\n \"virtualNetworkGateway1\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname\"\ \r\n },\r\n \"localNetworkGateway2\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname\"\ \r\n },\r\n \"connectionType\": \"IPsec\",\r\n \"connectionProtocol\"\ - : \"IKEv2\",\r\n \"routingWeight\": 0,\r\n \"sharedKey\": \"dLdmeySFes1BtfoLBquUKYZJdNi0BQzwd1iYbN8d3xnyjmVOgJAnc001rqICohbDNks2be1lxfJeLKVCUq0C7rZxw0Q3YJJbbBCLECm3GwQaugNlAzBaQdl1mTvg1HPg\"\ + : \"IKEv2\",\r\n \"routingWeight\": 0,\r\n \"sharedKey\": \"nDyhFZHmWam985XigbgcwVdyujXm4R78U18aPDEsksfmb9MHC1EyiR1K3uNN6TyhCGZrPzgSjq2sT2feUWq2GTb7L6DPXghS2oqSJYv9VxtnVeIwP3w8JXyOTXzbrpLH\"\ ,\r\n \"enableBgp\": false,\r\n \"useLocalAzureIpAddress\": false,\r\ \n \"usePolicyBasedTrafficSelectors\": false,\r\n \"ipsecPolicies\"\ : [],\r\n \"trafficSelectorPolicies\": [],\r\n \"ingressBytesTransferred\"\ @@ -4708,7 +5023,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:33 GMT + - Tue, 26 Jan 2021 07:36:15 GMT expires: - '-1' pragma: @@ -4725,9 +5040,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ec1246e9-3e26-4b6c-8ca3-3e4253a950d1 + - a0e7a2dc-97da-4121-a098-8a88c9d71489 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1191' status: code: 200 message: OK @@ -4743,9 +5058,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/connections/connectionname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/connections/connectionname?api-version=2020-08-01 response: body: string: '' @@ -4753,17 +5068,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d2b7baf9-cceb-40d1-a449-e9f97ff3968c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/006b2084-6f53-4319-b774-aa1128d98a68?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:38:34 GMT + - Tue, 26 Jan 2021 07:36:16 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/d2b7baf9-cceb-40d1-a449-e9f97ff3968c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/006b2084-6f53-4319-b774-aa1128d98a68?api-version=2020-08-01 pragma: - no-cache server: @@ -4774,9 +5089,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b9da4a11-eef9-47e7-b5f2-11d251f92cdd + - 6eabb6a9-c15d-457c-a966-6380ba459dd0 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14994' status: code: 202 message: Accepted @@ -4790,21 +5105,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d2b7baf9-cceb-40d1-a449-e9f97ff3968c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/006b2084-6f53-4319-b774-aa1128d98a68?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" + string: "{\r\n \"status\": \"InProgress\"\r\n}" headers: cache-control: - no-cache content-length: - - '29' + - '30' content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:45 GMT + - Tue, 26 Jan 2021 07:36:26 GMT expires: - '-1' pragma: @@ -4821,7 +5136,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c3cda450-a3fc-4a03-91ef-b3b1f5a0a097 + - 2c52967c-1f5b-43bc-9472-c9003ea3d0f1 status: code: 200 message: OK @@ -4829,33 +5144,29 @@ interactions: body: null headers: Accept: - - application/json + - '*/*' Accept-Encoding: - gzip, deflate Connection: - keep-alive - Content-Length: - - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-07-01 + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/006b2084-6f53-4319-b774-aa1128d98a68?api-version=2020-08-01 response: body: - string: '' + string: "{\r\n \"status\": \"InProgress\"\r\n}" headers: - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c21ce471-6ed6-4532-b2d3-373beac9c83d?api-version=2020-07-01 cache-control: - no-cache content-length: - - '0' + - '30' + content-type: + - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:45 GMT + - Tue, 26 Jan 2021 07:36:37 GMT expires: - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/c21ce471-6ed6-4532-b2d3-373beac9c83d?api-version=2020-07-01 pragma: - no-cache server: @@ -4863,15 +5174,17 @@ interactions: - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 48c38288-acb1-4062-9864-d3178ba25fa0 - x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - ec81d655-37cb-40c5-9f53-0f067bf9c4d4 status: - code: 202 - message: Accepted + code: 200 + message: OK - request: body: null headers: @@ -4882,9 +5195,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/c21ce471-6ed6-4532-b2d3-373beac9c83d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/006b2084-6f53-4319-b774-aa1128d98a68?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -4896,7 +5209,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:38:56 GMT + - Tue, 26 Jan 2021 07:36:57 GMT expires: - '-1' pragma: @@ -4913,7 +5226,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0e10b02b-c8f2-44ae-b1bb-afe7a08ca8be + - bad33654-3d97-43f9-948d-fcef2c277b8b status: code: 200 message: OK @@ -4929,27 +5242,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/virtualNetworkPeerings/virtualnetworkpeeringname?api-version=2020-08-01 response: body: string: '' headers: - azure-asyncnotification: - - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/48d4ddf3-177b-44bc-85f9-b190e1eca691?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:38:57 GMT + - Tue, 26 Jan 2021 07:36:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/48d4ddf3-177b-44bc-85f9-b190e1eca691?api-version=2020-08-01 pragma: - no-cache server: @@ -4960,9 +5271,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7cc0702c-dc29-4714-afb9-1e1f9964e319 + - 851da640-f2c2-47ff-8594-7a0ade88b819 x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14993' status: code: 202 message: Accepted @@ -4976,66 +5287,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Tue, 01 Dec 2020 02:39:07 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - c5a7804a-30c6-406d-9f86-46c76d76a69f - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/48d4ddf3-177b-44bc-85f9-b190e1eca691?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: "{\r\n \"status\": \"Succeeded\"\r\n}" headers: cache-control: - no-cache content-length: - - '30' + - '29' content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:39:17 GMT + - Tue, 26 Jan 2021 07:37:09 GMT expires: - '-1' pragma: @@ -5052,7 +5318,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 311308f2-0ec8-4252-91d8-eb1282d8d021 + - 7bb8e52e-0b5f-405f-a61a-160968dd82f4 status: code: 200 message: OK @@ -5060,29 +5326,35 @@ interactions: body: null headers: Accept: - - '*/*' + - application/json Accept-Encoding: - gzip, deflate Connection: - keep-alive + Content-Length: + - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: '' headers: + azure-asyncnotification: + - Enabled + azure-asyncoperation: + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 cache-control: - no-cache content-length: - - '30' - content-type: - - application/json; charset=utf-8 + - '0' date: - - Tue, 01 Dec 2020 02:39:38 GMT + - Tue, 26 Jan 2021 07:37:11 GMT expires: - '-1' + location: + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 pragma: - no-cache server: @@ -5090,17 +5362,15 @@ interactions: - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff x-ms-arm-service-request-id: - - de770470-96d2-4731-90f5-37d666716f17 + - db62ea4b-ab81-4e11-bf21-f8b3a727f79b + x-ms-ratelimit-remaining-subscription-deletes: + - '14992' status: - code: 200 - message: OK + code: 202 + message: Accepted - request: body: null headers: @@ -5111,9 +5381,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5125,7 +5395,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:39:59 GMT + - Tue, 26 Jan 2021 07:37:21 GMT expires: - '-1' pragma: @@ -5142,7 +5412,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 89f59021-3e0d-4295-b552-7d7a4f6c7a16 + - 8a7fe07e-4811-4814-ac06-df5ab6dc137f status: code: 200 message: OK @@ -5156,9 +5426,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5170,7 +5440,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:40:39 GMT + - Tue, 26 Jan 2021 07:37:31 GMT expires: - '-1' pragma: @@ -5187,7 +5457,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 15158da8-55d0-4f5e-b869-d243915821ee + - 0ac11c14-5c81-47ba-8ae6-73c123b88596 status: code: 200 message: OK @@ -5201,9 +5471,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5215,7 +5485,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:41:20 GMT + - Tue, 26 Jan 2021 07:37:52 GMT expires: - '-1' pragma: @@ -5232,7 +5502,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - be8ce094-4f35-4ac4-8a5d-210cbfdcf32a + - c9b62e74-f20b-4cf3-aee2-4391b1c2120d status: code: 200 message: OK @@ -5246,9 +5516,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5260,7 +5530,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:42:40 GMT + - Tue, 26 Jan 2021 07:38:12 GMT expires: - '-1' pragma: @@ -5277,7 +5547,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6f0f8b51-73af-4646-bc6e-f2ffc39a4076 + - f9324a62-dc64-43f8-b5a7-377466973789 status: code: 200 message: OK @@ -5291,9 +5561,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5305,7 +5575,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:45:22 GMT + - Tue, 26 Jan 2021 07:38:54 GMT expires: - '-1' pragma: @@ -5322,7 +5592,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f59a6a10-94a6-4a25-a551-9d4c280f84fc + - 411d796d-a43e-4367-be65-119cf60a0f74 status: code: 200 message: OK @@ -5336,9 +5606,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5350,7 +5620,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:47:03 GMT + - Tue, 26 Jan 2021 07:39:34 GMT expires: - '-1' pragma: @@ -5367,7 +5637,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 92889f74-620e-4027-b982-fac89376efb1 + - f1fb9c20-366f-48a9-98a5-d9bd02b00f2e status: code: 200 message: OK @@ -5381,9 +5651,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5395,7 +5665,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:48:45 GMT + - Tue, 26 Jan 2021 07:40:54 GMT expires: - '-1' pragma: @@ -5412,7 +5682,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 21f087d0-93e0-40fa-b24f-ea743c1f28d7 + - 637a85ee-8caa-4a15-92ab-cdb89184323c status: code: 200 message: OK @@ -5426,9 +5696,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -5440,7 +5710,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:50:25 GMT + - Tue, 26 Jan 2021 07:43:35 GMT expires: - '-1' pragma: @@ -5457,7 +5727,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8f6f6226-a2c3-4199-b300-cba190d5b3ef + - 55414c93-a395-4541-90d5-e1ef4940cf69 status: code: 200 message: OK @@ -5471,9 +5741,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/820bd1bd-2ee5-46d3-b02c-62b78d592fba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20385ff6-ca6e-4060-839a-d8d9ea00744f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -5485,7 +5755,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:52:07 GMT + - Tue, 26 Jan 2021 07:45:16 GMT expires: - '-1' pragma: @@ -5502,7 +5772,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e62abf89-3fbe-419e-9c26-b3a785246035 + - 659c0d46-4ceb-4521-9ed1-3f714482bb40 status: code: 200 message: OK @@ -5518,9 +5788,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: '' @@ -5528,22 +5798,17 @@ interactions: cache-control: - no-cache date: - - Tue, 01 Dec 2020 02:52:16 GMT + - Tue, 26 Jan 2021 07:45:17 GMT expires: - '-1' pragma: - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains x-content-type-options: - nosniff - x-ms-arm-service-request-id: - - bd96f678-b438-4769-8c68-be62b5409a32 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14991' status: code: 204 message: No Content @@ -5559,9 +5824,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: '' @@ -5569,7 +5834,7 @@ interactions: cache-control: - no-cache date: - - Tue, 01 Dec 2020 02:52:16 GMT + - Tue, 26 Jan 2021 07:45:17 GMT expires: - '-1' pragma: @@ -5579,7 +5844,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14990' status: code: 204 message: No Content @@ -5595,9 +5860,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewayname?api-version=2020-08-01 response: body: string: '' @@ -5605,7 +5870,7 @@ interactions: cache-control: - no-cache date: - - Tue, 01 Dec 2020 02:52:17 GMT + - Tue, 26 Jan 2021 07:45:17 GMT expires: - '-1' pragma: @@ -5615,7 +5880,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14989' status: code: 204 message: No Content @@ -5631,9 +5896,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/localNetworkGateways/localnetworkgatewayname?api-version=2020-08-01 response: body: string: '' @@ -5641,17 +5906,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a7a2f671-855f-43e4-92c8-7768bc9d1073?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1094c17f-12dc-4b58-93fa-c14d0e333d1a?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:52:18 GMT + - Tue, 26 Jan 2021 07:45:18 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/a7a2f671-855f-43e4-92c8-7768bc9d1073?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1094c17f-12dc-4b58-93fa-c14d0e333d1a?api-version=2020-08-01 pragma: - no-cache server: @@ -5662,9 +5927,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 65785a1e-923d-42ef-b0c9-7143127861d5 + - 8083b0f6-dbe5-4ba2-933d-5f05d556c1bf x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14988' status: code: 202 message: Accepted @@ -5678,9 +5943,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a7a2f671-855f-43e4-92c8-7768bc9d1073?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1094c17f-12dc-4b58-93fa-c14d0e333d1a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -5692,7 +5957,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:52:28 GMT + - Tue, 26 Jan 2021 07:45:29 GMT expires: - '-1' pragma: @@ -5709,7 +5974,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 34406ea7-cb6f-4e2c-9f4a-dcdc301f8129 + - 41d898ac-8d60-4cce-8ead-0d12ec22e45b status: code: 200 message: OK @@ -5725,9 +5990,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/networkinterfacename?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/networkinterfacename?api-version=2020-08-01 response: body: string: '' @@ -5735,17 +6000,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/65aea0b0-fa7c-41c8-aedd-0da45af08fd3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/181ac243-b5cb-471f-91a4-f18af1ea98a1?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:52:29 GMT + - Tue, 26 Jan 2021 07:45:30 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/65aea0b0-fa7c-41c8-aedd-0da45af08fd3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/181ac243-b5cb-471f-91a4-f18af1ea98a1?api-version=2020-08-01 pragma: - no-cache server: @@ -5756,9 +6021,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 33799431-ff18-4dc7-b328-45cb7b19c395 + - d8c48080-1c84-492a-925a-2b268fc4d076 x-ms-ratelimit-remaining-subscription-deletes: - - '14995' + - '14987' status: code: 202 message: Accepted @@ -5772,9 +6037,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/65aea0b0-fa7c-41c8-aedd-0da45af08fd3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/181ac243-b5cb-471f-91a4-f18af1ea98a1?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -5786,7 +6051,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:52:39 GMT + - Tue, 26 Jan 2021 07:45:41 GMT expires: - '-1' pragma: @@ -5803,7 +6068,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - dd29b962-bc62-48fc-b11d-3ccb60cf42be + - 2c98eb8b-0d6c-4cb0-8b1a-a1f0dbeebeef status: code: 200 message: OK @@ -5819,25 +6084,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/bd2a71cc-13bf-4a56-833d-912fe09c1fe1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/470ecd92-6cdc-44e6-bad1-be772e4ffdf5?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:52:40 GMT + - Tue, 26 Jan 2021 07:45:41 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd2a71cc-13bf-4a56-833d-912fe09c1fe1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/470ecd92-6cdc-44e6-bad1-be772e4ffdf5?api-version=2020-08-01 pragma: - no-cache server: @@ -5848,9 +6113,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6b600069-0be1-4c8b-a9cf-445e978ed485 + - 42b2243d-43e7-4c46-82af-617c652ea59d x-ms-ratelimit-remaining-subscription-deletes: - - '14994' + - '14986' status: code: 202 message: Accepted @@ -5864,9 +6129,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/bd2a71cc-13bf-4a56-833d-912fe09c1fe1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/470ecd92-6cdc-44e6-bad1-be772e4ffdf5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -5878,7 +6143,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:52:50 GMT + - Tue, 26 Jan 2021 07:45:51 GMT expires: - '-1' pragma: @@ -5895,7 +6160,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - dac85527-e64c-4b51-9091-c4e8d1043b46 + - 4866d9e6-3f94-44c3-84a7-a8155e3d642b status: code: 200 message: OK @@ -5911,9 +6176,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: '' @@ -5921,17 +6186,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c0bed0e4-aeec-4a43-b6a3-a2d5b6ae02f3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/32e4fda2-8b01-4a64-8728-7a72eeae9668?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Tue, 01 Dec 2020 02:52:51 GMT + - Tue, 26 Jan 2021 07:45:52 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/c0bed0e4-aeec-4a43-b6a3-a2d5b6ae02f3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/32e4fda2-8b01-4a64-8728-7a72eeae9668?api-version=2020-08-01 pragma: - no-cache server: @@ -5942,9 +6207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b6c991d6-0cd6-4a28-b490-f429ca96c0fa + - c8b0c3bb-047d-414c-9769-5fb6540d4688 x-ms-ratelimit-remaining-subscription-deletes: - - '14993' + - '14985' status: code: 202 message: Accepted @@ -5958,9 +6223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/c0bed0e4-aeec-4a43-b6a3-a2d5b6ae02f3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/32e4fda2-8b01-4a64-8728-7a72eeae9668?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -5972,7 +6237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Tue, 01 Dec 2020 02:53:01 GMT + - Tue, 26 Jan 2021 07:46:03 GMT expires: - '-1' pragma: @@ -5989,7 +6254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e50157b2-7ac4-4576-a176-0bd7afcba800 + - 65a79444-51a5-47f7-8579-ca52331b4a14 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base_async.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base_async.test_network.yaml index 6ccbdd9d4d3a..92e260ca2179 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base_async.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_base_async.test_network.yaml @@ -10,44 +10,45 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\",\r\n - \ \"etag\": \"W/\\\"64371a0f-0025-4bb9-b92a-8029b807305e\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"45481191-8f9c-4875-af62-0f0c0e345edd\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"e814e57c-c3a3-414d-a1d2-62b3dd203473\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: azure-asyncnotification: Enabled - azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2d25d28b-7b95-4262-ba4d-d4dc3dbd43eb?api-version=2020-07-01 + azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f1d30cc8-2fc4-44d4-92ae-df075744043e?api-version=2020-08-01 cache-control: no-cache content-length: '723' content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:43 GMT + date: Tue, 26 Jan 2021 07:46:24 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-arm-service-request-id: aaebdf4c-29e8-45c4-ad78-0e317e65005e - x-ms-ratelimit-remaining-subscription-writes: '1199' + x-ms-arm-service-request-id: bbb96dd1-cd6a-4380-ad58-12ebb446dd7e + x-ms-ratelimit-remaining-subscription-writes: '1196' status: code: 201 message: Created - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2d25d28b-7b95-4262-ba4d-d4dc3dbd43eb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f1d30cc8-2fc4-44d4-92ae-df075744043e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -55,7 +56,7 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:48 GMT + date: Tue, 26 Jan 2021 07:46:28 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -63,34 +64,35 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: b3bbb4f9-ea10-44aa-aa87-cd1fcb2bff25 + x-ms-arm-service-request-id: eecb423b-26ca-42e7-87bb-6a0863da5c22 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/providers/Microsoft.Network/locations/eastus/operations/2d25d28b-7b95-4262-ba4d-d4dc3dbd43eb?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/providers/Microsoft.Network/locations/eastus/operations/f1d30cc8-2fc4-44d4-92ae-df075744043e?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\",\r\n - \ \"etag\": \"W/\\\"9e5469fa-c0c3-4d41-b93a-5b8250ea39e6\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"45481191-8f9c-4875-af62-0f0c0e345edd\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"dcbd4fd4-d9d5-4cf9-8014-69dae46edf84\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:49 GMT - etag: W/"9e5469fa-c0c3-4d41-b93a-5b8250ea39e6" + date: Tue, 26 Jan 2021 07:46:28 GMT + etag: W/"dcbd4fd4-d9d5-4cf9-8014-69dae46edf84" expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -98,11 +100,11 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 1c85e244-0b4e-49da-83f0-c9d1c627331a + x-ms-arm-service-request-id: a810eead-1a82-4a4c-a11d-3c6d90addc00 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 - request: body: '{"properties": {"addressPrefix": "10.0.0.0/24"}}' headers: @@ -113,41 +115,41 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"a61fe31f-b892-4694-9e60-5e0a8d2f1e15\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" - headers: - azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d09d16e8-f7a0-4bba-abca-53b7f3ead570?api-version=2020-07-01 + string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"8bbbc535-824b-40b5-bc52-cac1edff191d\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + headers: + azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/dde7b015-7265-42fa-a749-5a7bfc6ef638?api-version=2020-08-01 cache-control: no-cache content-length: '604' content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:49 GMT + date: Tue, 26 Jan 2021 07:46:29 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-arm-service-request-id: 714095c7-0811-4135-83b7-12df3fd5ebe1 - x-ms-ratelimit-remaining-subscription-writes: '1198' + x-ms-arm-service-request-id: a9197f5c-1b78-4adc-bbe9-b3d09529ed1d + x-ms-ratelimit-remaining-subscription-writes: '1195' status: code: 201 message: Created - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d09d16e8-f7a0-4bba-abca-53b7f3ead570?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/dde7b015-7265-42fa-a749-5a7bfc6ef638?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -155,7 +157,7 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:52 GMT + date: Tue, 26 Jan 2021 07:46:32 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -163,32 +165,32 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 156c1a33-2910-4f52-8c80-75f7b2130f13 + x-ms-arm-service-request-id: 477cb248-eb1c-4999-a8d2-0ca86ac9670b status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/providers/Microsoft.Network/locations/eastus/operations/d09d16e8-f7a0-4bba-abca-53b7f3ead570?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/providers/Microsoft.Network/locations/eastus/operations/dde7b015-7265-42fa-a749-5a7bfc6ef638?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:53 GMT - etag: W/"2746a993-94d6-41c2-a940-f0d5879801a0" + date: Tue, 26 Jan 2021 07:46:32 GMT + etag: W/"efececbd-6baf-4eff-9b8c-407cb66c7c11" expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -196,20 +198,20 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: d4ebe363-3b23-425c-a479-25538da70178 + x-ms-arm-service-request-id: 3123436c-d27c-4642-9db6-e3b4e3121c9f status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.0.4&api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.0.4&api-version=2020-08-01 response: body: string: "{\r\n \"available\": true,\r\n \"isPlatformReserved\": false\r\n}" @@ -217,7 +219,7 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:53 GMT + date: Tue, 26 Jan 2021 07:46:33 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -225,34 +227,34 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: c8a16817-3898-4555-bf4c-f4be02031656 + x-ms-arm-service-request-id: a2ea5376-12d0-4c85-b837-b62e86b540f7 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.0.4&api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/CheckIPAddressAvailability?ipAddress=10.0.0.4&api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:53 GMT - etag: W/"2746a993-94d6-41c2-a940-f0d5879801a0" + date: Tue, 26 Jan 2021 07:46:33 GMT + etag: W/"efececbd-6baf-4eff-9b8c-407cb66c7c11" expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -260,35 +262,36 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: c468db8e-7ba7-4cb6-98ed-6b7d409c0229 + x-ms-arm-service-request-id: 3f3d958d-c9f8-45ca-ae7c-5cbaab582184 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets?api-version=2020-08-01 response: body: - string: "{\r\n \"value\": [\r\n {\r\n \"name\": \"subnetname\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": - \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": - \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n - \ },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n - \ }\r\n ]\r\n}" + string: "{\r\n \"value\": [\r\n {\r\n \"name\": \"subnetname\",\r\n\ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\"\ + : [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \ + \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n }\r\n\ + \ ]\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:54 GMT + date: Tue, 26 Jan 2021 07:46:33 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -296,32 +299,32 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 11fce3e8-ee24-41a3-b9c0-1c7e285d8ac0 + x-ms-arm-service-request-id: 3f5452d6-787e-4713-85fd-6074613a8141 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/usages?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/usages?api-version=2020-08-01 response: body: - string: "{\r\n \"value\": [\r\n {\r\n \"currentValue\": 0,\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"limit\": 251,\r\n \"name\": {\r\n \"localizedValue\": - \"Subnet size and usage\",\r\n \"value\": \"SubnetSpace\"\r\n },\r\n - \ \"unit\": \"Count\"\r\n }\r\n ]\r\n}" + string: "{\r\n \"value\": [\r\n {\r\n \"currentValue\": 0,\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"limit\": 251,\r\n \"name\": {\r\n \"localizedValue\"\ + : \"Subnet size and usage\",\r\n \"value\": \"SubnetSpace\"\r\n \ + \ },\r\n \"unit\": \"Count\"\r\n }\r\n ]\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:54 GMT + date: Tue, 26 Jan 2021 07:46:34 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -329,42 +332,44 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: d0987224-3d03-4b3c-b71b-7b46fd77239c + x-ms-arm-service-request-id: 672e65f5-03fe-452b-8b2a-3c17544cf097 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/usages?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/usages?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"45481191-8f9c-4875-af62-0f0c0e345edd\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [\r\n - \ {\r\n \"name\": \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": - [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": - \"Enabled\"\r\n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n - \ }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": - false,\r\n \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [\r\n {\r\n \"name\"\ + : \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\"\ + : [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \ + \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n \ + \ }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\"\ + : false,\r\n \"enableVmProtection\": false\r\n }\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:54 GMT - etag: W/"2746a993-94d6-41c2-a940-f0d5879801a0" + date: Tue, 26 Jan 2021 07:46:34 GMT + etag: W/"efececbd-6baf-4eff-9b8c-407cb66c7c11" expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -372,44 +377,46 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 48958c9f-0494-4746-8faa-8d2c6ff2a8ad + x-ms-arm-service-request-id: d64fe03a-63c3-4f51-9081-f1ce51b8f2cf status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks?api-version=2020-08-01 response: body: - string: "{\r\n \"value\": [\r\n {\r\n \"name\": \"virtualnetworkname\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"45481191-8f9c-4875-af62-0f0c0e345edd\",\r\n \"addressSpace\": - {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\r\n ]\r\n - \ },\r\n \"subnets\": [\r\n {\r\n \"name\": - \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"2746a993-94d6-41c2-a940-f0d5879801a0\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": - [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n - \ \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n }\r\n - \ ],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": - false,\r\n \"enableVmProtection\": false\r\n }\r\n }\r\n ]\r\n}" + string: "{\r\n \"value\": [\r\n {\r\n \"name\": \"virtualnetworkname\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\"\ + ,\r\n \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \ + \ \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\"\ + : [\r\n {\r\n \"name\": \"subnetname\",\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\ + \",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n\ + \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"\ + Enabled\"\r\n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\ + \r\n }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\ + \n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n }\r\n ]\r\n}" headers: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:55 GMT + date: Tue, 26 Jan 2021 07:46:34 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -417,39 +424,99 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 76a783ac-a4eb-4c1c-add6-0b57c182315c + x-ms-arm-service-request-id: ae497cc2-e184-4814-9801-de2979af9ef9 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/virtualNetworks?api-version=2020-08-01 response: body: - string: '{"value":[{"name":"ag1Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_auth_cert4byayij22ux5s2qckve7wlvbmohns2v3njpsykaofypzmqlgp4owkn/providers/Microsoft.Network/virtualNetworks/ag1Vnet","etag":"W/\"4ba17860-eb3f-4e9b-ba67-f3218e7ceb8d\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"20ad8de1-fb4b-4562-9c91-5f3ec7af3871","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_auth_cert4byayij22ux5s2qckve7wlvbmohns2v3njpsykaofypzmqlgp4owkn/providers/Microsoft.Network/virtualNetworks/ag1Vnet/subnets/default","etag":"W/\"4ba17860-eb3f-4e9b-ba67-f3218e7ceb8d\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_auth_cert4byayij22ux5s2qckve7wlvbmohns2v3njpsykaofypzmqlgp4owkn/providers/Microsoft.Network/applicationGateways/ag1/frontendIPConfigurations/appGatewayPrivateFrontendIP"}],"applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_auth_cert4byayij22ux5s2qckve7wlvbmohns2v3njpsykaofypzmqlgp4owkn/providers/Microsoft.Network/applicationGateways/ag1/gatewayIPConfigurations/appGatewayPrivateFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"ag1Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basica5uhxc5lne534cf3t6qsuggtc2x3hry7pi5sgghsrhrqvwx56dykrskaix/providers/Microsoft.Network/virtualNetworks/ag1Vnet","etag":"W/\"757f1524-eeb6-45d9-8003-71e5fa467edf\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"30eff024-79e1-4842-8831-5deae78a594e","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basica5uhxc5lne534cf3t6qsuggtc2x3hry7pi5sgghsrhrqvwx56dykrskaix/providers/Microsoft.Network/virtualNetworks/ag1Vnet/subnets/default","etag":"W/\"757f1524-eeb6-45d9-8003-71e5fa467edf\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basica5uhxc5lne534cf3t6qsuggtc2x3hry7pi5sgghsrhrqvwx56dykrskaix/providers/Microsoft.Network/applicationGateways/ag1/frontendIPConfigurations/appGatewayPrivateFrontendIP"}],"applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basica5uhxc5lne534cf3t6qsuggtc2x3hry7pi5sgghsrhrqvwx56dykrskaix/providers/Microsoft.Network/applicationGateways/ag1/gatewayIPConfigurations/appGatewayPrivateFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"ag1Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basic_with_waf_v2_skufnqncafesepj33dyzpwzarjttxdnnslbuwdpnx4cvq/providers/Microsoft.Network/virtualNetworks/ag1Vnet","etag":"W/\"ed86cbf0-c8ed-4e54-824a-fd94621b391c\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"1922e70c-210e-4196-aff0-804bd46188d0","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_basic_with_waf_v2_skufnqncafesepj33dyzpwzarjttxdnnslbuwdpnx4cvq/providers/Microsoft.Network/virtualNetworks/ag1Vnet/subnets/default","etag":"W/\"ed86cbf0-c8ed-4e54-824a-fd94621b391c\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vnet2","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_existing_subnet2es6ejpawkrayg4vx3txhllakospxvuuttfvypjsds4korie/providers/Microsoft.Network/virtualNetworks/vnet2","etag":"W/\"f0ecd41e-f3c0-4395-b81a-baae1fa4517a\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"9dcbccf8-5718-4a0e-b1aa-8e92edc435b2","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"subnet1","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_existing_subnet2es6ejpawkrayg4vx3txhllakospxvuuttfvypjsds4korie/providers/Microsoft.Network/virtualNetworks/vnet2/subnets/subnet1","etag":"W/\"f0ecd41e-f3c0-4395-b81a-baae1fa4517a\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_existing_subnet2es6ejpawkrayg4vx3txhllakospxvuuttfvypjsds4korie/providers/Microsoft.Network/applicationGateways/ag2/frontendIPConfigurations/appGatewayPrivateFrontendIP"}],"applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_existing_subnet2es6ejpawkrayg4vx3txhllakospxvuuttfvypjsds4korie/providers/Microsoft.Network/applicationGateways/ag2/gatewayIPConfigurations/appGatewayPrivateFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"gatewayVnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_identitywwee6k32hfl4qmmynrnkmn4ubukkm4h67yg4sefx7aherrfqtpipai6/providers/Microsoft.Network/virtualNetworks/gatewayVnet","etag":"W/\"e2c210ce-b815-4215-97fe-8b1a4513e7eb\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"4fe60e52-2bc9-48f4-85ad-39ead6355426","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_identitywwee6k32hfl4qmmynrnkmn4ubukkm4h67yg4sefx7aherrfqtpipai6/providers/Microsoft.Network/virtualNetworks/gatewayVnet/subnets/default","etag":"W/\"e2c210ce-b815-4215-97fe-8b1a4513e7eb\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_identitywwee6k32hfl4qmmynrnkmn4ubukkm4h67yg4sefx7aherrfqtpipai6/providers/Microsoft.Network/applicationGateways/gateway/gatewayIPConfigurations/appGatewayFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"ag1Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_root_certwpvyockxfzb2bq2tyoxta6ywbaoifzpb3n2brv2qqqgof6tictbdjn/providers/Microsoft.Network/virtualNetworks/ag1Vnet","etag":"W/\"52c4a47e-9def-4577-9711-4693ecc969c3\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"c335f46c-4a21-47be-87a4-c804e357a610","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_root_certwpvyockxfzb2bq2tyoxta6ywbaoifzpb3n2brv2qqqgof6tictbdjn/providers/Microsoft.Network/virtualNetworks/ag1Vnet/subnets/default","etag":"W/\"52c4a47e-9def-4577-9711-4693ecc969c3\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_test_ag_root_certwpvyockxfzb2bq2tyoxta6ywbaoifzpb3n2brv2qqqgof6tictbdjn/providers/Microsoft.Network/applicationGateways/ag1/gatewayIPConfigurations/appGatewayFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vm1VNET","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest2/providers/Microsoft.Network/virtualNetworks/vm1VNET","etag":"W/\"98953260-b7dc-4045-8b6f-fbf7e8551336\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"b3589910-4808-41a4-a677-69cdbf23f9d1","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"vm1Subnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest2/providers/Microsoft.Network/virtualNetworks/vm1VNET/subnets/vm1Subnet","etag":"W/\"98953260-b7dc-4045-8b6f-fbf7e8551336\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest2/providers/Microsoft.Network/networkInterfaces/vm1VMNic/ipConfigurations/ipconfigvm1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vm1VNET","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest3/providers/Microsoft.Network/virtualNetworks/vm1VNET","etag":"W/\"f0acee59-ecb9-4d47-b897-4fc1653c4ee2\"","type":"Microsoft.Network/virtualNetworks","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"28fec551-0208-4430-b38e-3a7692c44872","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"vm1Subnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest3/providers/Microsoft.Network/virtualNetworks/vm1VNET/subnets/vm1Subnet","etag":"W/\"f0acee59-ecb9-4d47-b897-4fc1653c4ee2\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest3/providers/Microsoft.Network/networkInterfaces/vm1VMNic/ipConfigurations/ipconfigvm1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"bimplvnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/virtualNetworks/bimplvnet","etag":"W/\"2adffadc-e885-4767-bfb4-f27c043f7db4\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"54867026-fd16-4992-b987-a23d8f1a2ee5","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"bimsubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/virtualNetworks/bimplvnet/subnets/bimsubnet","etag":"W/\"2adffadc-e885-4767-bfb4-f27c043f7db4\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/networkInterfaces/bimpe.nic.89900ad0-7e6e-40b6-897b-29e7e4146280/ipConfigurations/vault-default.privateEndpoint"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/networkInterfaces/bim547/ipConfigurations/ipconfig1"}],"privateEndpoints":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/privateEndpoints/bimpe"}],"serviceEndpoints":[{"provisioningState":"Succeeded","service":"Microsoft.KeyVault","locations":["*"]}],"delegations":[],"purpose":"PrivateEndpoints","privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"AzureBastionSubnet_pltest","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim_pl_test_rg/providers/Microsoft.Network/virtualNetworks/bimplvnet/subnets/AzureBastionSubnet_pltest","etag":"W/\"2adffadc-e885-4767-bfb4-f27c043f7db4\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.1.0/24","serviceEndpoints":[],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"appgw-1Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/appgw-1Vnet","etag":"W/\"678fb22b-1170-47bb-811d-da5eb02d4d92\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"a9aafa38-2b10-44ca-9b95-70987fd20b3b","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/appgw-1Vnet/subnets/default","etag":"W/\"678fb22b-1170-47bb-811d-da5eb02d4d92\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"appgw-2Vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/appgw-2Vnet","etag":"W/\"d74b8820-4c35-4929-8c9d-8dd1828a7139\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"5c2c1936-843e-47c6-b78b-251e51d05958","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/appgw-2Vnet/subnets/default","etag":"W/\"d74b8820-4c35-4929-8c9d-8dd1828a7139\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/applicationGateways/appgw-2/gatewayIPConfigurations/appGatewayFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vnet1","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/vnet1","etag":"W/\"50a1b229-3c6a-4f39-a885-6c2c73b4b353\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"9d1731cb-2e82-4484-80ac-7cd50283e1ad","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"GatewaySubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworks/vnet1/subnets/GatewaySubnet","etag":"W/\"50a1b229-3c6a-4f39-a885-6c2c73b4b353\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.1.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/harold/providers/Microsoft.Network/virtualNetworkGateways/vpngw1/ipConfigurations/vnetGatewayConfig0"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"rmvirtualnetworkname","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/ku3geabscgxsndgfiqpai2ocqxxjos64cukwm7qv26sqqekh3y76qx2uuggpjebspedkh73b7vg/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname","etag":"W/\"78275037-0eba-4a71-b580-2ea663da8a64\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","properties":{"provisioningState":"Succeeded","resourceGuid":"041646e4-452f-4c6b-9e79-c78416cfeb47","addressSpace":{"addressPrefixes":["10.2.0.0/16"]},"subnets":[],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"virtualnetworkname","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname","etag":"W/\"2746a993-94d6-41c2-a940-f0d5879801a0\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","properties":{"provisioningState":"Succeeded","resourceGuid":"45481191-8f9c-4875-af62-0f0c0e345edd","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"subnetname","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname","etag":"W/\"2746a993-94d6-41c2-a940-f0d5879801a0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"QIAN","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/QIAN","etag":"W/\"bde83ff6-53a5-420d-83c8-ec0037e4b2b9\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","properties":{"provisioningState":"Succeeded","resourceGuid":"886c7457-e93f-4e82-b17c-ad21466f22e3","addressSpace":{"addressPrefixes":["10.7.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/QIAN/subnets/default","etag":"W/\"bde83ff6-53a5-420d-83c8-ec0037e4b2b9\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.7.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-1/ipConfigurations/primary"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-0/ipConfigurations/primary"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-2/ipConfigurations/primary"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-0/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-0-10-7-0-20"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-1/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-1-10-7-0-22"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-2/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-2-10-7-0-21"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-1/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-1-10-7-0-18"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-nfs346/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-1/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-1-10-7-0-23"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-0/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-0-10-7-0-17"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/QIANWENS/providers/Microsoft.Network/networkInterfaces/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-nic-2/ipConfigurations/prod-9bef63c3-4937-49ef-bfd6-55609d35142e-cluster-vm-2-10-7-0-19"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-windows228/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-rdp742/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-trusty198/ipConfigurations/ipconfig1"}],"serviceEndpoints":[{"provisioningState":"Succeeded","service":"Microsoft.Storage","locations":["eastus","westus"]}],"delegations":[],"privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"qianwendev","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwendev","etag":"W/\"ff1e9e9b-abe4-4702-a8d3-668801a06e2d\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","properties":{"provisioningState":"Succeeded","resourceGuid":"9ac268c5-7cd2-4ca6-9be3-be560ffefa49","addressSpace":{"addressPrefixes":["10.4.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwendev/subnets/default","etag":"W/\"ff1e9e9b-abe4-4702-a8d3-668801a06e2d\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.4.0.0/24","serviceEndpoints":[{"provisioningState":"Succeeded","service":"Microsoft.Storage","locations":["eastus","westus"]}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"aadds-vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/virtualNetworks/aadds-vnet","etag":"W/\"9a85b7ca-eb3c-4587-b340-263ebc530c9a\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","properties":{"provisioningState":"Succeeded","resourceGuid":"f51bb677-7115-48e0-b8d2-be69a72ad9a0","addressSpace":{"addressPrefixes":["10.2.2.0/24"]},"subnets":[{"name":"aadds-subnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/virtualNetworks/aadds-vnet/subnets/aadds-subnet","etag":"W/\"9a85b7ca-eb3c-4587-b340-263ebc530c9a\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.2.2.0/24","networkSecurityGroup":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/networkSecurityGroups/aadds-nsg"},"ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/networkInterfaces/aadds-d516bde6efd946f4b0bbec1fdd7259ef-nic/ipConfigurations/INHGKMIOFO8VWUEIpcfg"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/networkInterfaces/aadds-e5d46dabe08f4148acfb02778268b842-nic/ipConfigurations/BRMHKF8D4JAW76WIpcfg"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"zuhgateVnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/virtualNetworks/zuhgateVnet","etag":"W/\"d3ebb264-f61d-4e4d-9c5c-a31c0b26b12a\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"667f0790-c8a9-4923-8760-7a600e16783b","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/virtualNetworks/zuhgateVnet/subnets/default","etag":"W/\"d3ebb264-f61d-4e4d-9c5c-a31c0b26b12a\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/applicationGateways/zuhgate/frontendIPConfigurations/appGatewayPrivateFrontendIP"}],"applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/applicationGateways/zuhgate/gatewayIPConfigurations/appGatewayPrivateFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"zuhvmVNET","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/virtualNetworks/zuhvmVNET","etag":"W/\"448f5f9a-0819-4a63-a36b-bc78c17fb50f\"","type":"Microsoft.Network/virtualNetworks","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"d5da1a47-3c7b-4c28-ab23-43a5c8eeb06c","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"zuhvmSubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/virtualNetworks/zuhvmVNET/subnets/zuhvmSubnet","etag":"W/\"448f5f9a-0819-4a63-a36b-bc78c17fb50f\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuhtest/providers/Microsoft.Network/networkInterfaces/zuhvmVMNic/ipConfigurations/ipconfigzuhvm"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"qianwenhpcc","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwenhpcc","etag":"W/\"6c8aaa6d-3d3c-4dcc-9239-8e8cb4f4276c\"","type":"Microsoft.Network/virtualNetworks","location":"northeurope","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"201936e6-9c56-41c0-91ed-48c3e91d363a","addressSpace":{"addressPrefixes":["10.11.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwenhpcc/subnets/default","etag":"W/\"6c8aaa6d-3d3c-4dcc-9239-8e8cb4f4276c\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.11.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vm1VNET","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fyvm/providers/Microsoft.Network/virtualNetworks/vm1VNET","etag":"W/\"7f51014d-792f-458a-8047-bd433398d7df\"","type":"Microsoft.Network/virtualNetworks","location":"eastasia","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"a808bcca-f2d8-4d18-a891-66f3f79f0572","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"vm1Subnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fyvm/providers/Microsoft.Network/virtualNetworks/vm1VNET/subnets/vm1Subnet","etag":"W/\"7f51014d-792f-458a-8047-bd433398d7df\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fyvm/providers/Microsoft.Network/networkInterfaces/vm1VMNic/ipConfigurations/ipconfigvm1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"qianwens-vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwens-vnet","etag":"W/\"ee382a25-ba6c-455f-9aba-4faf778d6645\"","type":"Microsoft.Network/virtualNetworks","location":"southeastasia","properties":{"provisioningState":"Succeeded","resourceGuid":"a394bdb8-358f-4852-a090-6339e3cb7cbd","addressSpace":{"addressPrefixes":["10.2.3.0/24"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/virtualNetworks/qianwens-vnet/subnets/default","etag":"W/\"ee382a25-ba6c-455f-9aba-4faf778d6645\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.2.3.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-ubuntu473/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-rdp2308/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwencentos539/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-centos8455/ipConfigurations/ipconfig1"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qianwens/providers/Microsoft.Network/networkInterfaces/qianwen-rdp3736/ipConfigurations/ipconfig1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vnettest","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","type":"Microsoft.Network/virtualNetworks","location":"centralus","properties":{"provisioningState":"Succeeded","resourceGuid":"069414bc-bd93-47a1-976e-2e51578a2c72","addressSpace":{"addressPrefixes":["10.1.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/default","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/networkInterfaces/sdfsdfsdf.nic.483f3d12-3ba8-4789-92dd-b7ed9c4d43db/ipConfigurations/sdfsdfsdf_ipconfig_0"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/privateLinkServices/sdfsdfsdf/ipConfigurations/sdfsdfsdf_ipconfig_0"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Disabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"GatewaySubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/GatewaySubnet","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.3.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"test1","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/test1","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.1.0/24","serviceEndpoints":[],"delegations":[],"privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"test2","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/test2","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.2.0/24","serviceEndpoints":[],"delegations":[],"purpose":"PrivateEndpoints","privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"test3","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/test3","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.4.0/24","serviceEndpoints":[],"delegations":[],"purpose":"PrivateEndpoints","privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"test4","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-test/providers/Microsoft.Network/virtualNetworks/vnettest/subnets/test4","etag":"W/\"2a99f2ce-5482-4e66-a221-8a08d60295d0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.1.5.0/24","serviceEndpoints":[],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Disabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"fengnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/feng-cli-rg/providers/Microsoft.Network/virtualNetworks/fengnet","etag":"W/\"ab7fc3cd-5cd6-4589-94a3-051eb2cfaa57\"","type":"Microsoft.Network/virtualNetworks","location":"centralus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"11ee3c60-0e22-44a3-a916-d553364b109e","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/feng-cli-rg/providers/Microsoft.Network/virtualNetworks/fengnet/subnets/default","etag":"W/\"ab7fc3cd-5cd6-4589-94a3-051eb2cfaa57\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"fengtestvnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/feng-cli-rg/providers/Microsoft.Network/virtualNetworks/fengtestvnet","etag":"W/\"d5e7f592-f675-4296-a973-59b532c4ab9f\"","type":"Microsoft.Network/virtualNetworks","location":"centralus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"59680b56-4598-4692-8f56-3ba38d3d2d14","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/feng-cli-rg/providers/Microsoft.Network/virtualNetworks/fengtestvnet/subnets/default","etag":"W/\"d5e7f592-f675-4296-a973-59b532c4ab9f\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"updatesub","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/feng-cli-rg/providers/Microsoft.Network/virtualNetworks/fengtestvnet/subnets/updatesub","etag":"W/\"d5e7f592-f675-4296-a973-59b532c4ab9f\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.1.0/24","serviceEndpoints":[{"provisioningState":"Succeeded","service":"Microsoft.AzureActiveDirectory","locations":["*"]}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"zhoxing-test","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zhoxing-test/providers/Microsoft.Network/virtualNetworks/zhoxing-test","etag":"W/\"90b80523-2b83-47be-9d25-2d0da19ac519\"","type":"Microsoft.Network/virtualNetworks","location":"centralus","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"293fee2e-3a44-4ce6-82ad-22c26e08a733","addressSpace":{"addressPrefixes":["10.13.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zhoxing-test/providers/Microsoft.Network/virtualNetworks/zhoxing-test/subnets/default","etag":"W/\"90b80523-2b83-47be-9d25-2d0da19ac519\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.13.0.0/24","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"zhoxing-test","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zhoxing-test/providers/Microsoft.Network/virtualNetworks/zhoxing-test/subnets/zhoxing-test","etag":"W/\"90b80523-2b83-47be-9d25-2d0da19ac519\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.13.1.0/24","serviceEndpoints":[],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"cli-vnet-lefr-02","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_netappfiles_test_snapshot_vpshzlob7c63iuglneagoxjxa45dqn6eoglhf37oo5cms/providers/Microsoft.Network/virtualNetworks/cli-vnet-lefr-02","etag":"W/\"dab31e4f-5bd7-49f4-9a61-9d62789c0b14\"","type":"Microsoft.Network/virtualNetworks","location":"westus2","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"d0252539-b9d8-4264-bf7a-dfc99802c145","addressSpace":{"addressPrefixes":["10.5.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"cli-subnet-lefr-02","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_netappfiles_test_snapshot_vpshzlob7c63iuglneagoxjxa45dqn6eoglhf37oo5cms/providers/Microsoft.Network/virtualNetworks/cli-vnet-lefr-02/subnets/cli-subnet-lefr-02","etag":"W/\"dab31e4f-5bd7-49f4-9a61-9d62789c0b14\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.5.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_netappfiles_test_snapshot_vpshzlob7c63iuglneagoxjxa45dqn6eoglhf37oo5cms/providers/Microsoft.Network/networkInterfaces/anf-cli-vnet-lefr-02-nic-OP6BGH/ipConfigurations/ipconfig1"}],"delegations":[{"name":"0","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cli_netappfiles_test_snapshot_vpshzlob7c63iuglneagoxjxa45dqn6eoglhf37oo5cms/providers/Microsoft.Network/virtualNetworks/cli-vnet-lefr-02/subnets/cli-subnet-lefr-02/delegations/0","etag":"W/\"dab31e4f-5bd7-49f4-9a61-9d62789c0b14\"","properties":{"provisioningState":"Succeeded","serviceName":"Microsoft.Netapp/volumes","actions":["Microsoft.Network/networkinterfaces/*","Microsoft.Network/virtualNetworks/subnets/join/action"]},"type":"Microsoft.Network/virtualNetworks/subnets/delegations"}],"purpose":"HostedWorkloads","privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"jiasli-cli-dev-vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/jiasli-cli-dev/providers/Microsoft.Network/virtualNetworks/jiasli-cli-dev-vnet","etag":"W/\"d4a0700b-94e7-435b-8855-1d9f6f523e81\"","type":"Microsoft.Network/virtualNetworks","location":"westus2","properties":{"provisioningState":"Succeeded","resourceGuid":"8a6b6633-fb55-48e1-af56-b8757edd9595","addressSpace":{"addressPrefixes":["10.2.1.0/24"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/jiasli-cli-dev/providers/Microsoft.Network/virtualNetworks/jiasli-cli-dev-vnet/subnets/default","etag":"W/\"d4a0700b-94e7-435b-8855-1d9f6f523e81\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.2.1.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/jiasli-cli-dev/providers/Microsoft.Network/networkInterfaces/jlwin846/ipConfigurations/ipconfig1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"sdk-vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-wus2-rg-test/providers/Microsoft.Network/virtualNetworks/sdk-vnet","etag":"W/\"b277f4c3-62f6-411f-b1e3-80ca12a5ea9c\"","type":"Microsoft.Network/virtualNetworks","location":"westus2","properties":{"provisioningState":"Succeeded","resourceGuid":"7637a963-71f9-4aed-905b-8c0f4aed45b9","addressSpace":{"addressPrefixes":["10.6.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-wus2-rg-test/providers/Microsoft.Network/virtualNetworks/sdk-vnet/subnets/default","etag":"W/\"b277f4c3-62f6-411f-b1e3-80ca12a5ea9c\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.6.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-wus2-rg-test/providers/Microsoft.Network/networkInterfaces/anf-sdk-vnet-nic-VLB5RZ/ipConfigurations/ipconfig1"}],"serviceEndpoints":[],"delegations":[{"name":"514c6b63b2df4757ba448bd8f44d10a5","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-wus2-rg-test/providers/Microsoft.Network/virtualNetworks/sdk-vnet/subnets/default/delegations/514c6b63b2df4757ba448bd8f44d10a5","etag":"W/\"b277f4c3-62f6-411f-b1e3-80ca12a5ea9c\"","properties":{"provisioningState":"Succeeded","serviceName":"Microsoft.Netapp/volumes","actions":["Microsoft.Network/networkinterfaces/*","Microsoft.Network/virtualNetworks/subnets/join/action"]},"type":"Microsoft.Network/virtualNetworks/subnets/delegations"}],"purpose":"HostedWorkloads","privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"fanqiu-vm-vnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-vm/providers/Microsoft.Network/virtualNetworks/fanqiu-vm-vnet","etag":"W/\"26b49ce9-cd61-447d-bf92-bdc35e3300f5\"","type":"Microsoft.Network/virtualNetworks","location":"koreacentral","properties":{"provisioningState":"Succeeded","resourceGuid":"b432ede1-6e3a-4fc9-b600-c575f84f20c9","addressSpace":{"addressPrefixes":["10.3.0.0/24"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-vm/providers/Microsoft.Network/virtualNetworks/fanqiu-vm-vnet/subnets/default","etag":"W/\"26b49ce9-cd61-447d-bf92-bdc35e3300f5\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.3.0.0/28","delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"},{"name":"AzureBastionSubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fanqiu-vm/providers/Microsoft.Network/virtualNetworks/fanqiu-vm-vnet/subnets/AzureBastionSubnet","etag":"W/\"26b49ce9-cd61-447d-bf92-bdc35e3300f5\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.3.0.32/27","serviceEndpoints":[],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"bim-vnet3","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim-rg/providers/Microsoft.Network/virtualNetworks/bim-vnet3","etag":"W/\"c8676aab-8991-4de8-929f-b926372792e0\"","type":"Microsoft.Network/virtualNetworks","location":"centraluseuap","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"b343e2a8-eae2-4a21-8eae-0f89c0c927af","addressSpace":{"addressPrefixes":["10.10.0.0/16"]},"subnets":[{"name":"default","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim-rg/providers/Microsoft.Network/virtualNetworks/bim-vnet3/subnets/default","etag":"W/\"c8676aab-8991-4de8-929f-b926372792e0\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.10.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim-rg/providers/Microsoft.Network/networkInterfaces/bim-pe3.nic.405cb318-6279-4d72-8c8c-76914c9f5f89/ipConfigurations/vault-default.privateEndpoint"}],"privateEndpoints":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bim-rg/providers/Microsoft.Network/privateEndpoints/bim-pe3"}],"delegations":[],"privateEndpointNetworkPolicies":"Disabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"vm1VNET","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest/providers/Microsoft.Network/virtualNetworks/vm1VNET","etag":"W/\"a7bcaad2-7ab2-45e3-b2a7-41863ede64c8\"","type":"Microsoft.Network/virtualNetworks","location":"centraluseuap","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"0d1a03ff-12e1-4fae-ade6-d43324a07ed6","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"subnets":[{"name":"vm1Subnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest/providers/Microsoft.Network/virtualNetworks/vm1VNET/subnets/vm1Subnet","etag":"W/\"a7bcaad2-7ab2-45e3-b2a7-41863ede64c8\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/fytest/providers/Microsoft.Network/networkInterfaces/vm1VMNic/ipConfigurations/ipconfigvm1"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}},{"name":"zuhvnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/virtualNetworks/zuhvnet","etag":"W/\"1d10510b-2356-4a7b-b3fc-2db1c9cf0e67\"","type":"Microsoft.Network/virtualNetworks","location":"eastus2euap","tags":{},"properties":{"provisioningState":"Succeeded","resourceGuid":"3dd96fad-bc86-4367-88f2-ea2e0bfac2c9","addressSpace":{"addressPrefixes":["10.0.0.0/16"]},"dhcpOptions":{"dnsServers":[]},"subnets":[{"name":"zuhsubnet","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/virtualNetworks/zuhvnet/subnets/zuhsubnet","etag":"W/\"1d10510b-2356-4a7b-b3fc-2db1c9cf0e67\"","properties":{"provisioningState":"Succeeded","addressPrefix":"10.0.0.0/24","ipConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/applicationGateways/zuhgate/frontendIPConfigurations/appGatewayPrivateFrontendIP"}],"applicationGatewayIPConfigurations":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zuh/providers/Microsoft.Network/applicationGateways/zuhgate/gatewayIPConfigurations/appGatewayFrontendIP"}],"delegations":[],"privateEndpointNetworkPolicies":"Enabled","privateLinkServiceNetworkPolicies":"Enabled"},"type":"Microsoft.Network/virtualNetworks/subnets"}],"virtualNetworkPeerings":[],"enableDdosProtection":false,"enableVmProtection":false}}]}' + string: "{\r\n \"value\": [\r\n {\r\n \"name\": \"rmvirtualnetworkname\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/jc3vgnszph754mtc2q4qhf57x4s6bi7tcc4lqm5h65umgzirugdwlkasogj7miofa2qrs6n2zqd/providers/Microsoft.Network/virtualNetworks/rmvirtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"5768872e-98cb-447d-8fde-ab15cd093395\\\"\",\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"36e2bf7c-b57d-453d-8cc8-300cf005cd3d\"\ + ,\r\n \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \ + \ \"10.2.0.0/16\"\r\n ]\r\n },\r\n \"subnets\"\ + : [],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\"\ + : false,\r\n \"enableVmProtection\": false\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"sdknettestqa2vnet464\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2/providers/Microsoft.Network/virtualNetworks/sdknettestqa2vnet464\"\ + ,\r\n \"etag\": \"W/\\\"b2bf7f8b-0e8a-4410-b275-1f550862ebeb\\\"\",\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {},\r\n \"properties\": {\r\n \ + \ \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"a0cd9266-92c6-44e2-9039-28d28196e9bc\"\ + ,\r\n \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \ + \ \"10.1.0.0/16\"\r\n ]\r\n },\r\n \"subnets\"\ + : [\r\n {\r\n \"name\": \"default\",\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2/providers/Microsoft.Network/virtualNetworks/sdknettestqa2vnet464/subnets/default\"\ + ,\r\n \"etag\": \"W/\\\"b2bf7f8b-0e8a-4410-b275-1f550862ebeb\\\"\ + \",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"addressPrefix\": \"10.1.0.0/24\",\r\n\ + \ \"ipConfigurations\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2/providers/Microsoft.Network/networkInterfaces/anf-sdknettestqa2vnet464-nic-2JBDNX/ipConfigurations/ipconfig1\"\ + \r\n }\r\n ],\r\n \"serviceEndpoints\"\ + : [],\r\n \"delegations\": [\r\n {\r\n \ + \ \"name\": \"858246068f874a3f96e679fc8bf8c983\",\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2/providers/Microsoft.Network/virtualNetworks/sdknettestqa2vnet464/subnets/default/delegations/858246068f874a3f96e679fc8bf8c983\"\ + ,\r\n \"etag\": \"W/\\\"b2bf7f8b-0e8a-4410-b275-1f550862ebeb\\\ + \"\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"serviceName\": \"Microsoft.Netapp/volumes\"\ + ,\r\n \"actions\": [\r\n \"Microsoft.Network/networkinterfaces/*\"\ + ,\r\n \"Microsoft.Network/virtualNetworks/subnets/join/action\"\ + \r\n ]\r\n },\r\n \"\ + type\": \"Microsoft.Network/virtualNetworks/subnets/delegations\"\r\n \ + \ }\r\n ],\r\n \"purpose\": \"HostedWorkloads\"\ + ,\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \ + \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n \ + \ },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\ + \r\n }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\ + \n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n },\r\n {\r\n \"name\": \"virtualnetworkname\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\",\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\"\ + ,\r\n \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \ + \ \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\"\ + : [\r\n {\r\n \"name\": \"subnetname\",\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"efececbd-6baf-4eff-9b8c-407cb66c7c11\\\"\ + \",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n\ + \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"\ + Enabled\"\r\n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\ + \r\n }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\ + \n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n }\r\n ]\r\n}" headers: cache-control: no-cache content-encoding: gzip - content-length: '8255' content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:55 GMT + date: Tue, 26 Jan 2021 07:46:35 GMT expires: '-1' pragma: no-cache + server: Microsoft-HTTPAPI/2.0 strict-transport-security: max-age=31536000; includeSubDomains + transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-original-request-ids: 522fe787-5967-4b79-a45d-6da18f59645e + x-ms-arm-service-request-id: 82ecabd4-e871-4f3a-a059-14c8152d41ff status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/providers/Microsoft.Network/virtualNetworks?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/providers/Microsoft.Network/virtualNetworks?api-version=2020-08-01 - request: body: '{"tags": {"tag1": "value1", "tag2": "value2"}}' headers: @@ -460,33 +527,34 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\",\r\n - \ \"etag\": \"W/\\\"8e48caf5-7e3e-4a33-8677-50174ae6621f\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n - \ },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"45481191-8f9c-4875-af62-0f0c0e345edd\",\r\n \"addressSpace\": - {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\r\n ]\r\n - \ },\r\n \"subnets\": [\r\n {\r\n \"name\": \"subnetname\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\",\r\n - \ \"etag\": \"W/\\\"8e48caf5-7e3e-4a33-8677-50174ae6621f\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": - [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": - \"Enabled\"\r\n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n - \ }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": - false,\r\n \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetworkname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname\"\ + ,\r\n \"etag\": \"W/\\\"a9cda41a-dcdd-4f3e-9356-55ac6d827a87\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"3df2ce00-a40a-46c9-b17a-e65e775c9377\",\r\n \ + \ \"addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [\r\n {\r\n \"name\"\ + : \"subnetname\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname\"\ + ,\r\n \"etag\": \"W/\\\"a9cda41a-dcdd-4f3e-9356-55ac6d827a87\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\"\ + : [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n \ + \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\ + \n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n \ + \ }\r\n ],\r\n \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\"\ + : false,\r\n \"enableVmProtection\": false\r\n }\r\n}" headers: azure-asyncnotification: Enabled cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:56:58 GMT + date: Tue, 26 Jan 2021 07:46:38 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -494,48 +562,48 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 24bc4dd8-80e1-4782-a6fb-d8b934e23e16 - x-ms-ratelimit-remaining-subscription-writes: '1197' + x-ms-arm-service-request-id: 05a1e594-3e14-4869-8dd9-d442322aacee + x-ms-ratelimit-remaining-subscription-writes: '1194' status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 response: body: string: '' headers: - azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f58d029f-8151-4a90-8908-1958b2ff0f08?api-version=2020-07-01 + azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2c7547ff-d89d-4f5c-b733-7e52f3667fc9?api-version=2020-08-01 cache-control: no-cache content-length: '0' - date: Wed, 25 Nov 2020 09:56:59 GMT + date: Tue, 26 Jan 2021 07:46:38 GMT expires: '-1' - location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f58d029f-8151-4a90-8908-1958b2ff0f08?api-version=2020-07-01 + location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2c7547ff-d89d-4f5c-b733-7e52f3667fc9?api-version=2020-08-01 pragma: no-cache server: Microsoft-HTTPAPI/2.0 strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-arm-service-request-id: e7da1063-937c-4acb-9ee3-fb6fbd184c2f - x-ms-ratelimit-remaining-subscription-deletes: '14999' + x-ms-arm-service-request-id: b02c4194-7c81-4c46-ac05-855fc087fcf5 + x-ms-ratelimit-remaining-subscription-deletes: '14996' status: code: 202 message: Accepted - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname/subnets/subnetname?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f58d029f-8151-4a90-8908-1958b2ff0f08?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2c7547ff-d89d-4f5c-b733-7e52f3667fc9?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -543,7 +611,7 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:57:09 GMT + date: Tue, 26 Jan 2021 07:46:49 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -551,48 +619,48 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: d68db633-6c58-47d0-8348-c8448b7ab118 + x-ms-arm-service-request-id: 51f5432d-ac4c-45b3-bdbc-d37b7437a7a4 status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/providers/Microsoft.Network/locations/eastus/operations/f58d029f-8151-4a90-8908-1958b2ff0f08?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/providers/Microsoft.Network/locations/eastus/operations/2c7547ff-d89d-4f5c-b733-7e52f3667fc9?api-version=2020-08-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 response: body: string: '' headers: azure-asyncnotification: Enabled - azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b0a31564-f727-4376-9663-b8258b8e1a20?api-version=2020-07-01 + azure-asyncoperation: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/28529362-83aa-45d3-a747-ce33525193d8?api-version=2020-08-01 cache-control: no-cache content-length: '0' - date: Wed, 25 Nov 2020 09:57:10 GMT + date: Tue, 26 Jan 2021 07:46:49 GMT expires: '-1' - location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b0a31564-f727-4376-9663-b8258b8e1a20?api-version=2020-07-01 + location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/28529362-83aa-45d3-a747-ce33525193d8?api-version=2020-08-01 pragma: no-cache server: Microsoft-HTTPAPI/2.0 strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-arm-service-request-id: b35340a9-cc43-4325-ac16-664843baa289 - x-ms-ratelimit-remaining-subscription-deletes: '14998' + x-ms-arm-service-request-id: 423b7409-5c55-4ec7-9be7-3b90380b5654 + x-ms-ratelimit-remaining-subscription-deletes: '14995' status: code: 202 message: Accepted - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/resourceGroups/nupdi2gt57jcwuuewbv7g246nafmcjusaa3zvg5e7gmegsbpwzjck6gxjbfdkkp6jsr4it4bkng/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/v5h2sddw72q5ofyg6ogv6mz4zvo7ucaz35e4oyy4qi6fj33ts5cftes3knk4lsyqjazno73g6fn/providers/Microsoft.Network/virtualNetworks/virtualnetworkname?api-version=2020-08-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/b0a31564-f727-4376-9663-b8258b8e1a20?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/28529362-83aa-45d3-a747-ce33525193d8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -600,7 +668,7 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Wed, 25 Nov 2020 09:57:20 GMT + date: Tue, 26 Jan 2021 07:47:00 GMT expires: '-1' pragma: no-cache server: Microsoft-HTTPAPI/2.0 @@ -608,9 +676,9 @@ interactions: transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-arm-service-request-id: 02212522-ce2e-4dac-ab40-4a959c65baa1 + x-ms-arm-service-request-id: 2771bb01-013a-44bc-a74c-cc5d9d7e8b2e status: code: 200 message: OK - url: https://management.azure.com/subscriptions/0b1f6471-1bf0-4dda-aec3-cb9272f09590/providers/Microsoft.Network/locations/eastus/operations/b0a31564-f727-4376-9663-b8258b8e1a20?api-version=2020-07-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/providers/Microsoft.Network/locations/eastus/operations/28529362-83aa-45d3-a747-ce33525193d8?api-version=2020-08-01 version: 1 diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ddos.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ddos.test_network.yaml index 42f33e2622a7..8e20b626fb83 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ddos.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ddos.test_network.yaml @@ -14,24 +14,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035\",\r\n - \ \"etag\": \"W/\\\"381652f5-7445-40bd-8a2f-2c439dc53972\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"5f829d6b-f14f-443f-a291-cbf464f980cc\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"fa5501ff-a938-41b0-9e55-ca15ae9175fc\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"01632b6c-3a76-4bf1-9027-a6bb4a2b2225\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0422bfe7-ad81-46e5-ab0d-4acfe69af0c8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/23f634ae-f302-456d-a3eb-3e36dd306c3e?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:40 GMT + - Tue, 26 Jan 2021 07:47:17 GMT expires: - '-1' pragma: @@ -52,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fd5e2ceb-a2d3-4610-a63d-5888868d694a + - a8572923-3d6f-4a77-8e0d-45259a5329c2 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1196' status: code: 201 message: Created @@ -68,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0422bfe7-ad81-46e5-ab0d-4acfe69af0c8?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/23f634ae-f302-456d-a3eb-3e36dd306c3e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:45 GMT + - Tue, 26 Jan 2021 07:47:20 GMT expires: - '-1' pragma: @@ -99,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3d6c6719-b315-41a8-9b41-dba300ca1d19 + - d3dce243-1450-4d33-ac72-ec15dfd487fb status: code: 200 message: OK @@ -113,19 +114,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035\",\r\n - \ \"etag\": \"W/\\\"dc7a09e8-f52e-42ed-9520-0502a594e4a9\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"5f829d6b-f14f-443f-a291-cbf464f980cc\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"5726c423-2a27-447b-835a-c94bd52990ed\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"01632b6c-3a76-4bf1-9027-a6bb4a2b2225\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: cache-control: - no-cache @@ -134,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:45 GMT + - Tue, 26 Jan 2021 07:47:21 GMT etag: - - W/"dc7a09e8-f52e-42ed-9520-0502a594e4a9" + - W/"5726c423-2a27-447b-835a-c94bd52990ed" expires: - '-1' pragma: @@ -153,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ee6c2fdd-dc2d-42f7-93c1-b2a856536a7b + - 526bbb79-90e9-4fe0-965f-af29303c843a status: code: 200 message: OK @@ -171,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\",\r\n - \ \"etag\": \"W/\\\"c9036375-a636-48f9-9199-3c82e80267df\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"701a2b07-620c-4317-bdb1-c5affdef4ad0\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/803637a7-5220-4be0-b076-2433ca31a6f5?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a86e8e60-fd68-4753-bd99-2d8fb66ec392?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -192,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:46 GMT + - Tue, 26 Jan 2021 07:47:22 GMT expires: - '-1' pragma: @@ -205,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 92a40ea0-5def-4818-8e76-5b8bef3dc0e4 + - 73cea9a0-baa8-4988-8401-54ac28066bb0 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1195' status: code: 201 message: Created @@ -221,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/803637a7-5220-4be0-b076-2433ca31a6f5?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a86e8e60-fd68-4753-bd99-2d8fb66ec392?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -235,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:49 GMT + - Tue, 26 Jan 2021 07:47:25 GMT expires: - '-1' pragma: @@ -252,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 043abbbc-21b9-4a83-a579-d688a8afef92 + - 1d09f4ec-fcfe-49db-88d2-ed707c59f502 status: code: 200 message: OK @@ -266,17 +268,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\",\r\n - \ \"etag\": \"W/\\\"49fe8a48-687d-46a3-a93b-c88e2e67382a\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"b71100a6-e2a5-4b70-ae31-a1f07786911b\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: - no-cache @@ -285,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:49 GMT + - Tue, 26 Jan 2021 07:47:25 GMT etag: - - W/"49fe8a48-687d-46a3-a93b-c88e2e67382a" + - W/"b71100a6-e2a5-4b70-ae31-a1f07786911b" expires: - '-1' pragma: @@ -304,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b6777f83-d1bd-4869-ac3b-a59794516fe1 + - 92caa620-6732-46d0-9a08-f360713d18e4 status: code: 200 message: OK @@ -323,33 +325,35 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"interface43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\",\r\n - \ \"etag\": \"W/\\\"4ba0cbc4-0b64-40e9-bb70-0683f112c37b\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"ac71bb5a-fde1-4412-9941-3886442aaf1a\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"MyIpConfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035/ipConfigurations/MyIpConfig\",\r\n - \ \"etag\": \"W/\\\"4ba0cbc4-0b64-40e9-bb70-0683f112c37b\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"nooyex0p4e5ujiurzp0gj4maze.bx.internal.cloudapp.net\"\r\n },\r\n \"enableAcceleratedNetworking\": - false,\r\n \"enableIPForwarding\": false,\r\n \"hostedWorkloads\": [],\r\n - \ \"tapConfigurations\": [],\r\n \"nicType\": \"Standard\"\r\n },\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"interface43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"e1f2880b-5b2a-49df-9edb-8a5a6821858c\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"7edce5de-a9c7-419c-8809-f0cfcb460c52\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035/ipConfigurations/MyIpConfig\"\ + ,\r\n \"etag\": \"W/\\\"e1f2880b-5b2a-49df-9edb-8a5a6821858c\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nqvwgalwhlyuxebhu03uukzcef.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ + : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0c72e98a-2b20-45c2-ae1b-4c0aa0ab8e9a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/98da8b7d-f702-4b63-85fc-dff6569d9a11?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -357,7 +361,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:27:54 GMT + - Tue, 26 Jan 2021 07:47:30 GMT expires: - '-1' pragma: @@ -370,9 +374,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9c595dd1-5331-4c8a-af1b-732e5a5d1b48 + - 986850a0-8c4e-407f-8c84-bf9f1aeeb7cd x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1194' status: code: 201 message: Created @@ -386,9 +390,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0c72e98a-2b20-45c2-ae1b-4c0aa0ab8e9a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/98da8b7d-f702-4b63-85fc-dff6569d9a11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -400,7 +404,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:28:24 GMT + - Tue, 26 Jan 2021 07:48:01 GMT expires: - '-1' pragma: @@ -417,7 +421,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4dd26cff-97ac-463e-a9c7-5ffceab5a2f0 + - 38eddcd3-43c7-4cf4-8e98-6d3665aad373 status: code: 200 message: OK @@ -431,28 +435,30 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"interface43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\",\r\n - \ \"etag\": \"W/\\\"4ba0cbc4-0b64-40e9-bb70-0683f112c37b\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"ac71bb5a-fde1-4412-9941-3886442aaf1a\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"MyIpConfig\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035/ipConfigurations/MyIpConfig\",\r\n - \ \"etag\": \"W/\\\"4ba0cbc4-0b64-40e9-bb70-0683f112c37b\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"nooyex0p4e5ujiurzp0gj4maze.bx.internal.cloudapp.net\"\r\n },\r\n \"enableAcceleratedNetworking\": - false,\r\n \"enableIPForwarding\": false,\r\n \"hostedWorkloads\": [],\r\n - \ \"tapConfigurations\": [],\r\n \"nicType\": \"Standard\"\r\n },\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"interface43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"e1f2880b-5b2a-49df-9edb-8a5a6821858c\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"7edce5de-a9c7-419c-8809-f0cfcb460c52\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035/ipConfigurations/MyIpConfig\"\ + ,\r\n \"etag\": \"W/\\\"e1f2880b-5b2a-49df-9edb-8a5a6821858c\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork43ae1035/subnets/subnet43ae1035\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nqvwgalwhlyuxebhu03uukzcef.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ + : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: cache-control: - no-cache @@ -461,9 +467,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:28:24 GMT + - Tue, 26 Jan 2021 07:48:01 GMT etag: - - W/"4ba0cbc4-0b64-40e9-bb70-0683f112c37b" + - W/"e1f2880b-5b2a-49df-9edb-8a5a6821858c" expires: - '-1' pragma: @@ -480,7 +486,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a0d8fde2-b6ae-4b59-988f-88bb865d9efb + - 1629597b-148a-44cc-abec-5a8ca5ff43b5 status: code: 200 message: OK @@ -507,54 +513,58 @@ interactions: Content-Type: - application/json; charset=utf-8 User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035?api-version=2020-06-01 response: body: - string: "{\r\n \"name\": \"virtualmachine43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035\",\r\n - \ \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"vmId\": \"dec47879-9728-4cdb-96f4-3cebe132d439\",\r\n - \ \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n },\r\n - \ \"storageProfile\": {\r\n \"imageReference\": {\r\n \"publisher\": - \"MicrosoftWindowsServer\",\r\n \"offer\": \"WindowsServer\",\r\n \"sku\": - \"2016-Datacenter\",\r\n \"version\": \"latest\",\r\n \"exactVersion\": - \"14393.4048.2011170655\"\r\n },\r\n \"osDisk\": {\r\n \"osType\": - \"Windows\",\r\n \"name\": \"myVMosdisk\",\r\n \"createOption\": - \"FromImage\",\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n - \ \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": [\r\n {\r\n - \ \"lun\": 0,\r\n \"createOption\": \"Empty\",\r\n \"caching\": - \"None\",\r\n \"managedDisk\": {\r\n \"storageAccountType\": - \"Standard_LRS\"\r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"createOption\": - \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n - \ \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n }\r\n - \ ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\": \"myVM\",\r\n - \ \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\": - {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\": - true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\r\n - \ }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\": - true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\": - {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\",\"properties\":{\"primary\":true}}]},\r\n - \ \"provisioningState\": \"Creating\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualmachine43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035\"\ + ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"35c99a4d-1564-4c2e-bef2-21a0ca3015dd\"\ + ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ + \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ + \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ + WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ + \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ + \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ + ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ + \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ + \ \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": [\r\n \ + \ {\r\n \"lun\": 0,\r\n \"createOption\": \"Empty\",\r\n\ + \ \"caching\": \"None\",\r\n \"managedDisk\": {\r\n \ + \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ + \ \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n \ + \ },\r\n {\r\n \"lun\": 1,\r\n \"createOption\"\ + : \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\"\ + : {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\ + \n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n\ + \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ + : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ + : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ + : true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\ + \r\n }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ + : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ + networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\"\ + ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ + \r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/53aa19a0-c8cf-494e-8127-f4160a85e019?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1e01e43d-615e-4495-be2c-c3e6cbb6c5f5?api-version=2020-06-01 cache-control: - no-cache content-length: - - '2314' + - '2421' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:28:33 GMT + - Tue, 26 Jan 2021 07:48:09 GMT expires: - '-1' pragma: @@ -567,9 +577,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;743,Microsoft.Compute/PutVM30Min;3719 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1199 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1188' status: code: 201 message: Created @@ -583,14 +593,15 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/53aa19a0-c8cf-494e-8127-f4160a85e019?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1e01e43d-615e-4495-be2c-c3e6cbb6c5f5?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:28:31.6478199+00:00\",\r\n \"status\": - \"InProgress\",\r\n \"name\": \"53aa19a0-c8cf-494e-8127-f4160a85e019\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T07:48:08.3226829+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"1e01e43d-615e-4495-be2c-c3e6cbb6c5f5\"\ + \r\n}" headers: cache-control: - no-cache @@ -599,7 +610,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:28:43 GMT + - Tue, 26 Jan 2021 07:48:20 GMT expires: - '-1' pragma: @@ -630,23 +641,24 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/53aa19a0-c8cf-494e-8127-f4160a85e019?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1e01e43d-615e-4495-be2c-c3e6cbb6c5f5?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:28:31.6478199+00:00\",\r\n \"status\": - \"InProgress\",\r\n \"name\": \"53aa19a0-c8cf-494e-8127-f4160a85e019\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T07:48:08.3226829+00:00\",\r\n \"\ + endTime\": \"2021-01-26T07:49:05.228986+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"1e01e43d-615e-4495-be2c-c3e6cbb6c5f5\"\r\n}" headers: cache-control: - no-cache content-length: - - '134' + - '183' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:29:34 GMT + - Tue, 26 Jan 2021 07:49:10 GMT expires: - '-1' pragma: @@ -677,101 +689,57 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/53aa19a0-c8cf-494e-8127-f4160a85e019?api-version=2020-06-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-26T06:28:31.6478199+00:00\",\r\n \"endTime\": - \"2020-11-26T06:29:57.2733004+00:00\",\r\n \"status\": \"Succeeded\",\r\n - \ \"name\": \"53aa19a0-c8cf-494e-8127-f4160a85e019\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '184' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 26 Nov 2020 06:30:05 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14996,Microsoft.Compute/GetOperation30Min;29996 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035?api-version=2020-06-01 response: body: - string: "{\r\n \"name\": \"virtualmachine43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035\",\r\n - \ \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"vmId\": \"dec47879-9728-4cdb-96f4-3cebe132d439\",\r\n - \ \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n },\r\n - \ \"storageProfile\": {\r\n \"imageReference\": {\r\n \"publisher\": - \"MicrosoftWindowsServer\",\r\n \"offer\": \"WindowsServer\",\r\n \"sku\": - \"2016-Datacenter\",\r\n \"version\": \"latest\",\r\n \"exactVersion\": - \"14393.4048.2011170655\"\r\n },\r\n \"osDisk\": {\r\n \"osType\": - \"Windows\",\r\n \"name\": \"myVMosdisk\",\r\n \"createOption\": - \"FromImage\",\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\r\n - \ },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": - [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine43ae1035_disk2_48819c9d8320437695986f39e287fd6e\",\r\n - \ \"createOption\": \"Empty\",\r\n \"caching\": \"None\",\r\n - \ \"managedDisk\": {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine43ae1035_disk2_48819c9d8320437695986f39e287fd6e\"\r\n - \ },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"name\": - \"virtualmachine43ae1035_disk3_5d4f17ec87194f85a76a362bb1c9dfb6\",\r\n \"createOption\": - \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine43ae1035_disk3_5d4f17ec87194f85a76a362bb1c9dfb6\"\r\n - \ },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\": - \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\": - {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\": - true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\r\n - \ }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\": - true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\": - {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\",\"properties\":{\"primary\":true}}]},\r\n - \ \"provisioningState\": \"Succeeded\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualmachine43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine43ae1035\"\ + ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"35c99a4d-1564-4c2e-bef2-21a0ca3015dd\"\ + ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ + \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ + \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ + WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ + \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ + \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ + ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ + \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ + \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ + : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine43ae1035_disk2_b08bcd24c4d14d77b241da82e05885db\"\ + ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ + ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine43ae1035_disk2_b08bcd24c4d14d77b241da82e05885db\"\ + \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ + : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ + name\": \"virtualmachine43ae1035_disk3_d1f5a0be07eb4a8097630012f8e628e2\"\ + ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ + ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine43ae1035_disk3_d1f5a0be07eb4a8097630012f8e628e2\"\ + \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ + : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ + \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ + \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ + \n \"enableAutomaticUpdates\": true,\r\n \"patchSettings\":\ + \ {\r\n \"patchMode\": \"AutomaticByOS\"\r\n }\r\n },\r\ + \n \"secrets\": [],\r\n \"allowExtensionOperations\": true,\r\n\ + \ \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\"\ + : {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface43ae1035\"\ + ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '3213' + - '3320' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:05 GMT + - Tue, 26 Jan 2021 07:49:11 GMT expires: - '-1' pragma: @@ -807,24 +775,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\",\r\n - \ \"etag\": \"W/\\\"aa0400ed-a1fc-4ce1-9ecb-80b78f2a789e\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"resourceGuid\": \"c51d5797-bffa-461f-ab17-3b5cfa040afd\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddress43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"b5eaaae4-8c96-4222-ba0b-43bef71091d8\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"resourceGuid\": \"6bc6127f-4242-44fc-abf8-9fbeaf17c934\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Static\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\n\ + \ },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n\ + }" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b3d1cf4e-ee90-46ee-9248-373b45fa1613?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/189193ad-9f96-483f-8630-a57a42dfcb1c?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -832,7 +801,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:12 GMT + - Tue, 26 Jan 2021 07:49:20 GMT expires: - '-1' pragma: @@ -845,9 +814,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cb01213f-ded2-4b64-a2b8-227b7af55296 + - f0acc34d-0cf6-44ba-97a5-53e166e69c7d x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1193' status: code: 201 message: Created @@ -861,9 +830,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/b3d1cf4e-ee90-46ee-9248-373b45fa1613?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/189193ad-9f96-483f-8630-a57a42dfcb1c?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -875,7 +844,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:14 GMT + - Tue, 26 Jan 2021 07:49:22 GMT expires: - '-1' pragma: @@ -892,7 +861,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6011bc7a-e628-4cc1-8616-67e1ccddfd35 + - 72e83acb-dfe4-48b9-80ef-56046dd14ef0 status: code: 200 message: OK @@ -906,19 +875,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\",\r\n - \ \"etag\": \"W/\\\"a6f501bf-a6fc-49ca-96b6-fead1e1ce321\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"c51d5797-bffa-461f-ab17-3b5cfa040afd\",\r\n \"ipAddress\": - \"20.62.217.137\",\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\": - \"Static\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\n - \ },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\": - {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipaddress43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"0230b43c-b89b-4a24-8e75-67810a9eaaa1\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"6bc6127f-4242-44fc-abf8-9fbeaf17c934\"\ + ,\r\n \"ipAddress\": \"40.121.47.163\",\r\n \"publicIPAddressVersion\"\ + : \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\"\ + ,\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache @@ -927,9 +897,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:14 GMT + - Tue, 26 Jan 2021 07:49:22 GMT etag: - - W/"a6f501bf-a6fc-49ca-96b6-fead1e1ce321" + - W/"0230b43c-b89b-4a24-8e75-67810a9eaaa1" expires: - '-1' pragma: @@ -946,7 +916,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2ba67015-d61f-453a-91a8-b463c1896743 + - dded454f-af19-494a-ae6d-a7c92d63b27e status: code: 200 message: OK @@ -965,24 +935,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/bastionvirutalnetwork43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"bastionvirutalnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035\",\r\n - \ \"etag\": \"W/\\\"ecabaa88-e272-41f9-a1e5-1bf4eb7754ce\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"ca365d7b-8a99-4747-a78a-9acf276fa4c0\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"bastionvirutalnetwork43ae1035\",\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"3d91e0e5-fe91-4b53-9f9e-a582de3ad1b3\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"68bb15b0-e244-4924-9adc-bc9556293a82\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/49b0cb0c-53a5-4c3e-9af3-89fd7771ec0e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca927ae4-0eb0-4e78-91b5-8f7c21849ade?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -990,7 +962,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:19 GMT + - Tue, 26 Jan 2021 07:49:27 GMT expires: - '-1' pragma: @@ -1003,9 +975,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1be9b8d0-25e4-4e94-b6b7-87c476406df7 + - 41444f27-a8af-44af-9e71-11bd4d87f28d x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1192' status: code: 201 message: Created @@ -1019,9 +991,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/49b0cb0c-53a5-4c3e-9af3-89fd7771ec0e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca927ae4-0eb0-4e78-91b5-8f7c21849ade?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1033,7 +1005,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:22 GMT + - Tue, 26 Jan 2021 07:49:30 GMT expires: - '-1' pragma: @@ -1050,7 +1022,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e7eb8020-04ab-4d81-bcc8-fb4ce45b34ba + - 7b889d35-e521-4d5d-8cf7-2c164769d5f4 status: code: 200 message: OK @@ -1064,19 +1036,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/bastionvirutalnetwork43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"bastionvirutalnetwork43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035\",\r\n - \ \"etag\": \"W/\\\"f81d64be-a9ba-4417-9deb-eea8b85951ab\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"ca365d7b-8a99-4747-a78a-9acf276fa4c0\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"bastionvirutalnetwork43ae1035\",\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"b1f862a6-8cb1-4c10-92f0-2323c52ae485\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"68bb15b0-e244-4924-9adc-bc9556293a82\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: cache-control: - no-cache @@ -1085,9 +1059,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:23 GMT + - Tue, 26 Jan 2021 07:49:31 GMT etag: - - W/"f81d64be-a9ba-4417-9deb-eea8b85951ab" + - W/"b1f862a6-8cb1-4c10-92f0-2323c52ae485" expires: - '-1' pragma: @@ -1104,7 +1078,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 68fbe28a-0c52-4808-843f-ae4caeec6a45 + - 9626d8bd-aeb8-4071-b665-c7d7412aa408 status: code: 200 message: OK @@ -1122,20 +1096,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"AzureBastionSubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\",\r\n - \ \"etag\": \"W/\\\"9b19f8ad-ecc5-4572-a050-b384e51b516d\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"AzureBastionSubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\ + ,\r\n \"etag\": \"W/\\\"177f247c-38a1-47be-ba4d-9e6000e5381f\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d1c0bb39-cd93-4512-a4b7-5d9ccc9c5536?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f4767e5b-e033-457b-9a28-adb22ab6639c?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1143,7 +1117,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:23 GMT + - Tue, 26 Jan 2021 07:49:31 GMT expires: - '-1' pragma: @@ -1156,9 +1130,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ab8844f9-6089-4431-85e1-136d6c1c4ce6 + - 336caba0-f678-437a-a959-85d4e23a72b5 x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1191' status: code: 201 message: Created @@ -1172,9 +1146,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d1c0bb39-cd93-4512-a4b7-5d9ccc9c5536?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f4767e5b-e033-457b-9a28-adb22ab6639c?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1186,7 +1160,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:26 GMT + - Tue, 26 Jan 2021 07:49:35 GMT expires: - '-1' pragma: @@ -1203,7 +1177,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0bc6e60c-9605-4fed-b4dc-04f752b8219f + - 72730638-fa3c-46ec-adb3-7aaf9de7ca78 status: code: 200 message: OK @@ -1217,17 +1191,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"AzureBastionSubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\",\r\n - \ \"etag\": \"W/\\\"0d5a730b-3449-4b08-83ff-7d37f8b541f2\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"AzureBastionSubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\ + ,\r\n \"etag\": \"W/\\\"85c9b035-ef19-4c4e-9cef-577b52ae5732\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: - no-cache @@ -1236,9 +1210,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:27 GMT + - Tue, 26 Jan 2021 07:49:35 GMT etag: - - W/"0d5a730b-3449-4b08-83ff-7d37f8b541f2" + - W/"85c9b035-ef19-4c4e-9cef-577b52ae5732" expires: - '-1' pragma: @@ -1255,7 +1229,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b21b5cee-a370-4257-a067-0ae95367dcd2 + - cdec604c-583a-4a18-aab7-f95a30d03fe0 status: code: 200 message: OK @@ -1275,30 +1249,30 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/bastionHosts/bastionhost43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\",\r\n - \ \"etag\": \"W/\\\"3787448f-5d25-4f71-8e45-526e9e07e8c7\\\"\",\r\n \"type\": - \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"scaleUnits\": 2,\r\n - \ \"ipConfigurations\": [\r\n {\r\n \"name\": \"bastionHostIpConfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"3787448f-5d25-4f71-8e45-526e9e07e8c7\\\"\",\r\n - \ \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\": - {}\r\n }\r\n}" + string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"b72a6c07-67ef-4efe-9031-5b907a8334a2\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"scaleUnits\": 2,\r\n \"ipConfigurations\": [\r\n {\r\n \ + \ \"name\": \"bastionHostIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"b72a6c07-67ef-4efe-9031-5b907a8334a2\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\"\ + : {}\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1306,7 +1280,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:30 GMT + - Tue, 26 Jan 2021 07:49:39 GMT expires: - '-1' pragma: @@ -1319,9 +1293,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 667864d5-5dc5-4c35-b76b-e789f8fb32d4 + - 1b1fcc4b-391a-488d-bff1-f108ca7a2749 x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1190' status: code: 201 message: Created @@ -1335,9 +1309,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1349,7 +1323,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:41 GMT + - Tue, 26 Jan 2021 07:49:49 GMT expires: - '-1' pragma: @@ -1366,7 +1340,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 00adbcc9-91b6-4031-b626-fb476dc2dc04 + - 88131a24-8a70-4b51-a3a2-79042adc7016 status: code: 200 message: OK @@ -1380,9 +1354,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1394,7 +1368,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:30:51 GMT + - Tue, 26 Jan 2021 07:49:59 GMT expires: - '-1' pragma: @@ -1411,7 +1385,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3d5671b5-f1a4-4dbb-9ed0-19c0fabfabe0 + - 8702dcd5-4d5e-4ff1-ad33-b587f735cd71 status: code: 200 message: OK @@ -1425,9 +1399,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1439,7 +1413,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:31:11 GMT + - Tue, 26 Jan 2021 07:50:20 GMT expires: - '-1' pragma: @@ -1456,7 +1430,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 03591ceb-0ebc-4798-a634-007796231fed + - fe30edf1-0282-4eb9-976d-1cada0e2b127 status: code: 200 message: OK @@ -1470,9 +1444,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1484,7 +1458,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:31:31 GMT + - Tue, 26 Jan 2021 07:50:40 GMT expires: - '-1' pragma: @@ -1501,7 +1475,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d003020a-67b4-4a98-816e-51c12b6d7fcc + - b91cfb71-ea15-4a40-a9c5-b6bbc3f8d3f5 status: code: 200 message: OK @@ -1515,9 +1489,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1529,7 +1503,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:32:11 GMT + - Tue, 26 Jan 2021 07:51:21 GMT expires: - '-1' pragma: @@ -1546,7 +1520,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c5ab977d-1aa2-43db-8b14-83569f811b30 + - 35f64017-c954-467f-ab61-1c11d06eec61 status: code: 200 message: OK @@ -1560,9 +1534,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1574,7 +1548,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:32:51 GMT + - Tue, 26 Jan 2021 07:52:01 GMT expires: - '-1' pragma: @@ -1591,7 +1565,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 508f0f2c-8d11-4d2d-b45f-9b2e7d514efb + - 8c18f303-67c4-4728-b0e4-b906104083d8 status: code: 200 message: OK @@ -1605,9 +1579,54 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/096ef521-c72e-4bc3-b3b9-e736a0ae543a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 07:53:21 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - b61df59e-fec2-4d6c-afb4-2afdec054e42 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d550e41c-d76c-4f11-b47d-462060f44e11?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1619,7 +1638,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:13 GMT + - Tue, 26 Jan 2021 07:56:03 GMT expires: - '-1' pragma: @@ -1636,7 +1655,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3163624c-cb43-4415-bd39-2cc75470f1d3 + - 32e326bb-6fc4-4717-8009-bfc5a6d4b4a4 status: code: 200 message: OK @@ -1650,25 +1669,26 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/bastionHosts/bastionhost43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\",\r\n - \ \"etag\": \"W/\\\"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23\\\"\",\r\n \"type\": - \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"dnsName\": \"bst-6ab7f018-0e4d-482f-9a8f-4d4028639df6.bastion.azure.com\",\r\n - \ \"scaleUnits\": 2,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"bastionHostIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23\\\"\",\r\n - \ \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\": - {}\r\n }\r\n}" + string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"9080547d-2b5a-4543-b513-72df364eebef\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"dnsName\": \"bst-a67328f7-a4e5-4518-b95b-fa58861bd18f.bastion.azure.com\"\ + ,\r\n \"scaleUnits\": 2,\r\n \"ipConfigurations\": [\r\n {\r\n\ + \ \"name\": \"bastionHostIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"9080547d-2b5a-4543-b513-72df364eebef\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\"\ + : {}\r\n }\r\n}" headers: cache-control: - no-cache @@ -1677,9 +1697,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:14 GMT + - Tue, 26 Jan 2021 07:56:03 GMT etag: - - W/"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23" + - W/"9080547d-2b5a-4543-b513-72df364eebef" expires: - '-1' pragma: @@ -1696,7 +1716,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 01bf04af-f69c-4bd3-9124-58a9d1faee0a + - 6de3c5bc-ae82-4a61-96de-783423247f03 status: code: 200 message: OK @@ -1714,20 +1734,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\",\r\n - \ \"etag\": \"W/\\\"60195a1a-768d-4b6c-ac86-adae03ea136e\\\"\",\r\n \"type\": - \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\r\n }\r\n}" + string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"3d66e350-0152-46ea-b328-7581173683fb\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\":\ + \ \"westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + \r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8da4a2e7-66fc-4ca2-87d2-dc684db4eff0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/754150ef-a3d0-4b0d-8a0a-10cc2f47cd61?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1735,7 +1756,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:22 GMT + - Tue, 26 Jan 2021 07:56:11 GMT expires: - '-1' pragma: @@ -1748,9 +1769,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d387c3d5-4094-4cbc-aa25-5a42a0053316 + - a13122f2-c77a-4104-ba8a-e4bc0669c93b x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1198' status: code: 201 message: Created @@ -1764,9 +1785,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/8da4a2e7-66fc-4ca2-87d2-dc684db4eff0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/754150ef-a3d0-4b0d-8a0a-10cc2f47cd61?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1778,7 +1799,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:53 GMT + - Tue, 26 Jan 2021 07:56:41 GMT expires: - '-1' pragma: @@ -1795,7 +1816,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 92396a78-96c0-4c73-be99-7813a617f253 + - 74c73810-5fd4-4894-987d-a74b70804651 status: code: 200 message: OK @@ -1809,15 +1830,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\",\r\n - \ \"etag\": \"W/\\\"60195a1a-768d-4b6c-ac86-adae03ea136e\\\"\",\r\n \"type\": - \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\r\n }\r\n}" + string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"3d66e350-0152-46ea-b328-7581173683fb\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\":\ + \ \"westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + \r\n }\r\n}" headers: cache-control: - no-cache @@ -1826,9 +1848,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:53 GMT + - Tue, 26 Jan 2021 07:56:42 GMT etag: - - W/"60195a1a-768d-4b6c-ac86-adae03ea136e" + - W/"3d66e350-0152-46ea-b328-7581173683fb" expires: - '-1' pragma: @@ -1845,7 +1867,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a881114-565a-4d88-88a1-8e4a642ed117 + - 6d31bc24-0a52-4036-a00e-321bfdd3cfb2 status: code: 200 message: OK @@ -1859,15 +1881,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\",\r\n - \ \"etag\": \"W/\\\"60195a1a-768d-4b6c-ac86-adae03ea136e\\\"\",\r\n \"type\": - \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\r\n }\r\n}" + string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"3d66e350-0152-46ea-b328-7581173683fb\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\":\ + \ \"westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + \r\n }\r\n}" headers: cache-control: - no-cache @@ -1876,9 +1899,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:53 GMT + - Tue, 26 Jan 2021 07:56:42 GMT etag: - - W/"60195a1a-768d-4b6c-ac86-adae03ea136e" + - W/"3d66e350-0152-46ea-b328-7581173683fb" expires: - '-1' pragma: @@ -1895,7 +1918,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2c31b21b-bfd4-4660-9c63-124dd0c9ec9d + - 1c2c959a-658c-4569-bc34-23f7d660088c status: code: 200 message: OK @@ -1909,25 +1932,26 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/bastionHosts/bastionhost43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\",\r\n - \ \"etag\": \"W/\\\"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23\\\"\",\r\n \"type\": - \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"dnsName\": \"bst-6ab7f018-0e4d-482f-9a8f-4d4028639df6.bastion.azure.com\",\r\n - \ \"scaleUnits\": 2,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"bastionHostIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23\\\"\",\r\n - \ \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\": - {}\r\n }\r\n}" + string: "{\r\n \"name\": \"bastionhost43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"9080547d-2b5a-4543-b513-72df364eebef\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/bastionHosts\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"dnsName\": \"bst-a67328f7-a4e5-4518-b95b-fa58861bd18f.bastion.azure.com\"\ + ,\r\n \"scaleUnits\": 2,\r\n \"ipConfigurations\": [\r\n {\r\n\ + \ \"name\": \"bastionHostIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035/bastionHostIpConfigurations/bastionHostIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"9080547d-2b5a-4543-b513-72df364eebef\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/bastionHosts/bastionHostIpConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress43ae1035\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/bastionvirutalnetwork43ae1035/subnets/AzureBastionSubnet\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"bastionShareableLinks\"\ + : {}\r\n }\r\n}" headers: cache-control: - no-cache @@ -1936,9 +1960,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:53 GMT + - Tue, 26 Jan 2021 07:56:42 GMT etag: - - W/"3a07faa6-1fe2-454f-9cb2-3c4e493e6e23" + - W/"9080547d-2b5a-4543-b513-72df364eebef" expires: - '-1' pragma: @@ -1955,7 +1979,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b7583436-4d12-4388-9beb-8991758298ff + - d23d6378-3e39-44f4-91e8-b5373c60706a status: code: 200 message: OK @@ -1969,9 +1993,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/CheckDnsNameAvailability?domainNameLabel=testdns43ae1035&api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/CheckDnsNameAvailability?domainNameLabel=testdns43ae1035&api-version=2020-08-01 response: body: string: "{\r\n \"available\": true\r\n}" @@ -1983,7 +2007,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:54 GMT + - Tue, 26 Jan 2021 07:56:43 GMT expires: - '-1' pragma: @@ -2000,7 +2024,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 91f45bc3-eb2b-4f22-abc3-a16d161fff0b + - 51e676f8-c2d8-48f8-9d89-6446368d8a73 status: code: 200 message: OK @@ -2018,17 +2042,17 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\",\r\n - \ \"etag\": \"W/\\\"3216fdd3-ca66-43b9-ad5d-81f4bea2df8b\\\"\",\r\n \"type\": - \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n - \ },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"ddosprotectionplan43ae1035\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035\"\ + ,\r\n \"etag\": \"W/\\\"2d81264a-fbc1-4a30-bfe0-ffeee292fbd6\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ddosProtectionPlans\",\r\n \"location\":\ + \ \"westus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ + : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ + \ \"Succeeded\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -2039,7 +2063,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:34:57 GMT + - Tue, 26 Jan 2021 07:56:46 GMT expires: - '-1' pragma: @@ -2056,9 +2080,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 24ecfc41-6051-4365-b930-e34b0658d6c1 + - cfb453d6-36be-4d82-8bf3-26e3ed7027e4 x-ms-ratelimit-remaining-subscription-writes: - - '1191' + - '1197' status: code: 200 message: OK @@ -2074,9 +2098,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ddosProtectionPlans/ddosprotectionplan43ae1035?api-version=2020-08-01 response: body: string: '' @@ -2084,17 +2108,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/d2206eba-8089-4780-8cd8-da497c10a60d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/75d50781-1d63-4e15-8749-e9f599b6edd2?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:34:58 GMT + - Tue, 26 Jan 2021 07:56:47 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/d2206eba-8089-4780-8cd8-da497c10a60d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/75d50781-1d63-4e15-8749-e9f599b6edd2?api-version=2020-08-01 pragma: - no-cache server: @@ -2105,9 +2129,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bf1ca942-3016-409a-9bd9-38ab12702b62 + - 671be2e2-fe1c-4135-a558-9fc52515f206 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14998' status: code: 202 message: Accepted @@ -2121,9 +2145,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/d2206eba-8089-4780-8cd8-da497c10a60d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/75d50781-1d63-4e15-8749-e9f599b6edd2?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2135,7 +2159,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:35:09 GMT + - Tue, 26 Jan 2021 07:56:57 GMT expires: - '-1' pragma: @@ -2152,7 +2176,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7487f00a-f0d1-47c4-bdea-6e552bd0ace0 + - f59df35b-49ca-4534-a6d1-dae8c1e2baa7 status: code: 200 message: OK @@ -2168,9 +2192,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/bastionHosts/bastionhost43ae1035?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/bastionHosts/bastionhost43ae1035?api-version=2020-08-01 response: body: string: '' @@ -2178,17 +2202,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:35:09 GMT + - Tue, 26 Jan 2021 07:56:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 pragma: - no-cache server: @@ -2199,9 +2223,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c00f5295-07d2-40b0-b32c-e407ffa4bf31 + - b1688609-e10e-413e-9b85-a71b529d0e1a x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14997' status: code: 202 message: Accepted @@ -2215,99 +2239,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 26 Nov 2020 06:35:20 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - c1c90b28-0ada-4574-bea6-5ddede3901cb - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 26 Nov 2020 06:35:32 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 17cbc136-f067-495f-b4b8-e02e179237fc - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2319,7 +2253,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:35:52 GMT + - Tue, 26 Jan 2021 07:57:09 GMT expires: - '-1' pragma: @@ -2336,7 +2270,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 811ade49-0547-4ee5-933f-8d43e866db54 + - bc65d381-42c0-4943-8fa2-ba9ef4386845 status: code: 200 message: OK @@ -2350,9 +2284,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2364,7 +2298,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:36:12 GMT + - Tue, 26 Jan 2021 07:57:19 GMT expires: - '-1' pragma: @@ -2381,7 +2315,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7fd6a61a-3b8a-4cd6-9cd7-65a239fcea90 + - 479ab28e-d82e-49d3-862f-2ec302bdd50d status: code: 200 message: OK @@ -2395,9 +2329,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2409,7 +2343,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:36:52 GMT + - Tue, 26 Jan 2021 07:57:39 GMT expires: - '-1' pragma: @@ -2426,7 +2360,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fac549d9-c6cf-4691-8508-1b5181336e37 + - 83395b4f-c180-4614-aad8-5c07232a4f8c status: code: 200 message: OK @@ -2440,9 +2374,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2454,7 +2388,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:37:33 GMT + - Tue, 26 Jan 2021 07:58:00 GMT expires: - '-1' pragma: @@ -2471,7 +2405,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - de960180-0633-4c21-b2e1-82b50b0f5da1 + - 323f0a3a-14d0-4be4-9111-ca89692a4d67 status: code: 200 message: OK @@ -2485,9 +2419,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2499,7 +2433,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:38:55 GMT + - Tue, 26 Jan 2021 07:58:41 GMT expires: - '-1' pragma: @@ -2516,7 +2450,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ad88cbc3-a993-4d5a-a0a4-8f8d1a4df801 + - 36d649a7-4900-4d72-92f4-fcb4d4e6db12 status: code: 200 message: OK @@ -2530,9 +2464,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2544,7 +2478,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:41:35 GMT + - Tue, 26 Jan 2021 07:59:21 GMT expires: - '-1' pragma: @@ -2561,7 +2495,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 47da50f6-94ad-4e8d-a8c3-8937adb98fe3 + - 1eac7c7d-554c-4f1b-b2d8-cf83c9035fe5 status: code: 200 message: OK @@ -2575,9 +2509,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2589,7 +2523,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:43:17 GMT + - Tue, 26 Jan 2021 08:00:42 GMT expires: - '-1' pragma: @@ -2606,7 +2540,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f9d91fb5-9195-479a-a041-e43855f52f71 + - d7f22232-d1d1-4616-aa21-b8666da19ca6 status: code: 200 message: OK @@ -2620,9 +2554,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/71636c40-c210-49fe-b9f2-62c15d66f514?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7c0071d-de62-447b-995a-96a5a7cb96cd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2634,7 +2568,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:44:57 GMT + - Tue, 26 Jan 2021 08:03:23 GMT expires: - '-1' pragma: @@ -2651,7 +2585,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bc719edb-6cab-4e8e-80ab-17736a9b739b + - 1a5447a9-9bd2-4fae-a9b4-a7611b8a46da status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint.test_network.yaml index 8f6d96971a6f..e2e0aad303ea 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint.test_network.yaml @@ -14,24 +14,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\",\r\n - \ \"etag\": \"W/\\\"b8438c56-4e5a-46a1-b8cd-021d13281b57\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"96040423-f6a7-452e-b11c-25c962b5949f\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\"\ + ,\r\n \"etag\": \"W/\\\"55a62d4f-c7a9-4eec-b860-e482fb60d880\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"dbf2c372-5eb3-4f00-8d6a-372fa948cfb2\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c2639d1-fa7f-4b42-9e48-5df4e837e977?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c4d06579-ccf3-4757-9910-6bc35a1a82ba?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:26 GMT + - Tue, 26 Jan 2021 08:03:43 GMT expires: - '-1' pragma: @@ -52,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 203d6dac-bf9b-4a95-853f-2b3c229967b8 + - 0c822e6d-db1d-4506-a612-ba25f18ef1f7 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1195' status: code: 201 message: Created @@ -68,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3c2639d1-fa7f-4b42-9e48-5df4e837e977?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c4d06579-ccf3-4757-9910-6bc35a1a82ba?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:30 GMT + - Tue, 26 Jan 2021 08:03:46 GMT expires: - '-1' pragma: @@ -99,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b868dd4f-4e3a-45b8-8f28-0221ba867e72 + - 55b5629c-0970-409c-9aa8-e5489defae95 status: code: 200 message: OK @@ -113,19 +114,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\",\r\n - \ \"etag\": \"W/\\\"ad81240d-128a-46d9-99c5-bda6fc0c6f38\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"96040423-f6a7-452e-b11c-25c962b5949f\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\"\ + ,\r\n \"etag\": \"W/\\\"9cf6ec66-f061-4834-94b0-9f6d6e98dc4a\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"dbf2c372-5eb3-4f00-8d6a-372fa948cfb2\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: cache-control: - no-cache @@ -134,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:30 GMT + - Tue, 26 Jan 2021 08:03:47 GMT etag: - - W/"ad81240d-128a-46d9-99c5-bda6fc0c6f38" + - W/"9cf6ec66-f061-4834-94b0-9f6d6e98dc4a" expires: - '-1' pragma: @@ -153,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 79380a3b-9b48-4870-93c6-611ea900fc63 + - 9172cbcf-de94-4006-9dd3-74a03a059bb6 status: code: 200 message: OK @@ -172,20 +174,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\",\r\n - \ \"etag\": \"W/\\\"d6cb2130-8764-4f23-b969-fae7158a5b98\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Disabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + ,\r\n \"etag\": \"W/\\\"bf744e00-a90e-4564-8dbd-8818639fdc80\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Disabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/52412656-6f95-4b75-99e9-b4e7c482feb5?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5821f123-1bba-478e-9ec0-27379b083618?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -193,7 +195,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:31 GMT + - Tue, 26 Jan 2021 08:03:48 GMT expires: - '-1' pragma: @@ -206,9 +208,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 79e7ef13-8f0f-4991-bd06-86ee9529698d + - d97f4de7-0e2d-4026-ac2a-ddcdf2a4a126 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1194' status: code: 201 message: Created @@ -222,9 +224,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/52412656-6f95-4b75-99e9-b4e7c482feb5?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5821f123-1bba-478e-9ec0-27379b083618?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -236,7 +238,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:34 GMT + - Tue, 26 Jan 2021 08:03:52 GMT expires: - '-1' pragma: @@ -253,7 +255,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c7157704-a436-4df5-a540-b24aa93c0576 + - a93d1eda-0fe2-4cf9-a8a6-a99904e016cf status: code: 200 message: OK @@ -267,17 +269,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\",\r\n - \ \"etag\": \"W/\\\"c4f507d4-b463-4393-a978-50f79081546c\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Disabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + ,\r\n \"etag\": \"W/\\\"0395a0f4-d386-4c1e-9f01-197f98beec22\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Disabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: - no-cache @@ -286,9 +288,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:35 GMT + - Tue, 26 Jan 2021 08:03:52 GMT etag: - - W/"c4f507d4-b463-4393-a978-50f79081546c" + - W/"0395a0f4-d386-4c1e-9f01-197f98beec22" expires: - '-1' pragma: @@ -305,7 +307,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 195e92a7-f5f5-44b0-8790-3acfb20ae3a2 + - bc7beaac-1388-4dc6-be6c-8862d0029097 status: code: 200 message: OK @@ -324,20 +326,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\",\r\n - \ \"etag\": \"W/\\\"212102af-f2f3-44e8-823c-aa0b0e8ef9c0\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.1.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Disabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\ + ,\r\n \"etag\": \"W/\\\"e4ae7410-3f11-48eb-8295-87f7f8bc8969\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.1.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Disabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6ea5e3d3-5c02-4f55-a4cf-d55b43106f41?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c2178be4-a013-4a33-bbed-e48c1fda77c8?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -345,7 +347,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:35 GMT + - Tue, 26 Jan 2021 08:03:53 GMT expires: - '-1' pragma: @@ -358,9 +360,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 060975ae-ed61-4d00-b441-9b2a267056d9 + - eb6b0e10-301b-430b-81df-190c948fa56b x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1193' status: code: 201 message: Created @@ -374,9 +376,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/6ea5e3d3-5c02-4f55-a4cf-d55b43106f41?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c2178be4-a013-4a33-bbed-e48c1fda77c8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -388,7 +390,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:38 GMT + - Tue, 26 Jan 2021 08:03:56 GMT expires: - '-1' pragma: @@ -405,7 +407,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0fce5554-d4de-46ce-866c-f69c6ef0ed84 + - 0a760792-8269-44e9-9c44-8eb300a3975c status: code: 200 message: OK @@ -419,17 +421,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\",\r\n - \ \"etag\": \"W/\\\"b54c7b15-198d-4b09-a8cb-3d860588a283\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.1.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Disabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\ + ,\r\n \"etag\": \"W/\\\"a52521cf-cb0c-4481-b711-6bf2c18c9272\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.1.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Disabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: - no-cache @@ -438,9 +440,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:39 GMT + - Tue, 26 Jan 2021 08:03:56 GMT etag: - - W/"b54c7b15-198d-4b09-a8cb-3d860588a283" + - W/"a52521cf-cb0c-4481-b711-6bf2c18c9272" expires: - '-1' pragma: @@ -457,7 +459,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9bce6c74-f69b-4617-b661-3b13ed92866a + - 084a7c14-6874-4b5b-b23d-013b6517f256 status: code: 200 message: OK @@ -476,32 +478,34 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/loadbalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"loadbalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer\",\r\n - \ \"etag\": \"W/\\\"b93f01bd-dd87-4a1b-abb8-92854b0be36d\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": \"5594153f-5d4a-4b8e-95a2-2fb7de1262d1\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myIPConfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"b93f01bd-dd87-4a1b-abb8-92854b0be36d\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n }\r\n - \ }\r\n ],\r\n \"backendAddressPools\": [],\r\n \"loadBalancingRules\": - [],\r\n \"probes\": [],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\": - [],\r\n \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": - \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"loadbalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer\"\ + ,\r\n \"etag\": \"W/\\\"f698082b-43ed-4595-a4d1-dc4dd2a75100\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"79554529-95d0-4119-9c9f-08d2ced9f39a\",\r\n \"\ + frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myIPConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"f698082b-43ed-4595-a4d1-dc4dd2a75100\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n \ + \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [],\r\n \"\ + loadBalancingRules\": [],\r\n \"probes\": [],\r\n \"inboundNatRules\"\ + : [],\r\n \"outboundRules\": [],\r\n \"inboundNatPools\": []\r\n },\r\ + \n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/9d457b55-cd75-4c22-b762-eed34d74c6bf?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/72fe4412-45b5-40ac-a4e9-6dc1ab9c0b13?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -509,7 +513,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:44 GMT + - Tue, 26 Jan 2021 08:04:01 GMT expires: - '-1' pragma: @@ -522,9 +526,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6022bb2f-f249-4676-bd69-f9d1803a4270 + - 53ddee3c-1f1a-4128-8286-df2c65c293fd x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1192' status: code: 201 message: Created @@ -538,9 +542,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/9d457b55-cd75-4c22-b762-eed34d74c6bf?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/72fe4412-45b5-40ac-a4e9-6dc1ab9c0b13?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -552,7 +556,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:54 GMT + - Tue, 26 Jan 2021 08:04:12 GMT expires: - '-1' pragma: @@ -569,7 +573,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 57d38ab4-46a1-446c-8e5a-a58903b44324 + - f5a8ed97-b122-40fd-b5cc-fa6f9974e6d5 status: code: 200 message: OK @@ -583,27 +587,29 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/loadbalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"loadbalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer\",\r\n - \ \"etag\": \"W/\\\"9e24181f-66ae-4f51-ad88-02344c0078e8\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"5594153f-5d4a-4b8e-95a2-2fb7de1262d1\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myIPConfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"9e24181f-66ae-4f51-ad88-02344c0078e8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n }\r\n - \ }\r\n ],\r\n \"backendAddressPools\": [],\r\n \"loadBalancingRules\": - [],\r\n \"probes\": [],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\": - [],\r\n \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": - \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"loadbalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer\"\ + ,\r\n \"etag\": \"W/\\\"8de7c8e5-3adf-44b1-9834-af7291206660\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"79554529-95d0-4119-9c9f-08d2ced9f39a\",\r\n \"\ + frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myIPConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"8de7c8e5-3adf-44b1-9834-af7291206660\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n \ + \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [],\r\n \"\ + loadBalancingRules\": [],\r\n \"probes\": [],\r\n \"inboundNatRules\"\ + : [],\r\n \"outboundRules\": [],\r\n \"inboundNatPools\": []\r\n },\r\ + \n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache @@ -612,9 +618,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:47:54 GMT + - Tue, 26 Jan 2021 08:04:12 GMT etag: - - W/"9e24181f-66ae-4f51-ad88-02344c0078e8" + - W/"8de7c8e5-3adf-44b1-9834-af7291206660" expires: - '-1' pragma: @@ -631,7 +637,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7098a829-9516-4e9e-9e69-4173011c14fe + - 86c94f6a-bcc1-4708-ae6b-e741ae1d5fdc status: code: 200 message: OK @@ -655,38 +661,39 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"etag\": \"W/\\\"38ebca09-93cf-4d47-a998-7a26b90d7ad3\\\"\",\r\n \"type\": - \"Microsoft.Network/privateLinkServices\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"328a3e20-724a-4d20-9686-ae4af9fe67e4\",\r\n \"fqdns\": [\r\n \"fqdn1\",\r\n - \ \"fqdn2\",\r\n \"fqdn3\"\r\n ],\r\n \"alias\": \"myservice.4fa7db5a-643e-4361-a1d7-33446780645c.eastus.azure.privatelinkservice\",\r\n - \ \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n - \ ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\": [\r\n - \ \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n },\r\n - \ \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\r\n - \ }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"38ebca09-93cf-4d47-a998-7a26b90d7ad3\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"subnet\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\": - [],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.6d95599e-9861-436a-9a81-9549646d3ff7\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"etag\": \"W/\\\"5a4bfcad-0324-4647-a4b7-f5ec8ac2f8d1\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateLinkServices\",\r\n \"location\":\ + \ \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"resourceGuid\": \"f4ff6ce6-3871-4264-a7e9-0aebd018b326\",\r\n \ + \ \"fqdns\": [\r\n \"fqdn1\",\r\n \"fqdn2\",\r\n \"fqdn3\"\ + \r\n ],\r\n \"alias\": \"myservice.a7112f56-49cc-421c-8806-26ee8085f2cc.eastus.azure.privatelinkservice\"\ + ,\r\n \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\ + \r\n ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\"\ + : [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n \ + \ },\r\n \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + \r\n }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \ + \ \"name\": \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"5a4bfcad-0324-4647-a4b7-f5ec8ac2f8d1\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\"\ + : [],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.33737f74-f7da-49fe-8f01-bdb9de646e25\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/07a153a6-d196-492b-9d6b-abb2d618414d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4d2baa69-c97b-4ed8-9dc4-420f7f0eed36?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -694,7 +701,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:02 GMT + - Tue, 26 Jan 2021 08:04:17 GMT expires: - '-1' pragma: @@ -707,9 +714,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 032c75cf-dbb6-4a9c-9a5c-be982a50d01e + - 145eb2ed-46af-447b-866e-f36c4d64683a x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1191' status: code: 201 message: Created @@ -723,9 +730,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/07a153a6-d196-492b-9d6b-abb2d618414d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4d2baa69-c97b-4ed8-9dc4-420f7f0eed36?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -737,7 +744,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:12 GMT + - Tue, 26 Jan 2021 08:04:28 GMT expires: - '-1' pragma: @@ -754,7 +761,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e663d295-e67a-40cd-928d-ea23f0424782 + - 47159031-97a4-4693-a3de-d731cb0f09df status: code: 200 message: OK @@ -768,33 +775,34 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"etag\": \"W/\\\"3c144e04-304d-4e7f-9fea-11bb96ebd00b\\\"\",\r\n \"type\": - \"Microsoft.Network/privateLinkServices\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"328a3e20-724a-4d20-9686-ae4af9fe67e4\",\r\n \"fqdns\": [\r\n \"fqdn1\",\r\n - \ \"fqdn2\",\r\n \"fqdn3\"\r\n ],\r\n \"alias\": \"myservice.4fa7db5a-643e-4361-a1d7-33446780645c.eastus.azure.privatelinkservice\",\r\n - \ \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n - \ ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\": [\r\n - \ \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n },\r\n - \ \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\r\n - \ }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"3c144e04-304d-4e7f-9fea-11bb96ebd00b\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"subnet\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\": - [],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.6d95599e-9861-436a-9a81-9549646d3ff7\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"etag\": \"W/\\\"b46deee3-ed39-4309-8bf9-bc5a960d543f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateLinkServices\",\r\n \"location\":\ + \ \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"f4ff6ce6-3871-4264-a7e9-0aebd018b326\",\r\n \ + \ \"fqdns\": [\r\n \"fqdn1\",\r\n \"fqdn2\",\r\n \"fqdn3\"\ + \r\n ],\r\n \"alias\": \"myservice.a7112f56-49cc-421c-8806-26ee8085f2cc.eastus.azure.privatelinkservice\"\ + ,\r\n \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\ + \r\n ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\"\ + : [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n \ + \ },\r\n \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + \r\n }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \ + \ \"name\": \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"b46deee3-ed39-4309-8bf9-bc5a960d543f\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\"\ + : [],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.33737f74-f7da-49fe-8f01-bdb9de646e25\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -803,9 +811,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:12 GMT + - Tue, 26 Jan 2021 08:04:28 GMT etag: - - W/"3c144e04-304d-4e7f-9fea-11bb96ebd00b" + - W/"b46deee3-ed39-4309-8bf9-bc5a960d543f" expires: - '-1' pragma: @@ -822,7 +830,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 05a6a12c-8087-460e-8e81-6ff78fce244f + - 58d2c0d6-63e9-4474-9614-d7d470695a4e status: code: 200 message: OK @@ -842,32 +850,35 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\",\r\n - \ \"etag\": \"W/\\\"95825663-4be4-46be-beac-61bd528cd499\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n \"privateLinkServiceConnections\": - [\r\n {\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\",\r\n - \ \"etag\": \"W/\\\"95825663-4be4-46be-beac-61bd528cd499\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"\",\r\n \"actionsRequired\": - \"None\"\r\n }\r\n },\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\r\n - \ }\r\n ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\n - \ \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\r\n - \ },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.e64dc9f3-7f52-4e27-a5f9-572c8bd61b5c\"\r\n - \ }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + ,\r\n \"etag\": \"W/\\\"0032ecaa-3480-4621-9f50-1968a8970888\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"\ + eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"resourceGuid\": \"2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\",\r\n \ + \ \"privateLinkServiceConnections\": [\r\n {\r\n \"name\": \"\ + myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\"\ + ,\r\n \"etag\": \"W/\\\"0032ecaa-3480-4621-9f50-1968a8970888\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"privateLinkServiceConnectionState\": {\r\n \"\ + status\": \"Approved\",\r\n \"description\": \"\",\r\n \ + \ \"actionsRequired\": \"None\"\r\n }\r\n },\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\ + \r\n }\r\n ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\ + \n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\ + \r\n },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.91fba56f-9782-466c-ac27-102ed8f3a738\"\ + \r\n }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/35ac1eef-b25f-41ac-9b8c-6ec34647999f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5bb864ef-0379-4134-9067-b78f4692f7ff?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -875,7 +886,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:18 GMT + - Tue, 26 Jan 2021 08:04:33 GMT expires: - '-1' pragma: @@ -888,9 +899,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 91aa7ac7-0208-4b2a-b0ff-eb89d5ba99d9 + - a6e4c50d-e413-4b92-8f3e-01fe773a5242 x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1190' status: code: 201 message: Created @@ -904,54 +915,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/35ac1eef-b25f-41ac-9b8c-6ec34647999f?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 26 Nov 2020 06:48:28 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 901241f1-8297-4d65-b719-865de3c7fd3b - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/35ac1eef-b25f-41ac-9b8c-6ec34647999f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5bb864ef-0379-4134-9067-b78f4692f7ff?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -963,7 +929,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:49 GMT + - Tue, 26 Jan 2021 08:04:43 GMT expires: - '-1' pragma: @@ -980,7 +946,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fae3d167-fc43-47b7-8876-5b297ec30380 + - 98394864-42e9-4573-afe2-4b13171c539f status: code: 200 message: OK @@ -994,27 +960,30 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\",\r\n - \ \"etag\": \"W/\\\"886046f7-c658-4ff0-918a-434be502396b\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n \"privateLinkServiceConnections\": - [\r\n {\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\",\r\n - \ \"etag\": \"W/\\\"886046f7-c658-4ff0-918a-434be502396b\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"Approved\",\r\n \"actionsRequired\": - \"None\"\r\n }\r\n },\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\r\n - \ }\r\n ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\n - \ \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\r\n - \ },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.e64dc9f3-7f52-4e27-a5f9-572c8bd61b5c\"\r\n - \ }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + ,\r\n \"etag\": \"W/\\\"d39ec0e2-dacb-4ab0-bebb-e22b1edeb61f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"\ + eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\",\r\n \ + \ \"privateLinkServiceConnections\": [\r\n {\r\n \"name\": \"\ + myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\"\ + ,\r\n \"etag\": \"W/\\\"d39ec0e2-dacb-4ab0-bebb-e22b1edeb61f\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"privateLinkServiceConnectionState\": {\r\n \"\ + status\": \"Approved\",\r\n \"description\": \"Approved\",\r\n\ + \ \"actionsRequired\": \"None\"\r\n }\r\n },\r\n\ + \ \"type\": \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\ + \r\n }\r\n ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\ + \n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\ + \r\n },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.91fba56f-9782-466c-ac27-102ed8f3a738\"\ + \r\n }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" headers: cache-control: - no-cache @@ -1023,9 +992,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:49 GMT + - Tue, 26 Jan 2021 08:04:43 GMT etag: - - W/"886046f7-c658-4ff0-918a-434be502396b" + - W/"d39ec0e2-dacb-4ab0-bebb-e22b1edeb61f" expires: - '-1' pragma: @@ -1042,7 +1011,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ee58bde5-91ba-475b-add7-bd19df51b360 + - 61a03160-bb94-4b10-b717-c87e4943f4be status: code: 200 message: OK @@ -1056,43 +1025,45 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"etag\": \"W/\\\"a076f27d-ae8f-4341-a0c7-f1230f0ec3f3\\\"\",\r\n \"type\": - \"Microsoft.Network/privateLinkServices\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"328a3e20-724a-4d20-9686-ae4af9fe67e4\",\r\n \"fqdns\": [\r\n \"fqdn1\",\r\n - \ \"fqdn2\",\r\n \"fqdn3\"\r\n ],\r\n \"alias\": \"myservice.4fa7db5a-643e-4361-a1d7-33446780645c.eastus.azure.privatelinkservice\",\r\n - \ \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n - \ ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\": [\r\n - \ \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n },\r\n - \ \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\r\n - \ }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"a076f27d-ae8f-4341-a0c7-f1230f0ec3f3\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"subnet\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\": - [\r\n {\r\n \"name\": \"myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"etag\": \"W/\\\"a076f27d-ae8f-4341-a0c7-f1230f0ec3f3\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\r\n - \ },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"Approved\",\r\n \"actionsRequired\": - \"None\"\r\n },\r\n \"linkIdentifier\": \"536890164\"\r\n - \ },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\r\n - \ }\r\n ],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.6d95599e-9861-436a-9a81-9549646d3ff7\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"etag\": \"W/\\\"663a58cc-c0d4-4a61-b80f-4774fc9ed14c\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateLinkServices\",\r\n \"location\":\ + \ \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"f4ff6ce6-3871-4264-a7e9-0aebd018b326\",\r\n \ + \ \"fqdns\": [\r\n \"fqdn1\",\r\n \"fqdn2\",\r\n \"fqdn3\"\ + \r\n ],\r\n \"alias\": \"myservice.a7112f56-49cc-421c-8806-26ee8085f2cc.eastus.azure.privatelinkservice\"\ + ,\r\n \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\ + \r\n ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\"\ + : [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n \ + \ },\r\n \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + \r\n }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \ + \ \"name\": \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"663a58cc-c0d4-4a61-b80f-4774fc9ed14c\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\"\ + : [\r\n {\r\n \"name\": \"myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"etag\": \"W/\\\"663a58cc-c0d4-4a61-b80f-4774fc9ed14c\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + \r\n },\r\n \"privateLinkServiceConnectionState\": {\r\n\ + \ \"status\": \"Approved\",\r\n \"description\": \"\ + Approved\",\r\n \"actionsRequired\": \"None\"\r\n },\r\ + \n \"linkIdentifier\": \"536928101\"\r\n },\r\n \"\ + type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\ + \r\n }\r\n ],\r\n \"networkInterfaces\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.33737f74-f7da-49fe-8f01-bdb9de646e25\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -1101,9 +1072,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:49 GMT + - Tue, 26 Jan 2021 08:04:44 GMT etag: - - W/"a076f27d-ae8f-4341-a0c7-f1230f0ec3f3" + - W/"663a58cc-c0d4-4a61-b80f-4774fc9ed14c" expires: - '-1' pragma: @@ -1120,12 +1091,12 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2f21b37e-170d-4452-91af-5014b1d54516 + - 55c5a306-5f55-44b6-8715-80f0118624cc status: code: 200 message: OK - request: - body: '{"name": "myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99", "properties": + body: '{"name": "myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3", "properties": {"privateLinkServiceConnectionState": {"status": "Approved", "description": "approved it for some reason."}}}' headers: @@ -1140,23 +1111,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"etag\": \"W/\\\"90781a94-3fa2-4995-88f4-b1987a50d7c5\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"privateEndpoint\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\r\n - \ },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"approved it for some reason.\",\r\n - \ \"actionsRequired\": \"\"\r\n },\r\n \"linkIdentifier\": \"536890164\"\r\n - \ },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\r\n}" + string: "{\r\n \"name\": \"myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"etag\": \"W/\\\"2c82d4ea-4169-4a5c-bde7-bf8ad23b19e5\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + \r\n },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\"\ + : \"Approved\",\r\n \"description\": \"approved it for some reason.\"\ + ,\r\n \"actionsRequired\": \"\"\r\n },\r\n \"linkIdentifier\":\ + \ \"536928101\"\r\n },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\ + \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0a90f315-1a5e-4461-a65b-d651791a2a93?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5e774793-edb8-44cb-9701-ea8dce75db8b?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1164,7 +1136,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:50 GMT + - Tue, 26 Jan 2021 08:04:44 GMT expires: - '-1' pragma: @@ -1181,9 +1153,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7ba63a76-3a2c-4dca-8b1b-39c143518c44 + - c949a8b9-0cf9-4616-9a4c-dc2ed6b30675 x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1189' status: code: 200 message: OK @@ -1201,8 +1173,8 @@ interactions: Content-Type: - application/json; charset=utf-8 User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-privatedns/0.1.0 Azure-SDK-For-Python + - 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-privatedns/0.1.0 Azure-SDK-For-Python accept-language: - en-US method: PUT @@ -1212,7 +1184,7 @@ interactions: string: '{}' headers: azure-asyncoperation: - - https://management.azure.com:443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationStatuses/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTszY2Y5YjUyZS0zODgyLTQ0MDMtODBhYi1iYWJmMGY0MjM0ZjQ=?api-version=2018-09-01 + - https://management.azure.com:443/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationStatuses/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTtkODI5MTljMi1lODk3LTRiZGYtOGYwMy00ODlhNzY1MTlmZTM=?api-version=2018-09-01 cache-control: - private content-length: @@ -1220,9 +1192,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:48:57 GMT + - Tue, 26 Jan 2021 08:04:49 GMT location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationResults/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTszY2Y5YjUyZS0zODgyLTQ0MDMtODBhYi1iYWJmMGY0MjM0ZjQ=?api-version=2018-09-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationResults/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTtkODI5MTljMi1lODk3LTRiZGYtOGYwMy00ODlhNzY1MTlmZTM=?api-version=2018-09-01 server: - Microsoft-IIS/10.0 strict-transport-security: @@ -1248,10 +1220,10 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-privatedns/0.1.0 Azure-SDK-For-Python + - 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-privatedns/0.1.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationStatuses/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTszY2Y5YjUyZS0zODgyLTQ0MDMtODBhYi1iYWJmMGY0MjM0ZjQ=?api-version=2018-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsOperationStatuses/RnJvbnRFbmRBc3luY09wZXJhdGlvbjtVcHNlcnRQcml2YXRlRG5zWm9uZTtkODI5MTljMi1lODk3LTRiZGYtOGYwMy00ODlhNzY1MTlmZTM=?api-version=2018-09-01 response: body: string: '{"status":"Succeeded"}' @@ -1263,7 +1235,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:28 GMT + - Tue, 26 Jan 2021 08:05:20 GMT server: - Microsoft-IIS/10.0 strict-transport-security: @@ -1293,13 +1265,13 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-privatedns/0.1.0 Azure-SDK-For-Python + - 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-privatedns/0.1.0 Azure-SDK-For-Python method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com?api-version=2018-09-01 response: body: - string: '{"id":"\/subscriptions\/00000000-0000-0000-0000-000000000000\/resourceGroups\/rgname\/providers\/Microsoft.Network\/privateDnsZones\/www.zone1.com","name":"www.zone1.com","type":"Microsoft.Network\/privateDnsZones","etag":"eaa4679d-cf90-48e6-8653-8c959ac9ae43","location":"global","properties":{"maxNumberOfRecordSets":25000,"maxNumberOfVirtualNetworkLinks":1000,"maxNumberOfVirtualNetworkLinksWithRegistration":100,"numberOfRecordSets":1,"numberOfVirtualNetworkLinks":0,"numberOfVirtualNetworkLinksWithRegistration":0,"provisioningState":"Succeeded"}}' + string: '{"id":"\/subscriptions\/00000000-0000-0000-0000-000000000000\/resourceGroups\/rgname\/providers\/Microsoft.Network\/privateDnsZones\/www.zone1.com","name":"www.zone1.com","type":"Microsoft.Network\/privateDnsZones","etag":"f6622f3f-acee-4b7e-867c-3b6cb2690465","location":"global","properties":{"maxNumberOfRecordSets":25000,"maxNumberOfVirtualNetworkLinks":1000,"maxNumberOfVirtualNetworkLinksWithRegistration":100,"numberOfRecordSets":1,"numberOfVirtualNetworkLinks":0,"numberOfVirtualNetworkLinksWithRegistration":0,"provisioningState":"Succeeded"}}' headers: cache-control: - private @@ -1308,9 +1280,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:28 GMT + - Tue, 26 Jan 2021 08:05:20 GMT etag: - - eaa4679d-cf90-48e6-8653-8c959ac9ae43 + - f6622f3f-acee-4b7e-867c-3b6cb2690465 server: - Microsoft-IIS/10.0 strict-transport-security: @@ -1345,24 +1317,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\",\r\n - \ \"etag\": \"W/\\\"eaff3a38-3dde-4fe4-b4b9-f2c963fce810\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"privateDnsZoneConfigs\": - [\r\n {\r\n \"name\": \"zone1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\",\r\n - \ \"etag\": \"W/\\\"eaff3a38-3dde-4fe4-b4b9-f2c963fce810\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\",\r\n - \ \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\"\ + ,\r\n \"etag\": \"W/\\\"605e323c-e344-483a-a473-0a862d5082ee\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + privateDnsZoneConfigs\": [\r\n {\r\n \"name\": \"zone1\",\r\n\ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\"\ + ,\r\n \"etag\": \"W/\\\"605e323c-e344-483a-a473-0a862d5082ee\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\"\ + ,\r\n \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\ + \n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c47f1a91-8e54-46cc-88f6-34d7dcaf4d42?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/363b0883-96bd-46d0-9a94-b70003b511c2?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1370,7 +1344,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:30 GMT + - Tue, 26 Jan 2021 08:05:22 GMT expires: - '-1' pragma: @@ -1383,9 +1357,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 143d4ce4-4e0e-400f-8a2c-b960add94ed7 + - 765214df-34fa-41f8-ac42-db4e1b03aa39 x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1188' status: code: 201 message: Created @@ -1399,9 +1373,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/c47f1a91-8e54-46cc-88f6-34d7dcaf4d42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/363b0883-96bd-46d0-9a94-b70003b511c2?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1413,7 +1387,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:41 GMT + - Tue, 26 Jan 2021 08:05:32 GMT expires: - '-1' pragma: @@ -1430,7 +1404,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 49b3bbf0-3248-4154-a1d8-d962d9969697 + - ade0ec3b-45b0-4e5a-9287-c35544bf0ab9 status: code: 200 message: OK @@ -1444,21 +1418,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"privateDnsZoneConfigs\": - [\r\n {\r\n \"name\": \"zone1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\",\r\n - \ \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \ + \ \"privateDnsZoneConfigs\": [\r\n {\r\n \"name\": \"zone1\",\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\"\ + ,\r\n \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\ + \n}" headers: cache-control: - no-cache @@ -1467,9 +1443,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:41 GMT + - Tue, 26 Jan 2021 08:05:32 GMT etag: - - W/"82103427-2aa5-48ea-8289-720f0aecbd0f" + - W/"e3282629-db87-4a11-a0d0-eca32a29979d" expires: - '-1' pragma: @@ -1486,7 +1462,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - afaa10bf-9637-4ebc-9a48-ed59e742d6e3 + - c0523377-788d-4612-adc6-fdc495e1fa7f status: code: 200 message: OK @@ -1500,21 +1476,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"privateDnsZoneConfigs\": - [\r\n {\r\n \"name\": \"zone1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\",\r\n - \ \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateDnsZoneGroup\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \ + \ \"privateDnsZoneConfigs\": [\r\n {\r\n \"name\": \"zone1\",\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup/privateDnsZoneConfigs/zone1\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateDnsZoneGroups/privateDnsZoneConfigs\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateDnsZoneId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateDnsZones/www.zone1.com\"\ + ,\r\n \"recordSets\": []\r\n }\r\n }\r\n ]\r\n }\r\ + \n}" headers: cache-control: - no-cache @@ -1523,9 +1501,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:42 GMT + - Tue, 26 Jan 2021 08:05:33 GMT etag: - - W/"82103427-2aa5-48ea-8289-720f0aecbd0f" + - W/"e3282629-db87-4a11-a0d0-eca32a29979d" expires: - '-1' pragma: @@ -1542,7 +1520,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 65b9298b-e541-4f36-a844-4c6e2ced5512 + - f8afe6bf-0ba3-4c27-ade5-1dd0bd04078a status: code: 200 message: OK @@ -1556,20 +1534,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"etag\": \"W/\\\"055adedd-9f44-46f4-bfef-e69825068ac8\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"privateEndpoint\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\r\n - \ },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"approved it for some reason.\",\r\n - \ \"actionsRequired\": \"\"\r\n },\r\n \"linkIdentifier\": \"536890164\"\r\n - \ },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\r\n}" + string: "{\r\n \"name\": \"myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"etag\": \"W/\\\"3fe5a14f-dc21-4593-932f-7823b981756d\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + \r\n },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\"\ + : \"Approved\",\r\n \"description\": \"approved it for some reason.\"\ + ,\r\n \"actionsRequired\": \"\"\r\n },\r\n \"linkIdentifier\":\ + \ \"536928101\"\r\n },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\ + \r\n}" headers: cache-control: - no-cache @@ -1578,9 +1557,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:43 GMT + - Tue, 26 Jan 2021 08:05:33 GMT etag: - - W/"055adedd-9f44-46f4-bfef-e69825068ac8" + - W/"3fe5a14f-dc21-4593-932f-7823b981756d" expires: - '-1' pragma: @@ -1597,7 +1576,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 75b45cb6-b2a2-47f1-b74b-38b0c5180c86 + - 3fc7ef87-94f1-43d9-9a03-dc8d3d48f816 status: code: 200 message: OK @@ -1611,28 +1590,30 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n \"type\": - \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n \"privateLinkServiceConnections\": - [\r\n {\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\",\r\n - \ \"etag\": \"W/\\\"82103427-2aa5-48ea-8289-720f0aecbd0f\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"approved it for some reason.\",\r\n - \ \"actionsRequired\": \"\"\r\n }\r\n },\r\n \"type\": - \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\r\n }\r\n - \ ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\n \"subnet\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\r\n - \ },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.e64dc9f3-7f52-4e27-a5f9-572c8bd61b5c\"\r\n - \ }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myPrivateEndpoint\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateEndpoints\",\r\n \"location\": \"\ + eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\",\r\n \ + \ \"privateLinkServiceConnections\": [\r\n {\r\n \"name\": \"\ + myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateLinkServiceConnections/myService\"\ + ,\r\n \"etag\": \"W/\\\"e3282629-db87-4a11-a0d0-eca32a29979d\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateLinkServiceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"privateLinkServiceConnectionState\": {\r\n \"\ + status\": \"Approved\",\r\n \"description\": \"approved it for\ + \ some reason.\",\r\n \"actionsRequired\": \"\"\r\n }\r\ + \n },\r\n \"type\": \"Microsoft.Network/privateEndpoints/privateLinkServiceConnections\"\ + \r\n }\r\n ],\r\n \"manualPrivateLinkServiceConnections\": [],\r\ + \n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet2\"\ + \r\n },\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myPrivateEndpoint.nic.91fba56f-9782-466c-ac27-102ed8f3a738\"\ + \r\n }\r\n ],\r\n \"customDnsConfigs\": []\r\n }\r\n}" headers: cache-control: - no-cache @@ -1641,9 +1622,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:43 GMT + - Tue, 26 Jan 2021 08:05:33 GMT etag: - - W/"82103427-2aa5-48ea-8289-720f0aecbd0f" + - W/"e3282629-db87-4a11-a0d0-eca32a29979d" expires: - '-1' pragma: @@ -1660,7 +1641,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7ab877e1-83a6-47be-9495-0ba3dbc96021 + - dc19f5a8-96fe-49be-8448-5702f8670d89 status: code: 200 message: OK @@ -1674,43 +1655,45 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\",\r\n - \ \"etag\": \"W/\\\"055adedd-9f44-46f4-bfef-e69825068ac8\\\"\",\r\n \"type\": - \"Microsoft.Network/privateLinkServices\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"328a3e20-724a-4d20-9686-ae4af9fe67e4\",\r\n \"fqdns\": [\r\n \"fqdn1\",\r\n - \ \"fqdn2\",\r\n \"fqdn3\"\r\n ],\r\n \"alias\": \"myservice.4fa7db5a-643e-4361-a1d7-33446780645c.eastus.azure.privatelinkservice\",\r\n - \ \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n - \ ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\": [\r\n - \ \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n },\r\n - \ \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\r\n - \ }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": - \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\",\r\n - \ \"etag\": \"W/\\\"055adedd-9f44-46f4-bfef-e69825068ac8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"subnet\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\": - [\r\n {\r\n \"name\": \"myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99\",\r\n - \ \"etag\": \"W/\\\"055adedd-9f44-46f4-bfef-e69825068ac8\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\r\n - \ },\r\n \"privateLinkServiceConnectionState\": {\r\n \"status\": - \"Approved\",\r\n \"description\": \"approved it for some reason.\",\r\n - \ \"actionsRequired\": \"\"\r\n },\r\n \"linkIdentifier\": - \"536890164\"\r\n },\r\n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\r\n - \ }\r\n ],\r\n \"networkInterfaces\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.6d95599e-9861-436a-9a81-9549646d3ff7\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myService\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService\"\ + ,\r\n \"etag\": \"W/\\\"3fe5a14f-dc21-4593-932f-7823b981756d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/privateLinkServices\",\r\n \"location\":\ + \ \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"f4ff6ce6-3871-4264-a7e9-0aebd018b326\",\r\n \ + \ \"fqdns\": [\r\n \"fqdn1\",\r\n \"fqdn2\",\r\n \"fqdn3\"\ + \r\n ],\r\n \"alias\": \"myservice.a7112f56-49cc-421c-8806-26ee8085f2cc.eastus.azure.privatelinkservice\"\ + ,\r\n \"visibility\": {\r\n \"subscriptions\": [\r\n \"00000000-0000-0000-0000-000000000000\"\ + \r\n ]\r\n },\r\n \"autoApproval\": {\r\n \"subscriptions\"\ + : [\r\n \"00000000-0000-0000-0000-000000000000\"\r\n ]\r\n \ + \ },\r\n \"enableProxyProtocol\": false,\r\n \"loadBalancerFrontendIpConfigurations\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/loadbalancer/frontendIPConfigurations/myIPConfiguration\"\ + \r\n }\r\n ],\r\n \"ipConfigurations\": [\r\n {\r\n \ + \ \"name\": \"myIPConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/ipConfigurations/myIPConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"3fe5a14f-dc21-4593-932f-7823b981756d\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/privateLinkServices/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet1\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"privateEndpointConnections\"\ + : [\r\n {\r\n \"name\": \"myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3\"\ + ,\r\n \"etag\": \"W/\\\"3fe5a14f-dc21-4593-932f-7823b981756d\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateEndpoint\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint\"\ + \r\n },\r\n \"privateLinkServiceConnectionState\": {\r\n\ + \ \"status\": \"Approved\",\r\n \"description\": \"\ + approved it for some reason.\",\r\n \"actionsRequired\": \"\"\r\ + \n },\r\n \"linkIdentifier\": \"536928101\"\r\n },\r\ + \n \"type\": \"Microsoft.Network/privateLinkServices/privateEndpointConnections\"\ + \r\n }\r\n ],\r\n \"networkInterfaces\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myService.nic.33737f74-f7da-49fe-8f01-bdb9de646e25\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -1719,9 +1702,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:43 GMT + - Tue, 26 Jan 2021 08:05:34 GMT etag: - - W/"055adedd-9f44-46f4-bfef-e69825068ac8" + - W/"3fe5a14f-dc21-4593-932f-7823b981756d" expires: - '-1' pragma: @@ -1738,7 +1721,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3213bf55-d93b-48b2-b550-a3eb317a79b4 + - 92cc781e-e10c-4ab2-b3ac-a6dfbcdeff49 status: code: 200 message: OK @@ -1754,25 +1737,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint/privateDnsZoneGroups/myPrivateDnsZoneGroup?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/bfc96610-9e56-42bd-b109-f339ea305080?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/34c1383c-0e1e-4752-8abf-5148a0b60a27?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:49:44 GMT + - Tue, 26 Jan 2021 08:05:34 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bfc96610-9e56-42bd-b109-f339ea305080?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/34c1383c-0e1e-4752-8abf-5148a0b60a27?api-version=2020-08-01 pragma: - no-cache server: @@ -1783,7 +1766,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a8df5a8d-a51f-47bd-9a39-1da0ef6e2537 + - de32df89-0127-44ad-bf80-6acb3ab4384d x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -1799,9 +1782,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/bfc96610-9e56-42bd-b109-f339ea305080?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/34c1383c-0e1e-4752-8abf-5148a0b60a27?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1813,7 +1796,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:49:55 GMT + - Tue, 26 Jan 2021 08:05:45 GMT expires: - '-1' pragma: @@ -1830,7 +1813,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - aba2cae6-5110-4273-86de-d8c998f29b15 + - fbccd3e6-3243-4016-9bbc-60a0556e1f0c status: code: 200 message: OK @@ -1846,25 +1829,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.b6d9f93b-6394-4141-8065-42e5bad35e99?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService/privateEndpointConnections/myPrivateEndpoint.2a3ac4f2-8614-4a00-8cd1-4b559d8a71e3?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d11ec627-e038-4ba4-aa4d-e9d89d207503?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71899b2d-5650-4396-8b24-1bfaa42a1ded?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:49:55 GMT + - Tue, 26 Jan 2021 08:05:45 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/d11ec627-e038-4ba4-aa4d-e9d89d207503?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/71899b2d-5650-4396-8b24-1bfaa42a1ded?api-version=2020-08-01 pragma: - no-cache server: @@ -1875,7 +1858,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cbedcde1-02ac-4e44-90ac-51e6f04c4f79 + - dcfe6a94-d5ec-4ca6-bb69-02c9fb032ab5 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -1891,9 +1874,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d11ec627-e038-4ba4-aa4d-e9d89d207503?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71899b2d-5650-4396-8b24-1bfaa42a1ded?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1905,7 +1888,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:50:06 GMT + - Tue, 26 Jan 2021 08:05:56 GMT expires: - '-1' pragma: @@ -1922,7 +1905,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3fd8f50b-caae-4710-aa51-547c66f28554 + - 3621d19b-05da-45f3-bbbe-42d1c91e331b status: code: 200 message: OK @@ -1938,9 +1921,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateEndpoints/myPrivateEndpoint?api-version=2020-08-01 response: body: string: '' @@ -1948,17 +1931,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/18fa7d1a-b064-48c8-9d13-e8ecf27bcba2?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/cf43e076-33f7-4537-bf75-bc697322c067?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:50:07 GMT + - Tue, 26 Jan 2021 08:05:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/18fa7d1a-b064-48c8-9d13-e8ecf27bcba2?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/cf43e076-33f7-4537-bf75-bc697322c067?api-version=2020-08-01 pragma: - no-cache server: @@ -1969,7 +1952,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 97f6efab-3237-4046-a9f9-f1afaab058ed + - cadf6023-2ad6-454c-af51-b01388dca447 x-ms-ratelimit-remaining-subscription-deletes: - '14997' status: @@ -1985,9 +1968,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/18fa7d1a-b064-48c8-9d13-e8ecf27bcba2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/cf43e076-33f7-4537-bf75-bc697322c067?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1999,7 +1982,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:50:17 GMT + - Tue, 26 Jan 2021 08:06:09 GMT expires: - '-1' pragma: @@ -2016,7 +1999,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 82e7bb55-920a-4f38-aa37-66f914ff78b4 + - 49601a08-6825-49df-8bf3-0c9df9ec1b49 status: code: 200 message: OK @@ -2032,9 +2015,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/privateLinkServices/myService?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/privateLinkServices/myService?api-version=2020-08-01 response: body: string: '' @@ -2042,17 +2025,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2b889e86-e969-49d9-a6a2-a97dc43d3617?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b4490faf-790f-4590-826e-6a4c5b477107?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:50:19 GMT + - Tue, 26 Jan 2021 08:06:10 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2b889e86-e969-49d9-a6a2-a97dc43d3617?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b4490faf-790f-4590-826e-6a4c5b477107?api-version=2020-08-01 pragma: - no-cache server: @@ -2063,7 +2046,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 935078fc-0623-464e-a4f2-2e9aa8d0c27c + - 8e115083-1317-41e5-b92a-0bd915fa9941 x-ms-ratelimit-remaining-subscription-deletes: - '14996' status: @@ -2079,9 +2062,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2b889e86-e969-49d9-a6a2-a97dc43d3617?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b4490faf-790f-4590-826e-6a4c5b477107?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2093,7 +2076,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:50:29 GMT + - Tue, 26 Jan 2021 08:06:20 GMT expires: - '-1' pragma: @@ -2110,7 +2093,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8e8cae9a-7eae-4453-8543-59afaba7c31d + - 0be72832-fddf-48ac-92e9-a90f6f064b88 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint_policy.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint_policy.test_network.yaml index 398d9fc4b65a..7d8f88b932de 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint_policy.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_endpoint_policy.test_network.yaml @@ -13,22 +13,22 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\",\r\n - \ \"etag\": \"W/\\\"0a123d2b-dc24-4ad3-bbd8-04c592fef6a4\\\"\",\r\n \"type\": - \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"3779077a-9113-4745-8495-630713cfaa54\",\r\n \"serviceEndpointPolicyDefinitions\": - []\r\n }\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\"\ + ,\r\n \"etag\": \"W/\\\"94386ebe-8245-4af5-a137-9a4297fb6c60\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"resourceGuid\": \"7a8a03de-1ba1-43ea-949c-2d868307af2c\",\r\n \ + \ \"serviceEndpointPolicyDefinitions\": []\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b5868f73-3501-4599-ae1d-893c8eda8fd0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d724d54b-f2d9-4e12-afb9-ed54e604b4ab?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -36,7 +36,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:57:39 GMT + - Tue, 26 Jan 2021 08:06:40 GMT expires: - '-1' pragma: @@ -49,7 +49,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9fd01c4d-9bb4-4967-8a51-11702cd91b12 + - 463bc961-d74f-490f-8ad9-71ba8e5c4f0e x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -65,9 +65,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/b5868f73-3501-4599-ae1d-893c8eda8fd0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d724d54b-f2d9-4e12-afb9-ed54e604b4ab?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -79,7 +79,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:57:50 GMT + - Tue, 26 Jan 2021 08:06:51 GMT expires: - '-1' pragma: @@ -96,7 +96,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 358f859a-fef0-4ae6-a42d-4022de475d98 + - 1a65fc17-27f7-4049-87bf-455e72053c27 status: code: 200 message: OK @@ -110,17 +110,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\",\r\n - \ \"etag\": \"W/\\\"d98d705b-c923-4b2f-b668-a945ee33f981\\\"\",\r\n \"type\": - \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"3779077a-9113-4745-8495-630713cfaa54\",\r\n \"serviceEndpointPolicyDefinitions\": - []\r\n }\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\"\ + ,\r\n \"etag\": \"W/\\\"0a43cee8-7ca8-434f-a26a-b644b50879f1\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"7a8a03de-1ba1-43ea-949c-2d868307af2c\",\r\n \ + \ \"serviceEndpointPolicyDefinitions\": []\r\n }\r\n}" headers: cache-control: - no-cache @@ -129,9 +129,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:57:50 GMT + - Tue, 26 Jan 2021 08:06:51 GMT etag: - - W/"d98d705b-c923-4b2f-b668-a945ee33f981" + - W/"0a43cee8-7ca8-434f-a26a-b644b50879f1" expires: - '-1' pragma: @@ -148,7 +148,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cd2df5bf-efeb-4d61-b7cb-546c727a98f6 + - 441e6a1c-c3b2-4ba2-81a3-22fb25a5000a status: code: 200 message: OK @@ -167,21 +167,23 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\",\r\n - \ \"etag\": \"W/\\\"a5fe5731-0b32-44bb-b4df-400c372ca3dc\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"service\": \"Microsoft.Storage\",\r\n - \ \"description\": \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\": - [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\r\n - \ ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\"\ + ,\r\n \"etag\": \"W/\\\"b9b29494-a43c-4a63-ba79-b6f5858f75ec\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + service\": \"Microsoft.Storage\",\r\n \"description\": \"Storage Service\ + \ EndpointPolicy Definition\",\r\n \"serviceResources\": [\r\n \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\ + \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e169aff8-809f-4879-b5ef-bb2a0f49c27d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/72d171b7-4146-4cc5-8ee4-02a886614b6c?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -189,7 +191,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:57:51 GMT + - Tue, 26 Jan 2021 08:06:52 GMT expires: - '-1' pragma: @@ -202,7 +204,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d1a88067-af96-4c12-913c-65c9f48141a3 + - 035da197-bc3f-4d61-9671-1e85587fd27a x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -218,9 +220,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/e169aff8-809f-4879-b5ef-bb2a0f49c27d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/72d171b7-4146-4cc5-8ee4-02a886614b6c?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -232,7 +234,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:01 GMT + - Tue, 26 Jan 2021 08:07:03 GMT expires: - '-1' pragma: @@ -249,7 +251,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ce9cb1e2-ed2f-4515-89d5-067519e0d234 + - 140687ef-b612-4198-ac9e-01b7c41a14bf status: code: 200 message: OK @@ -263,18 +265,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\",\r\n - \ \"etag\": \"W/\\\"84fb4de8-4c1a-404d-830c-c43d98a3265f\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"service\": \"Microsoft.Storage\",\r\n - \ \"description\": \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\": - [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\r\n - \ ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\"\ + ,\r\n \"etag\": \"W/\\\"67d6506c-43b8-4b2d-b139-c2d945b5a330\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + service\": \"Microsoft.Storage\",\r\n \"description\": \"Storage Service\ + \ EndpointPolicy Definition\",\r\n \"serviceResources\": [\r\n \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\ + \r\n}" headers: cache-control: - no-cache @@ -283,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:01 GMT + - Tue, 26 Jan 2021 08:07:03 GMT etag: - - W/"84fb4de8-4c1a-404d-830c-c43d98a3265f" + - W/"67d6506c-43b8-4b2d-b139-c2d945b5a330" expires: - '-1' pragma: @@ -302,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 98631871-2819-48bd-a410-15d5d4153ab4 + - 1c9d5009-d1e4-4a7e-9266-7a35fd006104 status: code: 200 message: OK @@ -316,18 +320,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\",\r\n - \ \"etag\": \"W/\\\"84fb4de8-4c1a-404d-830c-c43d98a3265f\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"service\": \"Microsoft.Storage\",\r\n - \ \"description\": \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\": - [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\r\n - \ ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\"\ + ,\r\n \"etag\": \"W/\\\"67d6506c-43b8-4b2d-b139-c2d945b5a330\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + service\": \"Microsoft.Storage\",\r\n \"description\": \"Storage Service\ + \ EndpointPolicy Definition\",\r\n \"serviceResources\": [\r\n \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\ + \r\n}" headers: cache-control: - no-cache @@ -336,9 +342,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:02 GMT + - Tue, 26 Jan 2021 08:07:04 GMT etag: - - W/"84fb4de8-4c1a-404d-830c-c43d98a3265f" + - W/"67d6506c-43b8-4b2d-b139-c2d945b5a330" expires: - '-1' pragma: @@ -355,7 +361,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b324b488-957e-47bc-9e2f-0f1dd5f4ff7a + - 18974202-3724-4eed-9c2b-3fb260b91f52 status: code: 200 message: OK @@ -369,25 +375,25 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\",\r\n - \ \"etag\": \"W/\\\"84fb4de8-4c1a-404d-830c-c43d98a3265f\\\"\",\r\n \"type\": - \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"3779077a-9113-4745-8495-630713cfaa54\",\r\n \"serviceEndpointPolicyDefinitions\": - [\r\n {\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\",\r\n - \ \"etag\": \"W/\\\"84fb4de8-4c1a-404d-830c-c43d98a3265f\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"service\": \"Microsoft.Storage\",\r\n \"description\": - \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\": - [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\r\n - \ ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\"\ + ,\r\n \"etag\": \"W/\\\"67d6506c-43b8-4b2d-b139-c2d945b5a330\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\"\ + : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"7a8a03de-1ba1-43ea-949c-2d868307af2c\",\r\n \ + \ \"serviceEndpointPolicyDefinitions\": [\r\n {\r\n \"name\"\ + : \"myServiceEndpointPolicyDefinition\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\"\ + ,\r\n \"etag\": \"W/\\\"67d6506c-43b8-4b2d-b139-c2d945b5a330\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"service\": \"Microsoft.Storage\",\r\n \"description\"\ + : \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\"\ + : [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -396,9 +402,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:02 GMT + - Tue, 26 Jan 2021 08:07:04 GMT etag: - - W/"84fb4de8-4c1a-404d-830c-c43d98a3265f" + - W/"67d6506c-43b8-4b2d-b139-c2d945b5a330" expires: - '-1' pragma: @@ -415,7 +421,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - af7cb0f7-76ea-4cbc-9dd6-cb124ee031a6 + - 2c14ad9b-a065-4e6c-a650-418a31653c27 status: code: 200 message: OK @@ -433,26 +439,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\",\r\n - \ \"etag\": \"W/\\\"af867dd4-40ee-4d0c-a08d-5b206d774d96\\\"\",\r\n \"type\": - \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\": \"eastus\",\r\n - \ \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n - \ },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"3779077a-9113-4745-8495-630713cfaa54\",\r\n \"serviceEndpointPolicyDefinitions\": - [\r\n {\r\n \"name\": \"myServiceEndpointPolicyDefinition\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\",\r\n - \ \"etag\": \"W/\\\"af867dd4-40ee-4d0c-a08d-5b206d774d96\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"service\": \"Microsoft.Storage\",\r\n \"description\": - \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\": - [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\r\n - \ ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myServiceEndpointPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy\"\ + ,\r\n \"etag\": \"W/\\\"108d8266-e342-4d2f-a158-aa46dbcbb17b\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/serviceEndpointPolicies\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ + : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ + \ \"Succeeded\",\r\n \"resourceGuid\": \"7a8a03de-1ba1-43ea-949c-2d868307af2c\"\ + ,\r\n \"serviceEndpointPolicyDefinitions\": [\r\n {\r\n \"\ + name\": \"myServiceEndpointPolicyDefinition\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition\"\ + ,\r\n \"etag\": \"W/\\\"108d8266-e342-4d2f-a158-aa46dbcbb17b\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"service\": \"Microsoft.Storage\",\r\n \"description\"\ + : \"Storage Service EndpointPolicy Definition\",\r\n \"serviceResources\"\ + : [\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/serviceEndpointPolicies/serviceEndpointPolicyDefinitions\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -463,7 +469,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:06 GMT + - Tue, 26 Jan 2021 08:07:09 GMT expires: - '-1' pragma: @@ -480,7 +486,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 31e22f36-3922-4c14-812c-4f3432611c55 + - fedcd947-b1d9-45e3-9f14-4245a3760d8d x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -498,25 +504,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy/serviceEndpointPolicyDefinitions/myServiceEndpointPolicyDefinition?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e0499e45-28a4-4a9d-9644-086d501eadc0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/431bc9ac-eba4-480a-9b65-1d488f111bba?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 09:58:06 GMT + - Tue, 26 Jan 2021 08:07:10 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/e0499e45-28a4-4a9d-9644-086d501eadc0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/431bc9ac-eba4-480a-9b65-1d488f111bba?api-version=2020-08-01 pragma: - no-cache server: @@ -527,7 +533,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1dc4cce4-46f4-4827-a08c-425ce295e13d + - 592b4e84-5137-4173-a01f-b474fe4ab28e x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -543,9 +549,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/e0499e45-28a4-4a9d-9644-086d501eadc0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/431bc9ac-eba4-480a-9b65-1d488f111bba?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -557,7 +563,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:17 GMT + - Tue, 26 Jan 2021 08:07:20 GMT expires: - '-1' pragma: @@ -574,7 +580,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 25d9bded-1be9-4aee-94a7-0a489c10f61d + - 03e420d9-97bd-40c7-bbc8-ee92602e04f9 status: code: 200 message: OK @@ -590,9 +596,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/serviceEndpointPolicies/myServiceEndpointPolicy?api-version=2020-08-01 response: body: string: '' @@ -600,17 +606,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2f4e0cb0-d323-4527-beb7-e214b6125cab?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0a041d55-db60-42ab-9350-4e086b13bcf3?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 09:58:18 GMT + - Tue, 26 Jan 2021 08:07:21 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2f4e0cb0-d323-4527-beb7-e214b6125cab?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0a041d55-db60-42ab-9350-4e086b13bcf3?api-version=2020-08-01 pragma: - no-cache server: @@ -621,7 +627,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 432c9301-5ddf-4c4b-a725-f5d13b0c0585 + - 448e78e0-14f6-45d6-9643-43b1b6a9c2f6 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -637,9 +643,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2f4e0cb0-d323-4527-beb7-e214b6125cab?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0a041d55-db60-42ab-9350-4e086b13bcf3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -651,7 +657,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:58:28 GMT + - Tue, 26 Jan 2021 08:07:32 GMT expires: - '-1' pragma: @@ -668,7 +674,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 28d1de77-5d19-4c32-b092-48df5539000a + - 00b5f243-5eca-49fd-b840-de255dd54ddb status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_express_route.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_express_route.test_network.yaml index 693af75aa8a4..07dc01de9bf7 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_express_route.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_express_route.test_network.yaml @@ -16,16 +16,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myCircuit\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit\"\ - ,\r\n \"etag\": \"W/\\\"b89207e4-9aee-42c5-9d67-655f768a53d9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"6f570a5c-d6a3-4de2-b433-ccc4dfae6018\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/expressRouteCircuits\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"f6cc26bc-8d69-4576-b4d2-9c76f23861c9\",\r\n \ + ,\r\n \"resourceGuid\": \"c7418d8f-0646-49ea-9b7a-a8e0d6b311c8\",\r\n \ \ \"peerings\": [],\r\n \"authorizations\": [],\r\n \"serviceProviderProperties\"\ : {\r\n \"serviceProviderName\": \"Equinix\",\r\n \"peeringLocation\"\ : \"Silicon Valley\",\r\n \"bandwidthInMbps\": 200\r\n },\r\n \"\ @@ -39,7 +39,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -47,7 +47,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:23:48 GMT + - Tue, 26 Jan 2021 08:07:50 GMT expires: - '-1' pragma: @@ -60,9 +60,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 010b55ff-9e79-47b1-aff0-ef479349b266 + - 7784e00a-991d-4b9f-ab04-b60138182c33 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1196' status: code: 201 message: Created @@ -76,9 +76,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -90,7 +90,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:23:59 GMT + - Tue, 26 Jan 2021 08:08:00 GMT expires: - '-1' pragma: @@ -107,7 +107,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6675495c-197e-4534-9c88-30abb9093ca6 + - c7b133ac-4ad8-454e-a890-1c6e9deb4bce status: code: 200 message: OK @@ -121,9 +121,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -135,7 +135,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:24:09 GMT + - Tue, 26 Jan 2021 08:08:11 GMT expires: - '-1' pragma: @@ -152,7 +152,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 75cc3e3e-1980-4b23-aacb-afe018c9eb56 + - 36c57e50-3039-4626-8f21-a3889604d43e status: code: 200 message: OK @@ -166,9 +166,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -180,7 +180,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:24:29 GMT + - Tue, 26 Jan 2021 08:08:31 GMT expires: - '-1' pragma: @@ -197,7 +197,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a5abcc4b-693a-490e-9acf-5be239fe4aeb + - 0cf4daa0-8d47-46b8-b861-6878a0a2f36e status: code: 200 message: OK @@ -211,9 +211,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -225,7 +225,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:24:49 GMT + - Tue, 26 Jan 2021 08:08:51 GMT expires: - '-1' pragma: @@ -242,7 +242,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0113fa36-cab6-44b4-a15c-c0de2d28fd32 + - 2150f969-0798-4523-b9be-2aabee63bffb status: code: 200 message: OK @@ -256,9 +256,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17e100c1-c509-40f1-aea8-c95e5729c9af?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e6c0cd31-d244-4ea9-8812-21de35529571?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -270,7 +270,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:25:31 GMT + - Tue, 26 Jan 2021 08:09:31 GMT expires: - '-1' pragma: @@ -287,7 +287,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 17817b03-f98e-4d69-8d35-0765c7e47a50 + - 374a6d02-be6b-401a-a3ff-ef4637f5d974 status: code: 200 message: OK @@ -301,35 +301,35 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myCircuit\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit\"\ - ,\r\n \"etag\": \"W/\\\"0f4b5939-7d1a-44e3-a31a-34d75f5c9909\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"ff67419d-f6ae-4b9f-8ab8-1ca8cca4fcd7\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/expressRouteCircuits\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"f6cc26bc-8d69-4576-b4d2-9c76f23861c9\",\r\n \ + ,\r\n \"resourceGuid\": \"c7418d8f-0646-49ea-9b7a-a8e0d6b311c8\",\r\n \ \ \"peerings\": [],\r\n \"authorizations\": [],\r\n \"serviceProviderProperties\"\ : {\r\n \"serviceProviderName\": \"Equinix\",\r\n \"peeringLocation\"\ : \"Silicon Valley\",\r\n \"bandwidthInMbps\": 200\r\n },\r\n \"\ circuitProvisioningState\": \"Enabled\",\r\n \"allowClassicOperations\"\ - : false,\r\n \"gatewayManagerEtag\": \"\",\r\n \"serviceKey\": \"642494e1-234b-40e4-bf92-7e0d4a563016\"\ + : false,\r\n \"gatewayManagerEtag\": \"\",\r\n \"serviceKey\": \"e64a0608-027e-461c-ac10-167a8732955f\"\ ,\r\n \"serviceProviderProvisioningState\": \"NotProvisioned\",\r\n \ \ \"allowGlobalReach\": false,\r\n \"globalReachEnabled\": false,\r\n \ - \ \"stag\": 72\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ + \ \"stag\": 140\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ ,\r\n \"tier\": \"Standard\",\r\n \"family\": \"MeteredData\"\r\n }\r\ \n}" headers: cache-control: - no-cache content-length: - - '1130' + - '1131' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:25:31 GMT + - Tue, 26 Jan 2021 08:09:32 GMT expires: - '-1' pragma: @@ -346,7 +346,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fbc4b2d2-c87e-4503-ad04-18c9bf2eaf22 + - a2d99b4f-e76c-4cdc-8174-ea56d7226894 status: code: 200 message: OK @@ -367,16 +367,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myCircuit2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2\"\ - ,\r\n \"etag\": \"W/\\\"812c00a8-04c5-4b4e-8d17-bbccce629df8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5815dd0b-58cf-4848-98f3-aa5d3359147f\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/expressRouteCircuits\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"44a41d0e-599b-4654-b98b-8254e4fc0292\",\r\n \ + ,\r\n \"resourceGuid\": \"d8a4ef3a-01e0-4b6e-a6dc-e72f2e0ac159\",\r\n \ \ \"peerings\": [],\r\n \"authorizations\": [],\r\n \"serviceProviderProperties\"\ : {\r\n \"serviceProviderName\": \"Equinix\",\r\n \"peeringLocation\"\ : \"Silicon Valley\",\r\n \"bandwidthInMbps\": 200\r\n },\r\n \"\ @@ -390,7 +390,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -398,7 +398,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:25:38 GMT + - Tue, 26 Jan 2021 08:09:39 GMT expires: - '-1' pragma: @@ -411,9 +411,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9459d781-6154-4060-8bdd-3d7b5890bc6a + - f36d38a0-267a-4c71-be3a-7b2ca3a52c95 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1195' status: code: 201 message: Created @@ -427,9 +427,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -441,7 +441,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:25:48 GMT + - Tue, 26 Jan 2021 08:09:50 GMT expires: - '-1' pragma: @@ -458,7 +458,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b3bc05d9-21e6-4d52-aa2a-f4bef4e3ff58 + - 20d61023-c277-4f19-8cf3-a45585032b1c status: code: 200 message: OK @@ -472,9 +472,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -486,7 +486,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:25:59 GMT + - Tue, 26 Jan 2021 08:10:01 GMT expires: - '-1' pragma: @@ -503,7 +503,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b41263ae-2772-432f-a896-85e817118492 + - 4a8bc7c7-faa6-45d7-966f-68bf330cccc4 status: code: 200 message: OK @@ -517,9 +517,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -531,7 +531,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:26:19 GMT + - Tue, 26 Jan 2021 08:10:21 GMT expires: - '-1' pragma: @@ -548,7 +548,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6739d478-715e-42e3-8edb-467bac0b5dde + - 53604d3e-4130-4d19-ac17-6afd6cf11d7e status: code: 200 message: OK @@ -562,9 +562,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -576,7 +576,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:26:39 GMT + - Tue, 26 Jan 2021 08:10:41 GMT expires: - '-1' pragma: @@ -593,7 +593,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 88e03cad-8fdc-4ee9-a7dc-384bc07875e4 + - 4a25ab5b-8da1-4f0c-9490-b07ee61eab96 status: code: 200 message: OK @@ -607,9 +607,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9a4522c-09f1-4823-b417-fab08bf537c3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad606ae0-855d-4379-850d-43a5d43bce44?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -621,7 +621,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:19 GMT + - Tue, 26 Jan 2021 08:11:22 GMT expires: - '-1' pragma: @@ -638,7 +638,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - be2918f0-2fa8-47fc-aeba-2c8e3184bfa2 + - 181722f6-7aa6-4768-b1c3-d4a6c41e1aad status: code: 200 message: OK @@ -652,35 +652,35 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myCircuit2\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2\"\ - ,\r\n \"etag\": \"W/\\\"bf442b2b-a327-4162-b145-76e52dca5e2d\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"6cf67d27-e2e3-4d05-af1b-b81d2d85ff19\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/expressRouteCircuits\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"44a41d0e-599b-4654-b98b-8254e4fc0292\",\r\n \ + ,\r\n \"resourceGuid\": \"d8a4ef3a-01e0-4b6e-a6dc-e72f2e0ac159\",\r\n \ \ \"peerings\": [],\r\n \"authorizations\": [],\r\n \"serviceProviderProperties\"\ : {\r\n \"serviceProviderName\": \"Equinix\",\r\n \"peeringLocation\"\ : \"Silicon Valley\",\r\n \"bandwidthInMbps\": 200\r\n },\r\n \"\ circuitProvisioningState\": \"Enabled\",\r\n \"allowClassicOperations\"\ - : false,\r\n \"gatewayManagerEtag\": \"\",\r\n \"serviceKey\": \"6e1aa481-a51c-42a2-be23-af3ba440e298\"\ + : false,\r\n \"gatewayManagerEtag\": \"\",\r\n \"serviceKey\": \"418bdf5f-ae2a-4768-aca1-4d2da9ab9e30\"\ ,\r\n \"serviceProviderProvisioningState\": \"NotProvisioned\",\r\n \ \ \"allowGlobalReach\": false,\r\n \"globalReachEnabled\": false,\r\n \ - \ \"stag\": 84\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ + \ \"stag\": 147\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ ,\r\n \"tier\": \"Standard\",\r\n \"family\": \"MeteredData\"\r\n }\r\ \n}" headers: cache-control: - no-cache content-length: - - '1132' + - '1133' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:20 GMT + - Tue, 26 Jan 2021 08:11:22 GMT expires: - '-1' pragma: @@ -697,7 +697,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7f32960c-ee16-4030-9eb1-6c66db4ab2be + - 20cc1825-dcd7-4613-ba79-aae8e7188760 status: code: 200 message: OK @@ -716,13 +716,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AzurePrivatePeering\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"4698510b-d101-43c5-91c7-8d3b66a77ed6\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7de9b461-5597-4317-b71a-5d9eac263841\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ peeringType\": \"AzurePrivatePeering\",\r\n \"azureASN\": 0,\r\n \"\ peerASN\": 10001,\r\n \"primaryPeerAddressPrefix\": \"102.0.0.0/30\",\r\ @@ -732,7 +732,7 @@ interactions: type\": \"Microsoft.Network/expressRouteCircuits/peerings\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/075f44ab-17fb-4e12-b0bb-6ae6a7bb3b44?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c473dde-9e8e-4ec3-a8cc-ee1ba86d62df?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -740,7 +740,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:21 GMT + - Tue, 26 Jan 2021 08:11:23 GMT expires: - '-1' pragma: @@ -753,9 +753,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 220149ed-c274-4860-9536-ef0397cba1c4 + - 99eb30e7-3fc5-4525-8e8a-e19d0d28e3f7 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1194' status: code: 201 message: Created @@ -769,9 +769,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/075f44ab-17fb-4e12-b0bb-6ae6a7bb3b44?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c473dde-9e8e-4ec3-a8cc-ee1ba86d62df?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -783,7 +783,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:31 GMT + - Tue, 26 Jan 2021 08:11:34 GMT expires: - '-1' pragma: @@ -800,7 +800,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - de4cf424-48c2-475a-9d6d-4d6b68771e96 + - 2b16f7ee-b611-4df0-9bce-ae7170f85bb2 status: code: 200 message: OK @@ -814,9 +814,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/075f44ab-17fb-4e12-b0bb-6ae6a7bb3b44?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c473dde-9e8e-4ec3-a8cc-ee1ba86d62df?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -828,7 +828,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:42 GMT + - Tue, 26 Jan 2021 08:11:44 GMT expires: - '-1' pragma: @@ -845,7 +845,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f0dc554a-4207-4ac6-9b26-a53dc6447498 + - 691ae2ff-7da9-41bd-ba0f-95d9da4829b8 status: code: 200 message: OK @@ -859,13 +859,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AzurePrivatePeering\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"69e7f6b9-a9dd-4c61-9392-f1d70d566a50\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1a4419e7-ee22-4c8e-85ad-f7d6391adf7b\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ peeringType\": \"AzurePrivatePeering\",\r\n \"azureASN\": 12076,\r\n \ \ \"peerASN\": 10001,\r\n \"primaryPeerAddressPrefix\": \"102.0.0.0/30\"\ @@ -883,7 +883,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:42 GMT + - Tue, 26 Jan 2021 08:11:45 GMT expires: - '-1' pragma: @@ -900,7 +900,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 239430d6-1f18-4e4f-accc-673e8fb74337 + - 355f27be-115b-4da9-aca8-6d12a4ab6c81 status: code: 200 message: OK @@ -919,13 +919,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AzurePrivatePeering\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"402729ca-6f62-44bc-aa6a-db41f71cb762\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"919eb128-edc2-4661-acc3-0220315e9f1c\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ peeringType\": \"AzurePrivatePeering\",\r\n \"azureASN\": 0,\r\n \"\ peerASN\": 10002,\r\n \"primaryPeerAddressPrefix\": \"104.0.0.0/30\",\r\ @@ -935,7 +935,7 @@ interactions: type\": \"Microsoft.Network/expressRouteCircuits/peerings\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/788d0cd0-445b-4aad-93f2-f5af95a88b09?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2f965bc8-0ebd-411b-bcf8-0c2c79896998?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -943,7 +943,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:43 GMT + - Tue, 26 Jan 2021 08:11:45 GMT expires: - '-1' pragma: @@ -956,9 +956,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 34e2d6a1-5a4c-4451-bb8f-fc1aed1d70f8 + - 3e828ab1-fd4d-46fd-9ae1-de8a4041a74d x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1193' status: code: 201 message: Created @@ -972,9 +972,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/788d0cd0-445b-4aad-93f2-f5af95a88b09?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2f965bc8-0ebd-411b-bcf8-0c2c79896998?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -986,7 +986,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:27:55 GMT + - Tue, 26 Jan 2021 08:11:56 GMT expires: - '-1' pragma: @@ -1003,7 +1003,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6a466413-20d7-426d-a9a4-ec752bd3f016 + - 098f02fb-13e1-442a-9a3c-11aa128d596a status: code: 200 message: OK @@ -1017,9 +1017,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/788d0cd0-445b-4aad-93f2-f5af95a88b09?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2f965bc8-0ebd-411b-bcf8-0c2c79896998?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1031,7 +1031,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:05 GMT + - Tue, 26 Jan 2021 08:12:06 GMT expires: - '-1' pragma: @@ -1048,7 +1048,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4c0b3fb8-6973-4678-bbef-8aed665e3973 + - a289f516-c604-403c-847c-dedb8e303cb6 status: code: 200 message: OK @@ -1062,13 +1062,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AzurePrivatePeering\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"c30426d3-6c17-4d6b-b607-736f3988a8a1\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"8e471014-6665-4a59-bed5-ee7e48a63a23\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ peeringType\": \"AzurePrivatePeering\",\r\n \"azureASN\": 12076,\r\n \ \ \"peerASN\": 10002,\r\n \"primaryPeerAddressPrefix\": \"104.0.0.0/30\"\ @@ -1086,7 +1086,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:06 GMT + - Tue, 26 Jan 2021 08:12:06 GMT expires: - '-1' pragma: @@ -1103,7 +1103,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9712d127-29dc-4ebc-b3bf-deeae70c002c + - c825c65a-61c8-49d8-8696-61b12cf0d9cf status: code: 200 message: OK @@ -1121,20 +1121,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myAuthorization\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization\"\ - ,\r\n \"etag\": \"W/\\\"f2e3a28d-5e95-4ed5-8a4c-4a8c299fff31\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"26063cfb-ab4c-449a-a34a-d23febf0abe8\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ - authorizationKey\": \"cec6e48b-3a91-4885-81c5-29a90d9d9c0d\",\r\n \"authorizationUseStatus\"\ + authorizationKey\": \"5b70f388-25d8-40bc-9485-fb10a8212b0b\",\r\n \"authorizationUseStatus\"\ : \"Available\"\r\n },\r\n \"type\": \"Microsoft.Network/expressRouteCircuits/authorizations\"\ \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0692f966-b432-4ffb-b303-bf72d2d198bd?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e5cea286-5e2d-4a2f-9327-de0ae941499e?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1142,7 +1142,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:07 GMT + - Tue, 26 Jan 2021 08:12:07 GMT expires: - '-1' pragma: @@ -1155,9 +1155,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9392426c-2f02-4fa8-beb1-161a0f009971 + - a5e7e84a-1205-45a5-afe1-4a452edb0295 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1192' status: code: 201 message: Created @@ -1171,9 +1171,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0692f966-b432-4ffb-b303-bf72d2d198bd?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e5cea286-5e2d-4a2f-9327-de0ae941499e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1185,7 +1185,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:17 GMT + - Tue, 26 Jan 2021 08:12:18 GMT expires: - '-1' pragma: @@ -1202,7 +1202,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e0370da4-b0df-42bd-b3cf-a84f57f867cd + - 1b06bae3-cc34-4422-b4de-fa92faeaa6d3 status: code: 200 message: OK @@ -1216,15 +1216,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myAuthorization\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization\"\ - ,\r\n \"etag\": \"W/\\\"f254737e-f0e7-49b0-a31b-1cff7e2ce8f8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d9c3d823-424b-4f51-b73b-e946e8a5b0ff\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - authorizationKey\": \"cec6e48b-3a91-4885-81c5-29a90d9d9c0d\",\r\n \"authorizationUseStatus\"\ + authorizationKey\": \"5b70f388-25d8-40bc-9485-fb10a8212b0b\",\r\n \"authorizationUseStatus\"\ : \"Available\"\r\n },\r\n \"type\": \"Microsoft.Network/expressRouteCircuits/authorizations\"\ \r\n}" headers: @@ -1235,7 +1235,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:18 GMT + - Tue, 26 Jan 2021 08:12:18 GMT expires: - '-1' pragma: @@ -1252,7 +1252,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b4d63b69-adfc-473f-88d3-7bf8475af968 + - a706f774-5d18-4107-9b2b-a37edc39e80c status: code: 200 message: OK @@ -1272,13 +1272,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myConnection\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection\"\ - ,\r\n \"etag\": \"W/\\\"75cd90e8-2be2-4228-8713-7a7c4822fe52\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e18a19eb-23bb-41f1-a0c5-d0143beff834\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ expressRouteCircuitPeering\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ \r\n },\r\n \"peerExpressRouteCircuitPeering\": {\r\n \"id\": \"\ @@ -1288,7 +1288,7 @@ interactions: \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6fa56c6d-b0a3-4a9e-a13f-d5e9e704bc99?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d2212d26-033f-4046-872b-6608e0b1a4d2?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1296,7 +1296,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:18 GMT + - Tue, 26 Jan 2021 08:12:19 GMT expires: - '-1' pragma: @@ -1309,9 +1309,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b788d66f-011b-4f30-8684-70dcaefe68c7 + - 7d535562-2ee0-474e-89cb-c33340b98b3b x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1191' status: code: 201 message: Created @@ -1325,15 +1325,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/6fa56c6d-b0a3-4a9e-a13f-d5e9e704bc99?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d2212d26-033f-4046-872b-6608e0b1a4d2?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Failed\",\r\n \"error\": {\r\n \"code\": \"\ InitiatingCircuitNotProvisioned\",\r\n \"message\": \"Put Global Reach\ \ Connection Initiating Circuit Subscription = 00000000-0000-0000-0000-000000000000,\ - \ ServiceKey = 642494e1-234b-40e4-bf92-7e0d4a563016 is Not Provisioned. Current\ + \ ServiceKey = e64a0608-027e-461c-ac10-167a8732955f is Not Provisioned. Current\ \ Status NotProvisioned\",\r\n \"details\": []\r\n }\r\n}" headers: cache-control: @@ -1343,7 +1343,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:29 GMT + - Tue, 26 Jan 2021 08:12:29 GMT expires: - '-1' pragma: @@ -1360,7 +1360,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 14c1905a-115d-4f76-a59b-8cc8c21450d2 + - 169dee52-1fe7-4037-badb-7fdc942ce487 status: code: 200 message: OK @@ -1374,9 +1374,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering/peerConnections/myConnection?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit2/peerings/AzurePrivatePeering/peerConnections/myConnection?api-version=2020-08-01 response: body: string: "{\r\n \"error\": {\r\n \"code\": \"NotFound\",\r\n \"message\"\ @@ -1390,7 +1390,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:30 GMT + - Tue, 26 Jan 2021 08:12:30 GMT expires: - '-1' pragma: @@ -1403,7 +1403,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c4ebcc74-a35d-48aa-bffe-8ac257dfc061 + - b21b4c0f-531e-41c3-992c-989d3ba57aaf status: code: 404 message: Not Found @@ -1417,13 +1417,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myConnection\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Failed\",\r\n \"expressRouteCircuitPeering\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ \r\n },\r\n \"peerExpressRouteCircuitPeering\": {\r\n \"id\": \"\ @@ -1439,9 +1439,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:30 GMT + - Tue, 26 Jan 2021 08:12:30 GMT etag: - - W/"e577bc7f-dde2-4e2e-9756-11f48c3f9311" + - W/"1f033034-6696-476b-82e9-b5bd658c7c59" expires: - '-1' pragma: @@ -1458,7 +1458,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - dd4c6fef-a531-4f0e-905e-a5d22880e7b7 + - f588190d-b926-49d4-905d-99a7c767b72c status: code: 200 message: OK @@ -1472,15 +1472,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myAuthorization\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Failed\",\r\n \"authorizationKey\"\ - : \"cec6e48b-3a91-4885-81c5-29a90d9d9c0d\",\r\n \"authorizationUseStatus\"\ + : \"5b70f388-25d8-40bc-9485-fb10a8212b0b\",\r\n \"authorizationUseStatus\"\ : \"Available\"\r\n },\r\n \"type\": \"Microsoft.Network/expressRouteCircuits/authorizations\"\ \r\n}" headers: @@ -1491,7 +1491,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:31 GMT + - Tue, 26 Jan 2021 08:12:31 GMT expires: - '-1' pragma: @@ -1508,7 +1508,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 26be09fc-10ab-4635-87d2-68afb31fe47f + - de13c4cd-3709-43ec-b17d-d8c2074c6a25 status: code: 200 message: OK @@ -1522,9 +1522,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/stats?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/stats?api-version=2020-08-01 response: body: string: "{\r\n \"primaryBytesIn\": 0,\r\n \"primaryBytesOut\": 0,\r\n \"\ @@ -1537,7 +1537,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:31 GMT + - Tue, 26 Jan 2021 08:12:31 GMT expires: - '-1' pragma: @@ -1554,7 +1554,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 31f2afa2-9dd5-4c9d-b470-ef90c5d78646 + - 2e5a91d9-9c30-4dd0-b393-4cf88ab9a2c4 status: code: 200 message: OK @@ -1568,13 +1568,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AzurePrivatePeering\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Failed\",\r\n \"peeringType\"\ : \"AzurePrivatePeering\",\r\n \"azureASN\": 12076,\r\n \"peerASN\"\ : 10001,\r\n \"primaryPeerAddressPrefix\": \"102.0.0.0/30\",\r\n \"\ @@ -1583,7 +1583,7 @@ interactions: ,\r\n \"state\": \"Enabled\",\r\n \"vlanId\": 101,\r\n \"gatewayManagerEtag\"\ : \"\",\r\n \"lastModifiedBy\": \"Customer\",\r\n \"connections\": [\r\ \n {\r\n \"name\": \"myConnection\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\"\ ,\r\n \"expressRouteCircuitPeering\": {\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ @@ -1602,7 +1602,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:33 GMT + - Tue, 26 Jan 2021 08:12:32 GMT expires: - '-1' pragma: @@ -1619,7 +1619,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d3c76fb7-b536-4d42-b18a-887d5e1b54b3 + - ca2341a9-67bb-4e90-a0ed-4c1373d99785 status: code: 200 message: OK @@ -1633,9 +1633,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/stats?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/stats?api-version=2020-08-01 response: body: string: "{\r\n \"primaryBytesIn\": 0,\r\n \"primaryBytesOut\": 0,\r\n \"\ @@ -1648,7 +1648,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:33 GMT + - Tue, 26 Jan 2021 08:12:32 GMT expires: - '-1' pragma: @@ -1665,7 +1665,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 586ff201-e724-475e-b92b-a790500b2da0 + - 4800cdf8-3076-4a79-8c64-94a7fd358f1c status: code: 200 message: OK @@ -1679,19 +1679,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"myCircuit\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/expressRouteCircuits\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\"\ - ,\r\n \"resourceGuid\": \"f6cc26bc-8d69-4576-b4d2-9c76f23861c9\",\r\n \ + ,\r\n \"resourceGuid\": \"c7418d8f-0646-49ea-9b7a-a8e0d6b311c8\",\r\n \ \ \"peerings\": [\r\n {\r\n \"name\": \"AzurePrivatePeering\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\"\ ,\r\n \"peeringType\": \"AzurePrivatePeering\",\r\n \"azureASN\"\ : 12076,\r\n \"peerASN\": 10001,\r\n \"primaryPeerAddressPrefix\"\ @@ -1701,7 +1701,7 @@ interactions: \n \"gatewayManagerEtag\": \"\",\r\n \"lastModifiedBy\"\ : \"Customer\",\r\n \"connections\": [\r\n {\r\n \ \ \"name\": \"myConnection\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\ \"\",\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Failed\",\r\n \"expressRouteCircuitPeering\": {\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering\"\ @@ -1714,30 +1714,30 @@ interactions: \n },\r\n \"type\": \"Microsoft.Network/expressRouteCircuits/peerings\"\ \r\n }\r\n ],\r\n \"authorizations\": [\r\n {\r\n \"\ name\": \"myAuthorization\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization\"\ - ,\r\n \"etag\": \"W/\\\"e577bc7f-dde2-4e2e-9756-11f48c3f9311\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1f033034-6696-476b-82e9-b5bd658c7c59\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\"\ - ,\r\n \"authorizationKey\": \"cec6e48b-3a91-4885-81c5-29a90d9d9c0d\"\ + ,\r\n \"authorizationKey\": \"5b70f388-25d8-40bc-9485-fb10a8212b0b\"\ ,\r\n \"authorizationUseStatus\": \"Available\"\r\n },\r\n\ \ \"type\": \"Microsoft.Network/expressRouteCircuits/authorizations\"\ \r\n }\r\n ],\r\n \"serviceProviderProperties\": {\r\n \"\ serviceProviderName\": \"Equinix\",\r\n \"peeringLocation\": \"Silicon\ \ Valley\",\r\n \"bandwidthInMbps\": 200\r\n },\r\n \"circuitProvisioningState\"\ : \"Enabled\",\r\n \"allowClassicOperations\": false,\r\n \"gatewayManagerEtag\"\ - : \"\",\r\n \"serviceKey\": \"642494e1-234b-40e4-bf92-7e0d4a563016\",\r\ + : \"\",\r\n \"serviceKey\": \"e64a0608-027e-461c-ac10-167a8732955f\",\r\ \n \"serviceProviderProvisioningState\": \"NotProvisioned\",\r\n \"\ allowGlobalReach\": false,\r\n \"globalReachEnabled\": false,\r\n \"\ - stag\": 72\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ + stag\": 140\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard_MeteredData\"\ ,\r\n \"tier\": \"Standard\",\r\n \"family\": \"MeteredData\"\r\n }\r\ \n}" headers: cache-control: - no-cache content-length: - - '4164' + - '4165' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:34 GMT + - Tue, 26 Jan 2021 08:12:33 GMT expires: - '-1' pragma: @@ -1754,7 +1754,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ca70e049-569d-4178-aea6-0b4805e1fde1 + - 5d7ce8ab-4792-4987-9dc5-c6983500ecf6 status: code: 200 message: OK @@ -1770,25 +1770,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering/connections/myConnection?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2805efd2-5276-4019-b3e2-58fc0b0f63f0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/45910de1-020d-4706-9df0-88c63af65592?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 06:28:34 GMT + - Tue, 26 Jan 2021 08:12:33 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2805efd2-5276-4019-b3e2-58fc0b0f63f0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/45910de1-020d-4706-9df0-88c63af65592?api-version=2020-08-01 pragma: - no-cache server: @@ -1799,9 +1799,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - caffd5c2-9d43-4f68-9d2d-619d22e7e59f + - 8900c88c-6e63-4397-bcbd-ddb8245a6139 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14996' status: code: 202 message: Accepted @@ -1815,9 +1815,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2805efd2-5276-4019-b3e2-58fc0b0f63f0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/45910de1-020d-4706-9df0-88c63af65592?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1829,7 +1829,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:45 GMT + - Tue, 26 Jan 2021 08:12:44 GMT expires: - '-1' pragma: @@ -1846,7 +1846,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 806b0a85-39df-43de-9385-c70da2b7de92 + - 18e3c45d-068e-4efb-9ebe-56561841d812 status: code: 200 message: OK @@ -1862,25 +1862,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/authorizations/myAuthorization?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/800a75b8-16b1-4fad-8b76-e1a3ecb32906?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c030b6da-5677-4360-b662-c1bf5e41dd5e?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 06:28:45 GMT + - Tue, 26 Jan 2021 08:12:44 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/800a75b8-16b1-4fad-8b76-e1a3ecb32906?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/c030b6da-5677-4360-b662-c1bf5e41dd5e?api-version=2020-08-01 pragma: - no-cache server: @@ -1891,9 +1891,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6355bd7d-8dc2-4244-9691-29da90afe676 + - fa293bff-ad39-4040-b5dd-08eb331a5352 x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14995' status: code: 202 message: Accepted @@ -1907,9 +1907,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/800a75b8-16b1-4fad-8b76-e1a3ecb32906?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c030b6da-5677-4360-b662-c1bf5e41dd5e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1921,7 +1921,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:28:55 GMT + - Tue, 26 Jan 2021 08:12:54 GMT expires: - '-1' pragma: @@ -1938,7 +1938,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8e6512e9-cfe5-4eaa-965d-3929366459f9 + - deaa8c1f-0116-43b2-8cab-0148873a1bad status: code: 200 message: OK @@ -1954,25 +1954,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit/peerings/AzurePrivatePeering?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f9eb1879-2004-4945-b0ce-3440070e013d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ce3a6840-d654-4301-bd7f-a8d1f4f15781?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 06:28:56 GMT + - Tue, 26 Jan 2021 08:12:55 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f9eb1879-2004-4945-b0ce-3440070e013d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/ce3a6840-d654-4301-bd7f-a8d1f4f15781?api-version=2020-08-01 pragma: - no-cache server: @@ -1983,9 +1983,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 411ed7e3-d5df-48c6-a527-a7a4702f324b + - b85164bc-7481-4838-a62d-deadc7f926e0 x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14994' status: code: 202 message: Accepted @@ -1999,9 +1999,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9eb1879-2004-4945-b0ce-3440070e013d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ce3a6840-d654-4301-bd7f-a8d1f4f15781?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2013,7 +2013,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:29:07 GMT + - Tue, 26 Jan 2021 08:13:06 GMT expires: - '-1' pragma: @@ -2030,7 +2030,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 10bea370-b56e-48d6-80a4-c18dc1e9fcfd + - eed66cc3-82e7-4dea-bee6-944adcbfcd70 status: code: 200 message: OK @@ -2044,9 +2044,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f9eb1879-2004-4945-b0ce-3440070e013d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ce3a6840-d654-4301-bd7f-a8d1f4f15781?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2058,7 +2058,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:29:17 GMT + - Tue, 26 Jan 2021 08:13:17 GMT expires: - '-1' pragma: @@ -2075,7 +2075,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8e2ef3c4-4160-4697-a01a-5e3efb81223f + - e66c64e2-f111-4496-87fe-204db2c1098d status: code: 200 message: OK @@ -2091,9 +2091,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/expressRouteCircuits/myCircuit?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/expressRouteCircuits/myCircuit?api-version=2020-08-01 response: body: string: '' @@ -2101,17 +2101,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0803c404-e982-4b2d-989e-f43e84475aac?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/31bd7098-9c75-4b4f-9a9b-77a2d690f380?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 06:29:18 GMT + - Tue, 26 Jan 2021 08:13:17 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0803c404-e982-4b2d-989e-f43e84475aac?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/31bd7098-9c75-4b4f-9a9b-77a2d690f380?api-version=2020-08-01 pragma: - no-cache server: @@ -2122,9 +2122,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c5c08026-4a6e-4bdf-99d9-8d9afc265e47 + - e0e96c9c-0a4f-4229-af72-d420ea241d67 x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14993' status: code: 202 message: Accepted @@ -2138,9 +2138,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0803c404-e982-4b2d-989e-f43e84475aac?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/31bd7098-9c75-4b4f-9a9b-77a2d690f380?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2152,7 +2152,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:29:29 GMT + - Tue, 26 Jan 2021 08:13:28 GMT expires: - '-1' pragma: @@ -2169,7 +2169,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bdf5e814-7e5d-415b-910b-769915287368 + - d230d00b-5c08-4b3e-8d90-cfcaac8a8199 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall.test_network.yaml index af1706716af9..6e4601b6b1e2 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall.test_network.yaml @@ -14,23 +14,23 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualwan\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\",\r\n - \ \"etag\": \"W/\\\"57f1d46b-b7e3-4eac-8548-7207ce8e38ee\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Updating\",\r\n \"disableVpnEncryption\": false,\r\n \"allowBranchToBranchTraffic\": - true,\r\n \"office365LocalBreakoutCategory\": \"None\",\r\n \"type\": - \"Basic\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualwan\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\ + ,\r\n \"etag\": \"W/\\\"a884057a-c9b2-468f-a2d2-4db75c767035\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Updating\",\r\n \"disableVpnEncryption\"\ + : false,\r\n \"allowBranchToBranchTraffic\": true,\r\n \"office365LocalBreakoutCategory\"\ + : \"None\",\r\n \"type\": \"Basic\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8f4b017e-ed46-4cab-bb42-773b73759163?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/fee7c713-fda6-4c33-8763-e8693959e4d7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -38,7 +38,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:06 GMT + - Tue, 26 Jan 2021 08:13:47 GMT expires: - '-1' pragma: @@ -51,7 +51,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 88d3a286-b780-41b7-9a60-8de4fa2557ab + - fc3a6185-c22d-47d6-9e5e-13cc503a10a9 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -67,9 +67,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/8f4b017e-ed46-4cab-bb42-773b73759163?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/fee7c713-fda6-4c33-8763-e8693959e4d7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -81,7 +81,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:16 GMT + - Tue, 26 Jan 2021 08:13:57 GMT expires: - '-1' pragma: @@ -98,7 +98,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7ffc67ce-f028-42e6-be6c-32c51ce371f8 + - 144d3863-92e9-4383-aa33-f76f009bd0ab status: code: 200 message: OK @@ -112,18 +112,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualwan\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\",\r\n - \ \"etag\": \"W/\\\"5b4c7f8d-472b-4257-99a7-fc1f1e4bfd58\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"disableVpnEncryption\": false,\r\n \"allowBranchToBranchTraffic\": - true,\r\n \"office365LocalBreakoutCategory\": \"None\",\r\n \"type\": - \"Basic\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualwan\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\ + ,\r\n \"etag\": \"W/\\\"633dc34e-d389-46bb-88e4-021595db1d5d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"disableVpnEncryption\"\ + : false,\r\n \"allowBranchToBranchTraffic\": true,\r\n \"office365LocalBreakoutCategory\"\ + : \"None\",\r\n \"type\": \"Basic\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -132,9 +132,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:17 GMT + - Tue, 26 Jan 2021 08:13:57 GMT etag: - - W/"5b4c7f8d-472b-4257-99a7-fc1f1e4bfd58" + - W/"633dc34e-d389-46bb-88e4-021595db1d5d" expires: - '-1' pragma: @@ -151,7 +151,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ae84e0d6-389e-4af9-ab77-4c43d1cf8da1 + - 5f22fdaa-d1f7-4f88-8870-792f95fc3fa0 status: code: 200 message: OK @@ -171,33 +171,34 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualhub\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\",\r\n - \ \"etag\": \"W/\\\"b25d3c4c-ac2e-4d3f-a0cf-2485355783fb\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Updating\",\r\n \"virtualHubRouteTableV2s\": [],\r\n \"addressPrefix\": - \"10.168.0.0/24\",\r\n \"virtualRouterAsn\": 0,\r\n \"virtualRouterIps\": - [],\r\n \"routeTable\": {\r\n \"routes\": []\r\n },\r\n \"virtualWan\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\r\n - \ },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualhub\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + ,\r\n \"etag\": \"W/\\\"e14f9595-83a4-4b7e-ab5e-f4bc9daa3745\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Updating\",\r\n \"virtualHubRouteTableV2s\"\ + : [],\r\n \"addressPrefix\": \"10.168.0.0/24\",\r\n \"virtualRouterAsn\"\ + : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ + routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\ + \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\",\r\ + \n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 cache-control: - no-cache content-length: - - '884' + - '926' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:21 GMT + - Tue, 26 Jan 2021 08:14:02 GMT expires: - '-1' pragma: @@ -210,7 +211,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 97351443-4050-4504-b276-f242dbf63170 + - 66e41154-5a26-4f5c-a3c0-28c11029e179 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -226,9 +227,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -240,7 +241,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:31 GMT + - Tue, 26 Jan 2021 08:14:13 GMT expires: - '-1' pragma: @@ -257,7 +258,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c8843bbe-c5e5-4906-9664-a4f888a9ac0b + - 1066e41f-892f-4d64-8149-784f37aa9793 status: code: 200 message: OK @@ -271,9 +272,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -285,7 +286,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 09:59:41 GMT + - Tue, 26 Jan 2021 08:14:23 GMT expires: - '-1' pragma: @@ -302,7 +303,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 00dab28a-16a2-445e-adfb-983a6f1f8c34 + - 2eac17ac-47a0-4a66-88a9-5791ea940b73 status: code: 200 message: OK @@ -316,9 +317,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -330,7 +331,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:00:02 GMT + - Tue, 26 Jan 2021 08:14:43 GMT expires: - '-1' pragma: @@ -347,7 +348,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2fb016fd-2cbc-4cec-8d1c-20845833f7da + - 698abfb0-c504-44fb-b15a-c8d37a7726ad status: code: 200 message: OK @@ -361,9 +362,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -375,7 +376,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:00:22 GMT + - Tue, 26 Jan 2021 08:15:04 GMT expires: - '-1' pragma: @@ -392,7 +393,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1728304b-abb5-404a-b92f-13088c69a099 + - 7d974df4-463d-4e37-b35d-3c2b0d460980 status: code: 200 message: OK @@ -406,9 +407,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -420,7 +421,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:01:03 GMT + - Tue, 26 Jan 2021 08:15:45 GMT expires: - '-1' pragma: @@ -437,7 +438,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ac18d5ea-fcec-4053-a1b9-1459db1e0ee8 + - 61c5c60c-4a5d-41cd-a8d9-2adf1284286e status: code: 200 message: OK @@ -451,9 +452,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -465,7 +466,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:01:43 GMT + - Tue, 26 Jan 2021 08:16:25 GMT expires: - '-1' pragma: @@ -482,7 +483,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 56fac9d9-77d2-48ab-a848-9b0e641ef6eb + - 8c7b0b7c-e1af-4b71-bf8b-cfe534c09d32 status: code: 200 message: OK @@ -496,21 +497,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/978e12e9-3a2c-4f50-ab62-3fbbc8da50ea?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" + string: "{\r\n \"status\": \"InProgress\"\r\n}" headers: cache-control: - no-cache content-length: - - '29' + - '30' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:03 GMT + - Tue, 26 Jan 2021 08:17:45 GMT expires: - '-1' pragma: @@ -527,7 +528,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c107be21-6560-4416-afa1-bd2b09614309 + - 29c976a9-6359-4e6c-a52c-41b5e4bab21d status: code: 200 message: OK @@ -541,30 +542,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0b765c25-75dd-4812-8fca-c28273aeef3a?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualhub\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\",\r\n - \ \"etag\": \"W/\\\"f918a045-9b38-473b-a243-fc83dfc8451c\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"virtualHubRouteTableV2s\": [],\r\n \"addressPrefix\": - \"10.168.0.0/24\",\r\n \"virtualRouterAsn\": 0,\r\n \"virtualRouterIps\": - [],\r\n \"routeTable\": {\r\n \"routes\": []\r\n },\r\n \"virtualWan\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\r\n - \ },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioning\"\r\n - \ }\r\n}" + string: "{\r\n \"status\": \"Succeeded\"\r\n}" headers: cache-control: - no-cache content-length: - - '893' + - '29' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:04 GMT + - Tue, 26 Jan 2021 08:19:26 GMT expires: - '-1' pragma: @@ -581,63 +573,10 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ad0a9d38-bab1-4fdd-aebe-98e6ed2379c2 + - 060224a5-2ae6-4304-9722-5d6e9566e7ca status: code: 200 message: OK -- request: - body: '{"location": "eastus", "tags": {"key1": "value1"}, "properties": {"threatIntelMode": - "Alert"}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '94' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy?api-version=2020-07-01 - response: - body: - string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\r\n - \ },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\": [],\r\n - \ \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \"provisioningState\": - \"Updating\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\",\r\n - \ \"name\": \"firewallpolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\",\r\n - \ \"etag\": \"e7e37a71-5f6c-47fb-86ae-a3b0d3ae75b2\",\r\n \"location\": \"eastus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" - headers: - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/nfvOperations/1ac81771-bc8f-4d81-8361-7ea0a025d655?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '613' - content-type: - - application/json; charset=utf-8 - date: - - Wed, 25 Nov 2020 10:03:12 GMT - expires: - - '-1' - 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: - - '1197' - status: - code: 201 - message: Created - request: body: null headers: @@ -648,74 +587,36 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/nfvOperations/1ac81771-bc8f-4d81-8361-7ea0a025d655?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" + string: "{\r\n \"name\": \"virtualhub\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + ,\r\n \"etag\": \"W/\\\"d44db41b-74f4-459b-ac09-52370ec2d8b9\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"virtualHubRouteTableV2s\"\ + : [],\r\n \"addressPrefix\": \"10.168.0.0/24\",\r\n \"virtualRouterAsn\"\ + : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ + routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualWans/virtualwan\"\ + \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioning\"\ + ,\r\n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '29' + - '935' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:24 GMT + - Tue, 26 Jan 2021 08:19:26 GMT expires: - '-1' pragma: - no-cache server: - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - 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-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy?api-version=2020-07-01 - response: - body: - string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\r\n - \ },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\": [],\r\n - \ \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \"provisioningState\": - \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\",\r\n - \ \"name\": \"firewallpolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\",\r\n - \ \"etag\": \"e7e37a71-5f6c-47fb-86ae-a3b0d3ae75b2\",\r\n \"location\": \"eastus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '614' - content-type: - - application/json; charset=utf-8 - date: - - Wed, 25 Nov 2020 10:03:24 GMT - expires: - - '-1' - pragma: - - no-cache - server: - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains @@ -725,15 +626,14 @@ interactions: - Accept-Encoding x-content-type-options: - nosniff + x-ms-arm-service-request-id: + - 0a8385b7-a937-406c-b7e9-aa2c4f2adb38 status: code: 200 message: OK - request: - body: '{"location": "West US", "tags": {"key1": "value1"}, "zones": [], "properties": - {"virtualHub": {"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub"}, - "firewallPolicy": {"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy"}, - "hubIPAddresses": {"publicIPs": {"addresses": [], "count": 1}}, "sku": {"name": - "AZFW_Hub", "tier": "Standard"}}}' + body: '{"location": "eastus", "tags": {"key1": "value1"}, "properties": {"threatIntelMode": + "Alert"}}' headers: Accept: - application/json @@ -742,54 +642,45 @@ interactions: Connection: - keep-alive Content-Length: - - '596' + - '94' Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"1dd8a7a5-0f3f-4c44-b3dd-687302ff22f2\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Updating\",\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": - \"Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"publicIPs\": {\r\n \"addresses\": - [],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\ + \r\n },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\"\ + : [],\r\n \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \ + \ \"provisioningState\": \"Updating\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + ,\r\n \"name\": \"firewallpolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\"\ + ,\r\n \"etag\": \"252a9858-9611-461f-b77e-2a0734941927\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: - azure-asyncnotification: - - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/nfvOperations/a6028ce0-d93c-40b4-b452-c52109666d13?api-version=2020-08-01 cache-control: - no-cache content-length: - - '1110' + - '613' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:30 GMT + - Tue, 26 Jan 2021 08:19:34 GMT expires: - '-1' pragma: - no-cache server: - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains x-content-type-options: - nosniff - x-ms-arm-service-request-id: - - 243b08fb-4e28-4484-96ca-bc9cfab6a75a x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: code: 201 message: Created @@ -803,28 +694,27 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/nfvOperations/a6028ce0-d93c-40b4-b452-c52109666d13?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: "{\r\n \"status\": \"Succeeded\"\r\n}" headers: cache-control: - no-cache content-length: - - '30' + - '29' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:40 GMT + - Tue, 26 Jan 2021 08:19:45 GMT expires: - '-1' pragma: - no-cache server: - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains transfer-encoding: @@ -833,8 +723,6 @@ interactions: - Accept-Encoding x-content-type-options: - nosniff - x-ms-arm-service-request-id: - - 1598d666-c65c-4584-b6c3-8b3ab488abe4 status: code: 200 message: OK @@ -848,28 +736,33 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\ + \r\n },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\"\ + : [],\r\n \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \ + \ \"provisioningState\": \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + ,\r\n \"name\": \"firewallpolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\"\ + ,\r\n \"etag\": \"252a9858-9611-461f-b77e-2a0734941927\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '30' + - '614' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:03:51 GMT + - Tue, 26 Jan 2021 08:19:45 GMT expires: - '-1' pragma: - no-cache server: - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains transfer-encoding: @@ -878,36 +771,57 @@ interactions: - Accept-Encoding x-content-type-options: - nosniff - x-ms-arm-service-request-id: - - f0a86cba-7f53-4245-9c36-d879305bc255 status: code: 200 message: OK - request: - body: null + body: '{"location": "West US", "tags": {"key1": "value1"}, "zones": [], "properties": + {"virtualHub": {"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub"}, + "firewallPolicy": {"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy"}, + "hubIPAddresses": {"publicIPs": {"addresses": [], "count": 1}}, "sku": {"name": + "AZFW_Hub", "tier": "Standard"}}}' headers: Accept: - - '*/*' + - application/json Accept-Encoding: - gzip, deflate Connection: - keep-alive + Content-Length: + - '596' + Content-Type: + - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"4aea45bd-ecd4-4494-87fe-e3d1f96d1cac\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Updating\",\r\n \"sku\": {\r\n \ + \ \"name\": \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \ + \ \"additionalProperties\": {},\r\n \"virtualHub\": {\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"publicIPs\": {\r\n \ + \ \"addresses\": [],\r\n \"count\": 1\r\n }\r\n },\r\n \ + \ \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: + azure-asyncnotification: + - Enabled + azure-asyncoperation: + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 cache-control: - no-cache content-length: - - '30' + - '1110' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:04:11 GMT + - Tue, 26 Jan 2021 08:19:53 GMT expires: - '-1' pragma: @@ -917,17 +831,15 @@ interactions: - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ea17e502-c6c2-44e7-85b7-c160fdef9dcc + - e5f863bb-3533-49d9-b4bd-8f0115299447 + x-ms-ratelimit-remaining-subscription-writes: + - '1196' status: - code: 200 - message: OK + code: 201 + message: Created - request: body: null headers: @@ -938,9 +850,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -952,7 +864,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:04:31 GMT + - Tue, 26 Jan 2021 08:20:03 GMT expires: - '-1' pragma: @@ -969,7 +881,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b59c8d33-d4ab-4fa4-a609-0bf9a1f828eb + - 45f14be9-1377-4a06-8f7b-b82d21498320 status: code: 200 message: OK @@ -983,9 +895,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -997,7 +909,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:05:11 GMT + - Tue, 26 Jan 2021 08:20:13 GMT expires: - '-1' pragma: @@ -1014,7 +926,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e7d8fa93-b85e-4a0a-b111-769d8df9e598 + - 43ac7e6e-379d-4128-a22f-14608272f6cc status: code: 200 message: OK @@ -1028,9 +940,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1042,7 +954,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:05:51 GMT + - Tue, 26 Jan 2021 08:20:35 GMT expires: - '-1' pragma: @@ -1059,7 +971,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 656b6555-4f21-4ea2-b2a2-07358ac4907c + - f7d7e5d1-d448-4501-b9d7-927827b66f41 status: code: 200 message: OK @@ -1073,9 +985,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1087,7 +999,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:07:12 GMT + - Tue, 26 Jan 2021 08:20:55 GMT expires: - '-1' pragma: @@ -1104,7 +1016,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a21530e3-52db-40c3-8775-d41d49d35824 + - 6d6e1c4c-f732-4795-b382-c2cc6714a63f status: code: 200 message: OK @@ -1118,9 +1030,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1132,7 +1044,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:09:53 GMT + - Tue, 26 Jan 2021 08:21:35 GMT expires: - '-1' pragma: @@ -1149,7 +1061,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5364d413-437e-480e-a07c-9770866db049 + - 548fa512-7b7b-477a-bc6d-8ef57bc1956d status: code: 200 message: OK @@ -1163,9 +1075,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1177,7 +1089,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:11:34 GMT + - Tue, 26 Jan 2021 08:22:16 GMT expires: - '-1' pragma: @@ -1194,7 +1106,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9bf013ed-9517-4194-b321-fff853765888 + - 7196f187-fef9-4954-bcec-bcc42e3891ed status: code: 200 message: OK @@ -1208,9 +1120,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1222,7 +1134,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:13:15 GMT + - Tue, 26 Jan 2021 08:23:36 GMT expires: - '-1' pragma: @@ -1239,7 +1151,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 60ab9b40-8eb9-49ca-a0ba-8e28ac87e88e + - bdf9c1d5-6cd1-482e-8116-88cc7cd76d20 status: code: 200 message: OK @@ -1253,9 +1165,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1267,7 +1179,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:14:56 GMT + - Tue, 26 Jan 2021 08:26:17 GMT expires: - '-1' pragma: @@ -1284,7 +1196,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2cfa9b18-a857-4520-be16-7ec051674520 + - 57a279da-4790-4ad9-810a-cd454d0684eb status: code: 200 message: OK @@ -1298,41 +1210,39 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" + string: '{"error":{"code":"ServerTimeout","message":"The request timed out. + Diagnostic information: timestamp ''20210126T083025Z'', subscription id ''00000000-0000-0000-0000-000000000000'', + tracking id ''05b27441-2fd2-47c1-b1dd-ff4d84c073d9'', request correlation + id ''05b27441-2fd2-47c1-b1dd-ff4d84c073d9''."}}' headers: cache-control: - no-cache + connection: + - close content-length: - - '30' + - '294' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:16:37 GMT + - Tue, 26 Jan 2021 08:30:26 GMT expires: - '-1' pragma: - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff - x-ms-arm-service-request-id: - - 0004b5fc-1432-412e-a222-3cb0ebf43791 + x-ms-failure-cause: + - gateway status: - code: 200 - message: OK + code: 503 + message: Service Unavailable - request: body: null headers: @@ -1343,9 +1253,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1357,7 +1267,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:18:18 GMT + - Tue, 26 Jan 2021 08:30:27 GMT expires: - '-1' pragma: @@ -1374,7 +1284,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bf51c335-3059-43fb-9449-732883237bb1 + - cc7f070a-7c2a-4202-9f7a-a300d73dad0a status: code: 200 message: OK @@ -1388,9 +1298,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1402,7 +1312,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:19:58 GMT + - Tue, 26 Jan 2021 08:32:08 GMT expires: - '-1' pragma: @@ -1419,7 +1329,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b0986e57-32e8-444a-aff8-0b9a8e4067d9 + - 2e1726d5-e694-49f5-bbcf-3d6142690d76 status: code: 200 message: OK @@ -1433,9 +1343,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/5f5a66fe-506f-495a-9cd9-5303266f7936?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3fc6ed9d-031e-40f6-a5d7-8dd27c1dafef?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1447,7 +1357,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:21:40 GMT + - Tue, 26 Jan 2021 08:33:48 GMT expires: - '-1' pragma: @@ -1464,7 +1374,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2b5614ad-2243-4afb-9a09-171fc4d50a0f + - a795c229-83cc-42b0-9f1b-09f864cf41b9 status: code: 200 message: OK @@ -1478,34 +1388,36 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"948a7c63-40e5-4893-ac48-66f448840391\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": - \"Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"52b912e1-135c-4c42-a485-9beaad90f622\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"sku\": {\r\n \ + \ \"name\": \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n\ + \ \"additionalProperties\": {},\r\n \"virtualHub\": {\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"\ + 10.168.0.132\",\r\n \"publicIPs\": {\r\n \"addresses\": [\r\n\ + \ {\r\n \"address\": \"104.40.16.196\"\r\n }\r\ + \n ],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '1228' + - '1230' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:21:40 GMT + - Tue, 26 Jan 2021 08:33:49 GMT etag: - - W/"948a7c63-40e5-4893-ac48-66f448840391" + - W/"52b912e1-135c-4c42-a485-9beaad90f622" expires: - '-1' pragma: @@ -1522,7 +1434,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 591e690a-c5da-4420-be05-e46a060474d4 + - 63f88ace-045e-48cd-9184-ef0fc6537182 status: code: 200 message: OK @@ -1536,34 +1448,36 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"948a7c63-40e5-4893-ac48-66f448840391\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": - \"Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"52b912e1-135c-4c42-a485-9beaad90f622\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"sku\": {\r\n \ + \ \"name\": \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n\ + \ \"additionalProperties\": {},\r\n \"virtualHub\": {\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"\ + 10.168.0.132\",\r\n \"publicIPs\": {\r\n \"addresses\": [\r\n\ + \ {\r\n \"address\": \"104.40.16.196\"\r\n }\r\ + \n ],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '1228' + - '1230' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:21:40 GMT + - Tue, 26 Jan 2021 08:33:49 GMT etag: - - W/"948a7c63-40e5-4893-ac48-66f448840391" + - W/"52b912e1-135c-4c42-a485-9beaad90f622" expires: - '-1' pragma: @@ -1580,7 +1494,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b7fb1a6c-860d-4c85-abd8-c671e6812a89 + - 3f07084d-3728-4b2c-a36d-e59c16166e0a status: code: 200 message: OK @@ -1598,34 +1512,36 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"ce25b2b8-de59-4a7e-89bc-2116b88f19cc\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"sku\": {\r\n \"name\": - \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \"additionalProperties\": - {},\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"cfa729d0-6b67-495b-b3aa-89023b8f784f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": \"\ + Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"\ + 10.168.0.132\",\r\n \"publicIPs\": {\r\n \"addresses\": [\r\n\ + \ {\r\n \"address\": \"104.40.16.196\"\r\n }\r\ + \n ],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: azure-asyncnotification: - Enabled cache-control: - no-cache content-length: - - '1250' + - '1252' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:21:45 GMT + - Tue, 26 Jan 2021 08:33:54 GMT expires: - '-1' pragma: @@ -1642,9 +1558,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 18201579-4a6e-45bc-93b7-728fb7ab8ec5 + - 1bb70dbb-5842-44af-b8e3-0ce43696a764 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1195' status: code: 200 message: OK @@ -1658,34 +1574,36 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"ce25b2b8-de59-4a7e-89bc-2116b88f19cc\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"sku\": {\r\n \"name\": - \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \"additionalProperties\": - {},\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"cfa729d0-6b67-495b-b3aa-89023b8f784f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": \"\ + Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"\ + 10.168.0.132\",\r\n \"publicIPs\": {\r\n \"addresses\": [\r\n\ + \ {\r\n \"address\": \"104.40.16.196\"\r\n }\r\ + \n ],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '1250' + - '1252' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:21:55 GMT + - Tue, 26 Jan 2021 08:34:04 GMT etag: - - W/"ce25b2b8-de59-4a7e-89bc-2116b88f19cc" + - W/"cfa729d0-6b67-495b-b3aa-89023b8f784f" expires: - '-1' pragma: @@ -1702,7 +1620,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b835cf91-06aa-40b9-a912-129f0b920e12 + - 976c0b32-f0b2-4cb0-adc3-42476ba4b724 status: code: 200 message: OK @@ -1716,34 +1634,36 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"ce25b2b8-de59-4a7e-89bc-2116b88f19cc\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"sku\": {\r\n \"name\": - \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \"additionalProperties\": - {},\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\"\ + ,\r\n \"etag\": \"W/\\\"81530f9e-30c9-4903-b23d-ed767533c7e3\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"sku\": {\r\n \"name\": \"AZFW_Hub\",\r\n \"tier\": \"\ + Standard\"\r\n },\r\n \"additionalProperties\": {},\r\n \"virtualHub\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\ + \r\n },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"\ + 10.168.0.132\",\r\n \"publicIPs\": {\r\n \"addresses\": [\r\n\ + \ {\r\n \"address\": \"104.40.16.196\"\r\n }\r\ + \n ],\r\n \"count\": 1\r\n }\r\n },\r\n \"firewallPolicy\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\ + \r\n }\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '1250' + - '1253' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:22:26 GMT + - Tue, 26 Jan 2021 08:34:34 GMT etag: - - W/"ce25b2b8-de59-4a7e-89bc-2116b88f19cc" + - W/"81530f9e-30c9-4903-b23d-ed767533c7e3" expires: - '-1' pragma: @@ -1760,7 +1680,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 897dcc44-61cc-4cf4-b2a5-34c62f2e5fe9 + - 9b84eaeb-0a0b-4430-a4fa-a816ea7dc735 status: code: 200 message: OK @@ -1768,42 +1688,35 @@ interactions: body: null headers: Accept: - - '*/*' + - application/json Accept-Encoding: - gzip, deflate Connection: - keep-alive + Content-Length: + - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"ce25b2b8-de59-4a7e-89bc-2116b88f19cc\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"sku\": {\r\n \"name\": - \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \"additionalProperties\": - {},\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: '' headers: + azure-asyncnotification: + - Enabled + azure-asyncoperation: + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 cache-control: - no-cache content-length: - - '1250' - content-type: - - application/json; charset=utf-8 + - '0' date: - - Wed, 25 Nov 2020 10:22:56 GMT - etag: - - W/"ce25b2b8-de59-4a7e-89bc-2116b88f19cc" + - Tue, 26 Jan 2021 08:34:35 GMT expires: - '-1' + location: + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 pragma: - no-cache server: @@ -1811,17 +1724,15 @@ interactions: - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e81ab0fa-230d-446a-849a-64781cc72049 + - 3fb3ff37-babb-41cb-b9a9-2c939c7e8474 + x-ms-ratelimit-remaining-subscription-deletes: + - '14989' status: - code: 200 - message: OK + code: 202 + message: Accepted - request: body: null headers: @@ -1832,34 +1743,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"azurefirewall\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall\",\r\n - \ \"etag\": \"W/\\\"ccc7e177-35fe-4f09-a54a-08fc222b239c\\\"\",\r\n \"type\": - \"Microsoft.Network/azureFirewalls\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"sku\": {\r\n \"name\": - \"AZFW_Hub\",\r\n \"tier\": \"Standard\"\r\n },\r\n \"additionalProperties\": - {},\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/virtualHubs/virtualhub\"\r\n - \ },\r\n \"hubIPAddresses\": {\r\n \"privateIPAddress\": \"10.168.0.68\",\r\n - \ \"publicIPs\": {\r\n \"addresses\": [\r\n {\r\n \"address\": - \"13.83.96.252\"\r\n }\r\n ],\r\n \"count\": 1\r\n - \ }\r\n },\r\n \"firewallPolicy\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/firewallPolicies/firewallpolicy\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"status\": \"InProgress\"\r\n}" headers: cache-control: - no-cache content-length: - - '1251' + - '30' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:23:56 GMT - etag: - - W/"ccc7e177-35fe-4f09-a54a-08fc222b239c" + - Tue, 26 Jan 2021 08:34:45 GMT expires: - '-1' pragma: @@ -1876,59 +1774,10 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ef0115b2-6a95-45b3-b272-acfa6170b0da + - a5384683-800b-49ff-b9fd-9345637a5658 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-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_firewall_test_network892411e1/providers/Microsoft.Network/azureFirewalls/azurefirewall?api-version=2020-07-01 - response: - body: - string: '' - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '0' - date: - - Wed, 25 Nov 2020 10:23:57 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 9a279f08-b8a6-4d16-82b2-0c2ef43308c9 - x-ms-ratelimit-remaining-subscription-deletes: - - '14999' - status: - code: 202 - message: Accepted - request: body: null headers: @@ -1939,9 +1788,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1953,7 +1802,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:24:09 GMT + - Tue, 26 Jan 2021 08:34:55 GMT expires: - '-1' pragma: @@ -1970,7 +1819,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3197dfa7-8da6-4ad8-8787-ff6b2c880427 + - a4709a4a-bb97-4e48-a9b1-f1d0c1ef1e3b status: code: 200 message: OK @@ -1984,9 +1833,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1998,7 +1847,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:24:19 GMT + - Tue, 26 Jan 2021 08:35:16 GMT expires: - '-1' pragma: @@ -2015,7 +1864,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 084d7aca-d675-4f91-8f32-da1882920148 + - 145488d8-e1ff-4c29-91e3-86bb1e845fd3 status: code: 200 message: OK @@ -2029,9 +1878,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2043,7 +1892,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:24:40 GMT + - Tue, 26 Jan 2021 08:35:36 GMT expires: - '-1' pragma: @@ -2060,7 +1909,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9b6f840b-a6de-41e8-ac0a-03e337e47b12 + - ada35753-6238-4ab7-84b1-c34403b55626 status: code: 200 message: OK @@ -2074,9 +1923,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2088,7 +1937,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:25:00 GMT + - Tue, 26 Jan 2021 08:36:16 GMT expires: - '-1' pragma: @@ -2105,7 +1954,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f587f86d-75e7-4dee-916d-7199f9974553 + - d47214bc-89f2-4ef6-b26a-3876d1b4f546 status: code: 200 message: OK @@ -2119,9 +1968,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2133,7 +1982,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:25:40 GMT + - Tue, 26 Jan 2021 08:36:57 GMT expires: - '-1' pragma: @@ -2150,7 +1999,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 45610fb5-6a77-4e38-b857-0b6c767c73a8 + - 93701a0f-a0ef-41ab-a2ce-73a2234616be status: code: 200 message: OK @@ -2164,9 +2013,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2178,7 +2027,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:26:21 GMT + - Tue, 26 Jan 2021 08:38:17 GMT expires: - '-1' pragma: @@ -2195,7 +2044,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4772c96a-89d9-40f2-9b62-7e3a76147da9 + - fda10c37-d705-46f4-a38f-07c9fb5e9d83 status: code: 200 message: OK @@ -2209,9 +2058,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2223,7 +2072,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:27:41 GMT + - Tue, 26 Jan 2021 08:40:58 GMT expires: - '-1' pragma: @@ -2240,7 +2089,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6dc4c384-e9b6-4bb1-85b9-e58e8307c231 + - ebbed208-318f-47fb-b89e-f74827f32265 status: code: 200 message: OK @@ -2254,9 +2103,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/07d96ccc-6645-4cbc-94e5-7bed00189173?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e8d49fd1-0958-4682-973b-f3ddaf6d91dd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2268,7 +2117,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:30:23 GMT + - Tue, 26 Jan 2021 08:42:38 GMT expires: - '-1' pragma: @@ -2285,7 +2134,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 122f88db-18ba-4527-84e1-ad0f8ad1a681 + - 08849139-b7ee-40df-addb-9f03693d2dcd status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall_policy.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall_policy.test_network.yaml index 352205be51e6..18ca38223581 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall_policy.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_firewall_policy.test_network.yaml @@ -14,21 +14,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\r\n - \ },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\": [],\r\n - \ \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \"provisioningState\": - \"Updating\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\",\r\n - \ \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\",\r\n - \ \"etag\": \"092884aa-040b-42f4-a59c-619a0a16c931\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\ + \r\n },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\"\ + : [],\r\n \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \ + \ \"provisioningState\": \"Updating\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\"\ + ,\r\n \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\"\ + ,\r\n \"etag\": \"e9b5cf2c-7382-4d7a-9aad-e0ae2fddaab2\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/e525a7ad-f796-44a6-b988-c59664d74a74?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/11d01c88-1221-45bb-8489-4d8bf596ab8d?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -36,7 +36,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:30:39 GMT + - Tue, 26 Jan 2021 08:42:58 GMT expires: - '-1' pragma: @@ -62,9 +62,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/nfvOperations/e525a7ad-f796-44a6-b988-c59664d74a74?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/11d01c88-1221-45bb-8489-4d8bf596ab8d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -76,7 +76,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:30:49 GMT + - Tue, 26 Jan 2021 08:43:08 GMT expires: - '-1' pragma: @@ -104,18 +104,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\r\n - \ },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\": [],\r\n - \ \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \"provisioningState\": - \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\",\r\n - \ \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\",\r\n - \ \"etag\": \"092884aa-040b-42f4-a59c-619a0a16c931\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\ + \r\n },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\"\ + : [],\r\n \"ruleCollectionGroups\": [],\r\n \"firewalls\": [],\r\n \ + \ \"provisioningState\": \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\"\ + ,\r\n \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\"\ + ,\r\n \"etag\": \"e9b5cf2c-7382-4d7a-9aad-e0ae2fddaab2\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -124,7 +124,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:30:50 GMT + - Tue, 26 Jan 2021 08:43:08 GMT expires: - '-1' pragma: @@ -160,28 +160,30 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup?api-version=2020-04-01 response: body: - string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\": - [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n \"action\": - {\r\n \"type\": \"Deny\"\r\n },\r\n \"ruleConditions\": - [\r\n {\r\n \"ruleConditionType\": \"NetworkRuleCondition\",\r\n - \ \"name\": \"network-condition1\",\r\n \"ipProtocols\": - [\r\n \"TCP\"\r\n ],\r\n \"sourceAddresses\": - [\r\n \"10.1.25.0/24\"\r\n ],\r\n \"destinationAddresses\": - [\r\n \"*\"\r\n ],\r\n \"destinationPorts\": - [\r\n \"*\"\r\n ]\r\n }\r\n ],\r\n - \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n - \ }\r\n ],\r\n \"provisioningState\": \"Updating\"\r\n },\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\",\r\n - \ \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\",\r\n - \ \"etag\": \"8c300e90-2a70-4986-af7b-5a854dbebd90\",\r\n \"location\": \"westus\"\r\n}" + string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\"\ + : [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n\ + \ \"action\": {\r\n \"type\": \"Deny\"\r\n },\r\n \ + \ \"ruleConditions\": [\r\n {\r\n \"ruleConditionType\"\ + : \"NetworkRuleCondition\",\r\n \"name\": \"network-condition1\"\ + ,\r\n \"ipProtocols\": [\r\n \"TCP\"\r\n \ + \ ],\r\n \"sourceAddresses\": [\r\n \"10.1.25.0/24\"\ + \r\n ],\r\n \"destinationAddresses\": [\r\n \ + \ \"*\"\r\n ],\r\n \"destinationPorts\": [\r\n\ + \ \"*\"\r\n ]\r\n }\r\n ],\r\n \ + \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n \ + \ }\r\n ],\r\n \"provisioningState\": \"Updating\"\r\n },\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\"\ + ,\r\n \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\"\ + ,\r\n \"etag\": \"943d6211-2e4d-450a-a53e-1b701314c906\",\r\n \"location\"\ + : \"westus\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/a75fc460-7870-4ec9-850e-79087ceaeb41?api-version=2020-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/626f8e58-a01b-49d8-8b63-9a7d79b6455c?api-version=2020-04-01 cache-control: - no-cache content-length: @@ -189,7 +191,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:30:52 GMT + - Tue, 26 Jan 2021 08:43:11 GMT expires: - '-1' pragma: @@ -215,9 +217,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/nfvOperations/a75fc460-7870-4ec9-850e-79087ceaeb41?api-version=2020-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/626f8e58-a01b-49d8-8b63-9a7d79b6455c?api-version=2020-04-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -229,7 +231,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:02 GMT + - Tue, 26 Jan 2021 08:43:22 GMT expires: - '-1' pragma: @@ -257,25 +259,27 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup?api-version=2020-04-01 response: body: - string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\": - [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n \"action\": - {\r\n \"type\": \"Deny\"\r\n },\r\n \"ruleConditions\": - [\r\n {\r\n \"ruleConditionType\": \"NetworkRuleCondition\",\r\n - \ \"name\": \"network-condition1\",\r\n \"ipProtocols\": - [\r\n \"TCP\"\r\n ],\r\n \"sourceAddresses\": - [\r\n \"10.1.25.0/24\"\r\n ],\r\n \"destinationAddresses\": - [\r\n \"*\"\r\n ],\r\n \"destinationPorts\": - [\r\n \"*\"\r\n ]\r\n }\r\n ],\r\n - \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n - \ }\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n },\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\",\r\n - \ \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\",\r\n - \ \"etag\": \"8c300e90-2a70-4986-af7b-5a854dbebd90\",\r\n \"location\": \"westus\"\r\n}" + string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\"\ + : [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n\ + \ \"action\": {\r\n \"type\": \"Deny\"\r\n },\r\n \ + \ \"ruleConditions\": [\r\n {\r\n \"ruleConditionType\"\ + : \"NetworkRuleCondition\",\r\n \"name\": \"network-condition1\"\ + ,\r\n \"ipProtocols\": [\r\n \"TCP\"\r\n \ + \ ],\r\n \"sourceAddresses\": [\r\n \"10.1.25.0/24\"\ + \r\n ],\r\n \"destinationAddresses\": [\r\n \ + \ \"*\"\r\n ],\r\n \"destinationPorts\": [\r\n\ + \ \"*\"\r\n ]\r\n }\r\n ],\r\n \ + \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n \ + \ }\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n },\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\"\ + ,\r\n \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\"\ + ,\r\n \"etag\": \"943d6211-2e4d-450a-a53e-1b701314c906\",\r\n \"location\"\ + : \"westus\"\r\n}" headers: cache-control: - no-cache @@ -284,7 +288,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:02 GMT + - Tue, 26 Jan 2021 08:43:23 GMT expires: - '-1' pragma: @@ -312,25 +316,27 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup?api-version=2020-04-01 response: body: - string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\": - [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n \"action\": - {\r\n \"type\": \"Deny\"\r\n },\r\n \"ruleConditions\": - [\r\n {\r\n \"ruleConditionType\": \"NetworkRuleCondition\",\r\n - \ \"name\": \"network-condition1\",\r\n \"ipProtocols\": - [\r\n \"TCP\"\r\n ],\r\n \"sourceAddresses\": - [\r\n \"10.1.25.0/24\"\r\n ],\r\n \"destinationAddresses\": - [\r\n \"*\"\r\n ],\r\n \"destinationPorts\": - [\r\n \"*\"\r\n ]\r\n }\r\n ],\r\n - \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n - \ }\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n },\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\",\r\n - \ \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\",\r\n - \ \"etag\": \"8c300e90-2a70-4986-af7b-5a854dbebd90\",\r\n \"location\": \"westus\"\r\n}" + string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\"\ + : [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n\ + \ \"action\": {\r\n \"type\": \"Deny\"\r\n },\r\n \ + \ \"ruleConditions\": [\r\n {\r\n \"ruleConditionType\"\ + : \"NetworkRuleCondition\",\r\n \"name\": \"network-condition1\"\ + ,\r\n \"ipProtocols\": [\r\n \"TCP\"\r\n \ + \ ],\r\n \"sourceAddresses\": [\r\n \"10.1.25.0/24\"\ + \r\n ],\r\n \"destinationAddresses\": [\r\n \ + \ \"*\"\r\n ],\r\n \"destinationPorts\": [\r\n\ + \ \"*\"\r\n ]\r\n }\r\n ],\r\n \ + \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n \ + \ }\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n },\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\"\ + ,\r\n \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\"\ + ,\r\n \"etag\": \"943d6211-2e4d-450a-a53e-1b701314c906\",\r\n \"location\"\ + : \"westus\"\r\n}" headers: cache-control: - no-cache @@ -339,7 +345,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:02 GMT + - Tue, 26 Jan 2021 08:43:23 GMT expires: - '-1' pragma: @@ -367,19 +373,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\r\n - \ },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\": [],\r\n - \ \"ruleCollectionGroups\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallpolicies/myFirewallPolicy/ruleCollectionGroups/myRuleGroup\"\r\n - \ }\r\n ],\r\n \"firewalls\": [],\r\n \"provisioningState\": - \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\",\r\n - \ \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\",\r\n - \ \"etag\": \"092884aa-040b-42f4-a59c-619a0a16c931\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"sku\": {\r\n \"tier\": \"Standard\"\ + \r\n },\r\n \"threatIntelMode\": \"Alert\",\r\n \"childPolicies\"\ + : [],\r\n \"ruleCollectionGroups\": [\r\n {\r\n \"id\": \"\ + /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallpolicies/myFirewallPolicy/ruleCollectionGroups/myRuleGroup\"\ + \r\n }\r\n ],\r\n \"firewalls\": [],\r\n \"provisioningState\"\ + : \"Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy\"\ + ,\r\n \"name\": \"myFirewallPolicy\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies\"\ + ,\r\n \"etag\": \"43128217-0acc-4ffb-96b5-053b1eac62a1\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -388,7 +395,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:03 GMT + - Tue, 26 Jan 2021 08:43:23 GMT expires: - '-1' pragma: @@ -418,28 +425,30 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup?api-version=2020-04-01 response: body: - string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\": - [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n \"action\": - {\r\n \"type\": \"Deny\"\r\n },\r\n \"ruleConditions\": - [\r\n {\r\n \"ruleConditionType\": \"NetworkRuleCondition\",\r\n - \ \"name\": \"network-condition1\",\r\n \"ipProtocols\": - [\r\n \"TCP\"\r\n ],\r\n \"sourceAddresses\": - [\r\n \"10.1.25.0/24\"\r\n ],\r\n \"destinationAddresses\": - [\r\n \"*\"\r\n ],\r\n \"destinationPorts\": - [\r\n \"*\"\r\n ]\r\n }\r\n ],\r\n - \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n - \ }\r\n ],\r\n \"provisioningState\": \"Deleting\"\r\n },\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\",\r\n - \ \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\",\r\n - \ \"etag\": \"8c300e90-2a70-4986-af7b-5a854dbebd90\",\r\n \"location\": \"westus\"\r\n}" + string: "{\r\n \"properties\": {\r\n \"priority\": 110,\r\n \"rules\"\ + : [\r\n {\r\n \"ruleType\": \"FirewallPolicyFilterRule\",\r\n\ + \ \"action\": {\r\n \"type\": \"Deny\"\r\n },\r\n \ + \ \"ruleConditions\": [\r\n {\r\n \"ruleConditionType\"\ + : \"NetworkRuleCondition\",\r\n \"name\": \"network-condition1\"\ + ,\r\n \"ipProtocols\": [\r\n \"TCP\"\r\n \ + \ ],\r\n \"sourceAddresses\": [\r\n \"10.1.25.0/24\"\ + \r\n ],\r\n \"destinationAddresses\": [\r\n \ + \ \"*\"\r\n ],\r\n \"destinationPorts\": [\r\n\ + \ \"*\"\r\n ]\r\n }\r\n ],\r\n \ + \ \"name\": \"Example-Filter-Rule\",\r\n \"priority\": 0\r\n \ + \ }\r\n ],\r\n \"provisioningState\": \"Deleting\"\r\n },\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy/ruleGroups/myRuleGroup\"\ + ,\r\n \"name\": \"myRuleGroup\",\r\n \"type\": \"Microsoft.Network/FirewallPolicies/RuleGroups\"\ + ,\r\n \"etag\": \"e49f88a6-eb45-4a5f-8fcc-b20f4a16c4b8\",\r\n \"location\"\ + : \"westus\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/a3a065fb-2859-40c6-bd34-012b87db1c6a?api-version=2020-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/41462a68-7f67-4549-983a-c410e7dad1eb?api-version=2020-04-01 cache-control: - no-cache content-length: @@ -447,11 +456,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:04 GMT + - Tue, 26 Jan 2021 08:43:24 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperationResults/a3a065fb-2859-40c6-bd34-012b87db1c6a?api-version=2020-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperationResults/41462a68-7f67-4549-983a-c410e7dad1eb?api-version=2020-04-01 pragma: - no-cache server: @@ -475,9 +484,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/nfvOperations/a3a065fb-2859-40c6-bd34-012b87db1c6a?api-version=2020-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/41462a68-7f67-4549-983a-c410e7dad1eb?api-version=2020-04-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -489,7 +498,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:31:14 GMT + - Tue, 26 Jan 2021 08:43:35 GMT expires: - '-1' pragma: @@ -519,9 +528,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/firewallPolicies/myFirewallPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/firewallPolicies/myFirewallPolicy?api-version=2020-08-01 response: body: string: '' @@ -531,7 +540,7 @@ interactions: content-length: - '0' date: - - Wed, 25 Nov 2020 10:31:17 GMT + - Tue, 26 Jan 2021 08:43:38 GMT expires: - '-1' pragma: diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_interface.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_interface.test_network.yaml index 66c7ad6f11ab..1a856a4dcc57 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_interface.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_interface.test_network.yaml @@ -14,24 +14,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\",\r\n - \ \"etag\": \"W/\\\"e829325d-52e1-4ee1-9011-30af3ea6a6d7\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"a4f9e3a8-9274-47bf-9cf1-2071a78902b7\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\"\ + ,\r\n \"etag\": \"W/\\\"4550f489-8b4a-4863-90e8-c6805f99ba13\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"8f86a96a-6325-4d24-90ff-5f1c827849ad\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3be8bb37-290a-4bcc-bed7-ce01bbb8ebe5?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6cacb184-3604-42b6-b2ab-86305ccfb7c7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:00 GMT + - Tue, 26 Jan 2021 08:43:55 GMT expires: - '-1' pragma: @@ -52,7 +53,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2786f067-e50e-4c67-8b89-b0bfda0c570b + - 9d55c8b9-cb41-4580-a175-b566261b0054 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -68,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3be8bb37-290a-4bcc-bed7-ce01bbb8ebe5?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6cacb184-3604-42b6-b2ab-86305ccfb7c7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:04 GMT + - Tue, 26 Jan 2021 08:43:58 GMT expires: - '-1' pragma: @@ -99,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3e432cca-b4b5-458f-b2e8-b45c81aa9179 + - 7444fe9f-bcb9-41a9-9adf-b27e37f5a78b status: code: 200 message: OK @@ -113,19 +114,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\",\r\n - \ \"etag\": \"W/\\\"64134922-110f-4389-a0f1-9172ec096698\\\"\",\r\n \"type\": - \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"a4f9e3a8-9274-47bf-9cf1-2071a78902b7\",\r\n \"addressSpace\": {\r\n \"addressPrefixes\": - [\r\n \"10.0.0.0/16\"\r\n ]\r\n },\r\n \"subnets\": [],\r\n - \ \"virtualNetworkPeerings\": [],\r\n \"enableDdosProtection\": false,\r\n - \ \"enableVmProtection\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualnetwork\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork\"\ + ,\r\n \"etag\": \"W/\\\"568a0f1e-dc9b-4fd9-9565-89963840c3c8\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"8f86a96a-6325-4d24-90ff-5f1c827849ad\",\r\n \"\ + addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ + \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ + : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ + : false\r\n }\r\n}" headers: cache-control: - no-cache @@ -134,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:05 GMT + - Tue, 26 Jan 2021 08:43:59 GMT etag: - - W/"64134922-110f-4389-a0f1-9172ec096698" + - W/"568a0f1e-dc9b-4fd9-9565-89963840c3c8" expires: - '-1' pragma: @@ -153,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f043b144-b10f-4080-9e02-2e0e8b836ae9 + - b86da1ac-0465-4441-b766-754a71c208f3 status: code: 200 message: OK @@ -171,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\",\r\n - \ \"etag\": \"W/\\\"dffdd23f-e5e5-4504-a131-affd3f0b2cc3\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + ,\r\n \"etag\": \"W/\\\"20f86b89-a6d3-4573-b432-9892a8317991\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/52effab1-7bbf-486e-8b27-5a583300a72f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37be024a-25f9-46c7-b069-a0e50a9e60be?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -192,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:05 GMT + - Tue, 26 Jan 2021 08:43:59 GMT expires: - '-1' pragma: @@ -205,7 +207,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b54fbdec-11f3-4cc3-aa62-93873d7d2eee + - edc05247-5732-479f-a0f3-f40ba492eb13 x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -221,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/52effab1-7bbf-486e-8b27-5a583300a72f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37be024a-25f9-46c7-b069-a0e50a9e60be?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -235,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:09 GMT + - Tue, 26 Jan 2021 08:44:03 GMT expires: - '-1' pragma: @@ -252,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b7d211cc-90b8-42ec-9e3a-de9f84975298 + - 0e82bec9-f70b-4f13-bff0-cddcaf7d3fce status: code: 200 message: OK @@ -266,17 +268,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork/subnets/subnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"subnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\",\r\n - \ \"etag\": \"W/\\\"027e1c84-7eb8-4e5e-a187-fead4ecee80c\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.0.0/24\",\r\n - \ \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\": \"Enabled\",\r\n - \ \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\n },\r\n \"type\": - \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" + string: "{\r\n \"name\": \"subnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + ,\r\n \"etag\": \"W/\\\"48ab1740-1471-4ef5-8c5d-9ecf454c623c\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ + : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ + \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: cache-control: - no-cache @@ -285,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:09 GMT + - Tue, 26 Jan 2021 08:44:04 GMT etag: - - W/"027e1c84-7eb8-4e5e-a187-fead4ecee80c" + - W/"48ab1740-1471-4ef5-8c5d-9ecf454c623c" expires: - '-1' pragma: @@ -304,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 21cc76f9-1bba-4b89-9007-5a85b51a8881 + - c0f7de1b-0b32-454a-a44e-857ffc597238 status: code: 200 message: OK @@ -322,24 +324,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\",\r\n - \ \"etag\": \"W/\\\"0d9aae20-6bb2-4271-bd1a-14c13e8eceee\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"resourceGuid\": \"daf6e06b-6bec-4f55-bdc2-1137cdd8a84f\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + ,\r\n \"etag\": \"W/\\\"5835c9e9-0ae7-45ad-9577-36209a89fdb9\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"resourceGuid\": \"31b30310-431d-4ee9-be35-bf2a57a78f0d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/adf28f0b-22c8-4511-be30-93e6e4a53dc2?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8bf87d8d-e372-4967-81dc-1d2d053f0451?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -347,7 +349,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:14 GMT + - Tue, 26 Jan 2021 08:44:09 GMT expires: - '-1' pragma: @@ -360,7 +362,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ddfe40bd-0cf7-46eb-90e4-2e7ad95a6ba5 + - 363c1c34-8309-4152-9674-2df1445262fe x-ms-ratelimit-remaining-subscription-writes: - '1196' status: @@ -376,9 +378,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/adf28f0b-22c8-4511-be30-93e6e4a53dc2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8bf87d8d-e372-4967-81dc-1d2d053f0451?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -390,7 +392,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:15 GMT + - Tue, 26 Jan 2021 08:44:10 GMT expires: - '-1' pragma: @@ -407,7 +409,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c7413037-6d98-4694-87f9-3a760547d5b7 + - 397c27dc-5188-43c0-8d97-3908ff9c4b54 status: code: 200 message: OK @@ -421,19 +423,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\",\r\n - \ \"etag\": \"W/\\\"15e3d715-50d9-480a-ad05-1fcc3e5503a4\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"daf6e06b-6bec-4f55-bdc2-1137cdd8a84f\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + ,\r\n \"etag\": \"W/\\\"2569fc1a-e908-4d02-86a7-1a8f1227d7fb\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"31b30310-431d-4ee9-be35-bf2a57a78f0d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -442,9 +444,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:15 GMT + - Tue, 26 Jan 2021 08:44:10 GMT etag: - - W/"15e3d715-50d9-480a-ad05-1fcc3e5503a4" + - W/"2569fc1a-e908-4d02-86a7-1a8f1227d7fb" expires: - '-1' pragma: @@ -461,7 +463,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 25396e7d-6289-4756-a352-98191d94901e + - f078e01c-16bb-4594-b3d0-4a922b6af5fe status: code: 200 message: OK @@ -482,35 +484,37 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\r\n - \ \"etag\": \"W/\\\"fe7ba487-8625-47cd-bbe7-5b46e73232d2\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"d0bca5f8-9296-4fb9-8b08-62d82e91acef\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"fe7ba487-8625-47cd-bbe7-5b46e73232d2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"vdr5tjdusk5uphhreby0pcicwh.bx.internal.cloudapp.net\"\r\n },\r\n \"enableAcceleratedNetworking\": - true,\r\n \"enableIPForwarding\": false,\r\n \"hostedWorkloads\": [],\r\n - \ \"tapConfigurations\": [],\r\n \"nicType\": \"Standard\"\r\n },\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\r\n \"etag\": \"W/\\\"07203469-e640-4e7f-b1a6-d55a459b26b5\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"6409a6ce-5825-419d-9325-f02010d3d63a\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"myIpConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"07203469-e640-4e7f-b1a6-d55a459b26b5\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nkuyndzfmmse1eh5l2oie4cjvf.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"enableAcceleratedNetworking\": true,\r\n \"enableIPForwarding\"\ + : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/db5ebad6-2836-4b97-bde7-aca87c0a93f9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a9e3ab36-64f5-475d-b787-3c0790e9a620?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -518,7 +522,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:19 GMT + - Tue, 26 Jan 2021 08:44:14 GMT expires: - '-1' pragma: @@ -531,7 +535,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0bbae132-6f57-4ec9-9349-35bf5d56de37 + - c773af6e-eb0b-47ee-806a-4f7c04848a62 x-ms-ratelimit-remaining-subscription-writes: - '1195' status: @@ -547,9 +551,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/db5ebad6-2836-4b97-bde7-aca87c0a93f9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a9e3ab36-64f5-475d-b787-3c0790e9a620?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -561,7 +565,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:51 GMT + - Tue, 26 Jan 2021 08:44:44 GMT expires: - '-1' pragma: @@ -578,7 +582,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - af9dd734-0feb-4669-83dd-4efc4a4cee95 + - 43216a83-85c8-42fb-a118-1d216057ed83 status: code: 200 message: OK @@ -592,30 +596,32 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\r\n - \ \"etag\": \"W/\\\"fe7ba487-8625-47cd-bbe7-5b46e73232d2\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"d0bca5f8-9296-4fb9-8b08-62d82e91acef\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"fe7ba487-8625-47cd-bbe7-5b46e73232d2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"vdr5tjdusk5uphhreby0pcicwh.bx.internal.cloudapp.net\"\r\n },\r\n \"enableAcceleratedNetworking\": - true,\r\n \"enableIPForwarding\": false,\r\n \"hostedWorkloads\": [],\r\n - \ \"tapConfigurations\": [],\r\n \"nicType\": \"Standard\"\r\n },\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\r\n \"etag\": \"W/\\\"07203469-e640-4e7f-b1a6-d55a459b26b5\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"6409a6ce-5825-419d-9325-f02010d3d63a\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"myIpConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"07203469-e640-4e7f-b1a6-d55a459b26b5\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nkuyndzfmmse1eh5l2oie4cjvf.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"enableAcceleratedNetworking\": true,\r\n \"enableIPForwarding\"\ + : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: cache-control: - no-cache @@ -624,9 +630,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:56:51 GMT + - Tue, 26 Jan 2021 08:44:45 GMT etag: - - W/"fe7ba487-8625-47cd-bbe7-5b46e73232d2" + - W/"07203469-e640-4e7f-b1a6-d55a459b26b5" expires: - '-1' pragma: @@ -643,7 +649,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d6440546-0234-4b14-90c6-0bc9ea06a679 + - 31bbded6-d0d5-4b8b-acc8-19353a3f5b81 status: code: 200 message: OK @@ -670,54 +676,58 @@ interactions: Content-Type: - application/json; charset=utf-8 User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine?api-version=2020-06-01 response: body: - string: "{\r\n \"name\": \"virtualmachine\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\",\r\n - \ \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"vmId\": \"a22e0f05-d51a-41f4-a636-2d0209c21f4e\",\r\n - \ \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n },\r\n - \ \"storageProfile\": {\r\n \"imageReference\": {\r\n \"publisher\": - \"MicrosoftWindowsServer\",\r\n \"offer\": \"WindowsServer\",\r\n \"sku\": - \"2016-Datacenter\",\r\n \"version\": \"latest\",\r\n \"exactVersion\": - \"14393.4048.2011170655\"\r\n },\r\n \"osDisk\": {\r\n \"osType\": - \"Windows\",\r\n \"name\": \"myVMosdisk\",\r\n \"createOption\": - \"FromImage\",\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n - \ \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": [\r\n {\r\n - \ \"lun\": 0,\r\n \"createOption\": \"Empty\",\r\n \"caching\": - \"None\",\r\n \"managedDisk\": {\r\n \"storageAccountType\": - \"Standard_LRS\"\r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"createOption\": - \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n - \ \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n }\r\n - \ ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\": \"myVM\",\r\n - \ \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\": - {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\": - true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\r\n - \ }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\": - true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\": - {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\"properties\":{\"primary\":true}}]},\r\n - \ \"provisioningState\": \"Creating\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualmachine\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\ + ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"1447a803-5ea7-4c04-beff-1893f31026e2\"\ + ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ + \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ + \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ + WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ + \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ + \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ + ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ + \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ + \ \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": [\r\n \ + \ {\r\n \"lun\": 0,\r\n \"createOption\": \"Empty\",\r\n\ + \ \"caching\": \"None\",\r\n \"managedDisk\": {\r\n \ + \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ + \ \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n \ + \ },\r\n {\r\n \"lun\": 1,\r\n \"createOption\"\ + : \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\"\ + : {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\ + \n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n\ + \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ + : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ + : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ + : true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\ + \r\n }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ + : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ + networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ + \r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/df3114f4-4794-4cdb-8672-0d4b27c1ad6a?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/e7a9f126-1171-4ba8-a067-cb4f96bc63c1?api-version=2020-06-01 cache-control: - no-cache content-length: - - '2299' + - '2406' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:57:01 GMT + - Tue, 26 Jan 2021 08:44:54 GMT expires: - '-1' pragma: @@ -730,9 +740,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;743,Microsoft.Compute/PutVM30Min;3719 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1199 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1198' status: code: 201 message: Created @@ -746,14 +756,15 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/df3114f4-4794-4cdb-8672-0d4b27c1ad6a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/e7a9f126-1171-4ba8-a067-cb4f96bc63c1?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:57:00.5471723+00:00\",\r\n \"status\": - \"InProgress\",\r\n \"name\": \"df3114f4-4794-4cdb-8672-0d4b27c1ad6a\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T08:44:53.2452679+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"e7a9f126-1171-4ba8-a067-cb4f96bc63c1\"\ + \r\n}" headers: cache-control: - no-cache @@ -762,7 +773,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:57:12 GMT + - Tue, 26 Jan 2021 08:45:05 GMT expires: - '-1' pragma: @@ -779,7 +790,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14999,Microsoft.Compute/GetOperation30Min;29997 + - Microsoft.Compute/GetOperation3Min;14999,Microsoft.Compute/GetOperation30Min;29999 status: code: 200 message: OK @@ -793,14 +804,15 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/df3114f4-4794-4cdb-8672-0d4b27c1ad6a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/e7a9f126-1171-4ba8-a067-cb4f96bc63c1?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:57:00.5471723+00:00\",\r\n \"status\": - \"InProgress\",\r\n \"name\": \"df3114f4-4794-4cdb-8672-0d4b27c1ad6a\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T08:44:53.2452679+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"e7a9f126-1171-4ba8-a067-cb4f96bc63c1\"\ + \r\n}" headers: cache-control: - no-cache @@ -809,7 +821,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:02 GMT + - Tue, 26 Jan 2021 08:45:56 GMT expires: - '-1' pragma: @@ -826,7 +838,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14998,Microsoft.Compute/GetOperation30Min;29996 + - Microsoft.Compute/GetOperation3Min;14998,Microsoft.Compute/GetOperation30Min;29998 status: code: 200 message: OK @@ -840,15 +852,15 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/df3114f4-4794-4cdb-8672-0d4b27c1ad6a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/e7a9f126-1171-4ba8-a067-cb4f96bc63c1?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:57:00.5471723+00:00\",\r\n \"endTime\": - \"2020-11-26T06:58:09.7975506+00:00\",\r\n \"status\": \"Succeeded\",\r\n - \ \"name\": \"df3114f4-4794-4cdb-8672-0d4b27c1ad6a\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T08:44:53.2452679+00:00\",\r\n \"\ + endTime\": \"2021-01-26T08:46:25.6358724+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"e7a9f126-1171-4ba8-a067-cb4f96bc63c1\"\r\n}" headers: cache-control: - no-cache @@ -857,7 +869,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:33 GMT + - Tue, 26 Jan 2021 08:46:26 GMT expires: - '-1' pragma: @@ -874,7 +886,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14996,Microsoft.Compute/GetOperation30Min;29994 + - Microsoft.Compute/GetOperation3Min;14997,Microsoft.Compute/GetOperation30Min;29997 status: code: 200 message: OK @@ -888,53 +900,57 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine?api-version=2020-06-01 response: body: - string: "{\r\n \"name\": \"virtualmachine\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\",\r\n - \ \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"vmId\": \"a22e0f05-d51a-41f4-a636-2d0209c21f4e\",\r\n - \ \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n },\r\n - \ \"storageProfile\": {\r\n \"imageReference\": {\r\n \"publisher\": - \"MicrosoftWindowsServer\",\r\n \"offer\": \"WindowsServer\",\r\n \"sku\": - \"2016-Datacenter\",\r\n \"version\": \"latest\",\r\n \"exactVersion\": - \"14393.4048.2011170655\"\r\n },\r\n \"osDisk\": {\r\n \"osType\": - \"Windows\",\r\n \"name\": \"myVMosdisk\",\r\n \"createOption\": - \"FromImage\",\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\r\n - \ },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": - [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine_disk2_a2d4171ead55440faadf8991902f13a1\",\r\n - \ \"createOption\": \"Empty\",\r\n \"caching\": \"None\",\r\n - \ \"managedDisk\": {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine_disk2_a2d4171ead55440faadf8991902f13a1\"\r\n - \ },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"name\": - \"virtualmachine_disk3_d4b7a94eb8214b8991bcbf962a195b5c\",\r\n \"createOption\": - \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\": - {\r\n \"storageAccountType\": \"Standard_LRS\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine_disk3_d4b7a94eb8214b8991bcbf962a195b5c\"\r\n - \ },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": - false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\": - \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\": - {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\": - true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\r\n - \ }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\": - true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\": - {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\"properties\":{\"primary\":true}}]},\r\n - \ \"provisioningState\": \"Succeeded\"\r\n }\r\n}" + string: "{\r\n \"name\": \"virtualmachine\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\ + ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"1447a803-5ea7-4c04-beff-1893f31026e2\"\ + ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ + \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ + \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ + WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ + \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ + \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ + ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ + \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ + \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ + : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine_disk2_e8c78937d01b437899735fd470c71cd6\"\ + ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ + ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine_disk2_e8c78937d01b437899735fd470c71cd6\"\ + \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ + : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ + name\": \"virtualmachine_disk3_36cee1878ef64f4298d49fab9a57bb9d\",\r\n \ + \ \"createOption\": \"Empty\",\r\n \"caching\": \"None\",\r\ + \n \"managedDisk\": {\r\n \"storageAccountType\": \"Standard_LRS\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine_disk3_36cee1878ef64f4298d49fab9a57bb9d\"\ + \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ + : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ + \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ + \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ + \n \"enableAutomaticUpdates\": true,\r\n \"patchSettings\":\ + \ {\r\n \"patchMode\": \"AutomaticByOS\"\r\n }\r\n },\r\ + \n \"secrets\": [],\r\n \"allowExtensionOperations\": true,\r\n\ + \ \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\"\ + : {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '3166' + - '3273' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:33 GMT + - Tue, 26 Jan 2021 08:46:26 GMT expires: - '-1' pragma: @@ -951,7 +967,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3996,Microsoft.Compute/LowCostGet30Min;31987 + - Microsoft.Compute/LowCostGet3Min;3999,Microsoft.Compute/LowCostGet30Min;31999 status: code: 200 message: OK @@ -965,20 +981,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"c2070919-4289-4c49-b5cd-bcb3f6fac89b\\\"\",\r\n \"type\": - \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"privateIPAddress\": - \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"b2e937ab-609b-454b-aa7b-7b00ab7ecab4\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n\ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": \"\ + Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": \"\ + IPv4\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -987,9 +1003,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:34 GMT + - Tue, 26 Jan 2021 08:46:28 GMT etag: - - W/"c2070919-4289-4c49-b5cd-bcb3f6fac89b" + - W/"b2e937ab-609b-454b-aa7b-7b00ab7ecab4" expires: - '-1' pragma: @@ -1006,7 +1022,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 828948b5-2948-414d-85a0-4c825eaa1538 + - d1d6ed08-00e5-4851-aaf1-2f552496dedb status: code: 200 message: OK @@ -1020,32 +1036,34 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\r\n - \ \"etag\": \"W/\\\"c2070919-4289-4c49-b5cd-bcb3f6fac89b\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"d0bca5f8-9296-4fb9-8b08-62d82e91acef\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"c2070919-4289-4c49-b5cd-bcb3f6fac89b\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"vdr5tjdusk5uphhreby0pcicwh.bx.internal.cloudapp.net\"\r\n },\r\n \"macAddress\": - \"00-0D-3A-99-10-C4\",\r\n \"enableAcceleratedNetworking\": true,\r\n \"enableIPForwarding\": - false,\r\n \"primary\": true,\r\n \"virtualMachine\": {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\r\n - \ },\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\n - \ \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\r\n \"etag\": \"W/\\\"b2e937ab-609b-454b-aa7b-7b00ab7ecab4\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"6409a6ce-5825-419d-9325-f02010d3d63a\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"myIpConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"b2e937ab-609b-454b-aa7b-7b00ab7ecab4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nkuyndzfmmse1eh5l2oie4cjvf.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"macAddress\": \"00-0D-3A-14-79-63\",\r\n \"enableAcceleratedNetworking\"\ + : true,\r\n \"enableIPForwarding\": false,\r\n \"primary\": true,\r\n\ + \ \"virtualMachine\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\ + \r\n },\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: cache-control: - no-cache @@ -1054,9 +1072,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:35 GMT + - Tue, 26 Jan 2021 08:46:28 GMT etag: - - W/"c2070919-4289-4c49-b5cd-bcb3f6fac89b" + - W/"b2e937ab-609b-454b-aa7b-7b00ab7ecab4" expires: - '-1' pragma: @@ -1073,7 +1091,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bd266686-e47c-47a1-8068-d762d9146d65 + - c41e3369-8822-4caf-8017-eee7a8f8ac72 status: code: 200 message: OK @@ -1089,9 +1107,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface/effectiveNetworkSecurityGroups?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/effectiveNetworkSecurityGroups?api-version=2020-08-01 response: body: string: 'null' @@ -1103,11 +1121,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:35 GMT + - Tue, 26 Jan 2021 08:46:29 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2ea87eee-4483-406e-9b10-3b256a630c25?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1803b278-5dcd-4646-b032-ea36e54928ff?api-version=2020-08-01 pragma: - no-cache server: @@ -1118,7 +1136,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 99b73c28-767c-45c7-90ea-4a18ddbd7a7a + - c3957974-76ea-439e-a3ce-ebf1f75784c0 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -1134,9 +1152,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/2ea87eee-4483-406e-9b10-3b256a630c25?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1803b278-5dcd-4646-b032-ea36e54928ff?api-version=2020-08-01 response: body: string: "{\r\n \"value\": []\r\n}" @@ -1148,11 +1166,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:46 GMT + - Tue, 26 Jan 2021 08:46:39 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2ea87eee-4483-406e-9b10-3b256a630c25?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1803b278-5dcd-4646-b032-ea36e54928ff?api-version=2020-08-01 pragma: - no-cache server: @@ -1167,7 +1185,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 99b73c28-767c-45c7-90ea-4a18ddbd7a7a + - c3957974-76ea-439e-a3ce-ebf1f75784c0 status: code: 200 message: OK @@ -1183,9 +1201,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface/effectiveRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/effectiveRouteTable?api-version=2020-08-01 response: body: string: 'null' @@ -1197,11 +1215,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:46 GMT + - Tue, 26 Jan 2021 08:46:40 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f13c36ba-59f8-4ad0-a0d2-764047b88272?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/14d633fa-e919-41c3-9021-7cd317435c57?api-version=2020-08-01 pragma: - no-cache server: @@ -1212,7 +1230,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 311ab446-48b1-46ef-8ca3-a5bbe17f8590 + - 90e1c92c-dfb3-47c6-9ce8-bd37ba38782f x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -1228,44 +1246,47 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/f13c36ba-59f8-4ad0-a0d2-764047b88272?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/14d633fa-e919-41c3-9021-7cd317435c57?api-version=2020-08-01 response: body: - string: "{\r\n \"value\": [\r\n {\r\n \"disableBgpRoutePropagation\": - false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\",\r\n - \ \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \"10.0.0.0/16\"\r\n - \ ],\r\n \"nextHopType\": \"VnetLocal\",\r\n \"nextHopIpAddress\": - [],\r\n \"destinationServiceTags\": [],\r\n \"tagMap\": {}\r\n },\r\n - \ {\r\n \"disableBgpRoutePropagation\": false,\r\n \"source\": - \"Default\",\r\n \"state\": \"Active\",\r\n \"hasBgpOverride\": - false,\r\n \"addressPrefix\": [\r\n \"0.0.0.0/0\"\r\n ],\r\n - \ \"nextHopType\": \"Internet\",\r\n \"nextHopIpAddress\": [],\r\n - \ \"destinationServiceTags\": [],\r\n \"tagMap\": {}\r\n },\r\n - \ {\r\n \"disableBgpRoutePropagation\": false,\r\n \"source\": - \"Default\",\r\n \"state\": \"Active\",\r\n \"hasBgpOverride\": - false,\r\n \"addressPrefix\": [\r\n \"10.0.0.0/8\"\r\n ],\r\n - \ \"nextHopType\": \"None\",\r\n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": - [],\r\n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\": - false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\",\r\n - \ \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \"100.64.0.0/10\"\r\n - \ ],\r\n \"nextHopType\": \"None\",\r\n \"nextHopIpAddress\": - [],\r\n \"destinationServiceTags\": [],\r\n \"tagMap\": {}\r\n },\r\n - \ {\r\n \"disableBgpRoutePropagation\": false,\r\n \"source\": - \"Default\",\r\n \"state\": \"Active\",\r\n \"hasBgpOverride\": - false,\r\n \"addressPrefix\": [\r\n \"192.168.0.0/16\"\r\n ],\r\n - \ \"nextHopType\": \"None\",\r\n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": - [],\r\n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\": - false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\",\r\n - \ \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \"25.33.80.0/20\"\r\n - \ ],\r\n \"nextHopType\": \"None\",\r\n \"nextHopIpAddress\": - [],\r\n \"destinationServiceTags\": [],\r\n \"tagMap\": {}\r\n },\r\n - \ {\r\n \"disableBgpRoutePropagation\": false,\r\n \"source\": - \"Default\",\r\n \"state\": \"Active\",\r\n \"hasBgpOverride\": - false,\r\n \"addressPrefix\": [\r\n \"25.41.3.0/25\"\r\n ],\r\n - \ \"nextHopType\": \"None\",\r\n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": - [],\r\n \"tagMap\": {}\r\n }\r\n ]\r\n}" + string: "{\r\n \"value\": [\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"10.0.0.0/16\"\r\n ],\r\n \"nextHopType\": \"VnetLocal\"\ + ,\r\n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\":\ + \ [],\r\n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"0.0.0.0/0\"\r\n ],\r\n \"nextHopType\": \"Internet\",\r\ + \n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"10.0.0.0/8\"\r\n ],\r\n \"nextHopType\": \"None\",\r\n\ + \ \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"100.64.0.0/10\"\r\n ],\r\n \"nextHopType\": \"None\",\r\ + \n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"192.168.0.0/16\"\r\n ],\r\n \"nextHopType\": \"None\",\r\ + \n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"25.33.80.0/20\"\r\n ],\r\n \"nextHopType\": \"None\",\r\ + \n \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n },\r\n {\r\n \"disableBgpRoutePropagation\"\ + : false,\r\n \"source\": \"Default\",\r\n \"state\": \"Active\"\ + ,\r\n \"hasBgpOverride\": false,\r\n \"addressPrefix\": [\r\n \ + \ \"25.41.3.0/25\"\r\n ],\r\n \"nextHopType\": \"None\",\r\n\ + \ \"nextHopIpAddress\": [],\r\n \"destinationServiceTags\": [],\r\ + \n \"tagMap\": {}\r\n }\r\n ]\r\n}" headers: cache-control: - no-cache @@ -1274,11 +1295,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:58:57 GMT + - Tue, 26 Jan 2021 08:46:50 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f13c36ba-59f8-4ad0-a0d2-764047b88272?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/14d633fa-e919-41c3-9021-7cd317435c57?api-version=2020-08-01 pragma: - no-cache server: @@ -1293,7 +1314,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 311ab446-48b1-46ef-8ca3-a5bbe17f8590 + - 90e1c92c-dfb3-47c6-9ce8-bd37ba38782f status: code: 200 message: OK @@ -1311,33 +1332,35 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\",\r\n - \ \"etag\": \"W/\\\"546175f2-013d-4b94-bd0f-8e793a3c26c2\\\"\",\r\n \"location\": - \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": - \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"d0bca5f8-9296-4fb9-8b08-62d82e91acef\",\r\n \"ipConfigurations\": - [\r\n {\r\n \"name\": \"myIpConfiguration\",\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\",\r\n - \ \"etag\": \"W/\\\"546175f2-013d-4b94-bd0f-8e793a3c26c2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\r\n - \ },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\": - \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n \"dnsServers\": - [],\r\n \"appliedDnsServers\": [],\r\n \"internalDomainNameSuffix\": - \"vdr5tjdusk5uphhreby0pcicwh.bx.internal.cloudapp.net\"\r\n },\r\n \"macAddress\": - \"00-0D-3A-99-10-C4\",\r\n \"enableAcceleratedNetworking\": true,\r\n \"enableIPForwarding\": - false,\r\n \"primary\": true,\r\n \"virtualMachine\": {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\r\n - \ },\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\n - \ \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\r\n}" + string: "{\r\n \"name\": \"myNetworkInterface\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface\"\ + ,\r\n \"etag\": \"W/\\\"b2cb8eeb-21cd-46b4-a3c2-e0dcd28057c3\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\ + \n \"tag2\": \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"6409a6ce-5825-419d-9325-f02010d3d63a\"\ + ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"myIpConfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface/ipConfigurations/myIpConfiguration\"\ + ,\r\n \"etag\": \"W/\\\"b2cb8eeb-21cd-46b4-a3c2-e0dcd28057c3\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n },\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork/subnets/subnet\"\ + \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ + \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ + internalDomainNameSuffix\": \"nkuyndzfmmse1eh5l2oie4cjvf.bx.internal.cloudapp.net\"\ + \r\n },\r\n \"macAddress\": \"00-0D-3A-14-79-63\",\r\n \"enableAcceleratedNetworking\"\ + : true,\r\n \"enableIPForwarding\": false,\r\n \"primary\": true,\r\n\ + \ \"virtualMachine\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine\"\ + \r\n },\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ + \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ + \r\n}" headers: azure-asyncnotification: - Enabled @@ -1348,7 +1371,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:59:02 GMT + - Tue, 26 Jan 2021 08:46:55 GMT expires: - '-1' pragma: @@ -1365,7 +1388,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6a52b180-8d51-4e19-8a72-e2675cb0e6b9 + - 4464d973-a596-4285-88b0-b4c2e5c7e520 x-ms-ratelimit-remaining-subscription-writes: - '1194' status: @@ -1383,8 +1406,8 @@ interactions: Content-Length: - '0' User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: DELETE @@ -1396,17 +1419,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d609222-1a77-409c-aa8a-f60c3d0810c4?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/20c74f00-2e14-4ad5-b288-4e9cdb03a126?api-version=2020-06-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:59:05 GMT + - Tue, 26 Jan 2021 08:46:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d609222-1a77-409c-aa8a-f60c3d0810c4?monitor=true&api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/20c74f00-2e14-4ad5-b288-4e9cdb03a126?monitor=true&api-version=2020-06-01 pragma: - no-cache server: @@ -1419,7 +1442,7 @@ interactions: x-ms-ratelimit-remaining-resource: - Microsoft.Compute/DeleteVM3Min;239,Microsoft.Compute/DeleteVM30Min;1199 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14998' status: code: 202 message: Accepted @@ -1433,23 +1456,24 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d609222-1a77-409c-aa8a-f60c3d0810c4?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/20c74f00-2e14-4ad5-b288-4e9cdb03a126?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:59:05.2353609+00:00\",\r\n \"status\": - \"InProgress\",\r\n \"name\": \"5d609222-1a77-409c-aa8a-f60c3d0810c4\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T08:46:58.557793+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"20c74f00-2e14-4ad5-b288-4e9cdb03a126\"\ + \r\n}" headers: cache-control: - no-cache content-length: - - '134' + - '133' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:59:15 GMT + - Tue, 26 Jan 2021 08:47:09 GMT expires: - '-1' pragma: @@ -1466,7 +1490,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14995,Microsoft.Compute/GetOperation30Min;29993 + - Microsoft.Compute/GetOperation3Min;14995,Microsoft.Compute/GetOperation30Min;29995 status: code: 200 message: OK @@ -1480,24 +1504,24 @@ interactions: Connection: - keep-alive User-Agent: - - python/3.7.3 (Windows-10-10.0.19041-SP0) msrest/0.6.19 msrest_azure/0.6.4 - azure-mgmt-compute/14.0.0 Azure-SDK-For-Python + - 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-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d609222-1a77-409c-aa8a-f60c3d0810c4?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/20c74f00-2e14-4ad5-b288-4e9cdb03a126?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-26T06:59:05.2353609+00:00\",\r\n \"endTime\": - \"2020-11-26T06:59:45.8137095+00:00\",\r\n \"status\": \"Succeeded\",\r\n - \ \"name\": \"5d609222-1a77-409c-aa8a-f60c3d0810c4\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T08:46:58.557793+00:00\",\r\n \"\ + endTime\": \"2021-01-26T08:47:29.3702828+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"20c74f00-2e14-4ad5-b288-4e9cdb03a126\"\r\n}" headers: cache-control: - no-cache content-length: - - '184' + - '183' content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:59:45 GMT + - Tue, 26 Jan 2021 08:47:39 GMT expires: - '-1' pragma: @@ -1514,7 +1538,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29992 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29993 status: code: 200 message: OK @@ -1530,9 +1554,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/myNetworkInterface?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/myNetworkInterface?api-version=2020-08-01 response: body: string: '' @@ -1540,17 +1564,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4303449e-441b-455a-83ba-02cd5edec875?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0c39b5de-e48c-4bb4-b694-c866ae0d38db?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Thu, 26 Nov 2020 06:59:47 GMT + - Tue, 26 Jan 2021 08:47:40 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/4303449e-441b-455a-83ba-02cd5edec875?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0c39b5de-e48c-4bb4-b694-c866ae0d38db?api-version=2020-08-01 pragma: - no-cache server: @@ -1561,9 +1585,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a4a48f2e-c9bf-49b3-97d2-2b1da3fbe8b2 + - 44086611-87cd-410d-9d71-bc4af78d2dfe x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14991' status: code: 202 message: Accepted @@ -1577,9 +1601,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/4303449e-441b-455a-83ba-02cd5edec875?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0c39b5de-e48c-4bb4-b694-c866ae0d38db?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1591,7 +1615,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 26 Nov 2020 06:59:57 GMT + - Tue, 26 Jan 2021 08:47:50 GMT expires: - '-1' pragma: @@ -1608,7 +1632,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c3818f89-72c3-4f26-a1f3-569d0de6866b + - 2eda19eb-71cf-43a7-a21d-30520ad8ebfb status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip.test_network.yaml index 81c26ee1607c..18f32867beed 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip.test_network.yaml @@ -14,21 +14,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ipGroups/myIpGroups?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\": - [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\",\r\n - \ \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"Updating\"\r\n - \ },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\",\r\n - \ \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\",\r\n - \ \"etag\": \"da7aa2fc-9ae3-42e0-ae89-92500dfc9e05\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\"\ + : [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\"\ + ,\r\n \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"\ + Updating\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\"\ + ,\r\n \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\"\ + ,\r\n \"etag\": \"5e791bd4-70f7-4de9-9eb0-4bd07fc52914\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/34e39a2f-e359-4660-958d-95506452b3ca?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/c7f8bc20-9e37-45e4-99aa-13accc9fe3f3?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -36,7 +36,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:32:35 GMT + - Tue, 26 Jan 2021 08:48:11 GMT expires: - '-1' pragma: @@ -48,7 +48,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1199' status: code: 201 message: Created @@ -62,9 +62,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/nfvOperations/34e39a2f-e359-4660-958d-95506452b3ca?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/nfvOperations/c7f8bc20-9e37-45e4-99aa-13accc9fe3f3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -76,7 +76,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:32:45 GMT + - Tue, 26 Jan 2021 08:48:22 GMT expires: - '-1' pragma: @@ -104,18 +104,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ipGroups/myIpGroups?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\": - [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\",\r\n - \ \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n - \ },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\",\r\n - \ \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\",\r\n - \ \"etag\": \"da7aa2fc-9ae3-42e0-ae89-92500dfc9e05\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\"\ + : [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\"\ + ,\r\n \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"\ + Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\"\ + ,\r\n \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\"\ + ,\r\n \"etag\": \"5e791bd4-70f7-4de9-9eb0-4bd07fc52914\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -124,7 +124,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:32:46 GMT + - Tue, 26 Jan 2021 08:48:22 GMT expires: - '-1' pragma: @@ -152,18 +152,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ipGroups/myIpGroups?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups?api-version=2020-08-01 response: body: - string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\": - [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\",\r\n - \ \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"Succeeded\"\r\n - \ },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\",\r\n - \ \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\",\r\n - \ \"etag\": \"da7aa2fc-9ae3-42e0-ae89-92500dfc9e05\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" + string: "{\r\n \"properties\": {\r\n \"firewalls\": [],\r\n \"firewallPolicies\"\ + : [],\r\n \"ipAddresses\": [\r\n \"13.64.39.16/32\",\r\n \"40.74.146.80/31\"\ + ,\r\n \"40.74.147.32/28\"\r\n ],\r\n \"provisioningState\": \"\ + Succeeded\"\r\n },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups\"\ + ,\r\n \"name\": \"myIpGroups\",\r\n \"type\": \"Microsoft.Network/IpGroups\"\ + ,\r\n \"etag\": \"5e791bd4-70f7-4de9-9eb0-4bd07fc52914\",\r\n \"location\"\ + : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -172,7 +172,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:32:46 GMT + - Tue, 26 Jan 2021 08:48:22 GMT expires: - '-1' pragma: @@ -202,9 +202,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ipGroups/myIpGroups?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ipGroups/myIpGroups?api-version=2020-08-01 response: body: string: '' @@ -214,7 +214,7 @@ interactions: content-length: - '0' date: - - Wed, 25 Nov 2020 10:32:49 GMT + - Tue, 26 Jan 2021 08:48:25 GMT expires: - '-1' pragma: diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip_addresses.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip_addresses.test_network.yaml index 5bd20aea395f..fa16470dd0be 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip_addresses.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_ip_addresses.test_network.yaml @@ -14,24 +14,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\",\r\n - \ \"etag\": \"W/\\\"af301676-742c-4594-9e08-3448fbfaec91\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"24e705d3-20a0-4f27-b4bb-dabf3b2e5332\",\r\n \"prefixLength\": 30,\r\n - \ \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipTags\": []\r\n },\r\n - \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"3cc8b2da-4f21-4998-a4a3-db67b6ca90f1\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"resourceGuid\": \"2187d88b-48dc-41f8-81a6-37f3d094722d\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/2928dd5c-98fb-4c71-ab93-603897eadb22?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/66e76931-13da-4284-90c8-18d7cb503a6c?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +39,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:02 GMT + - Tue, 26 Jan 2021 08:48:44 GMT expires: - '-1' pragma: @@ -52,9 +52,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a4b95c79-7d0f-4d8e-93c0-8853fe21ff57 + - 4d7fcc02-744c-4c87-9031-057a12497631 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1198' status: code: 201 message: Created @@ -68,9 +68,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/2928dd5c-98fb-4c71-ab93-603897eadb22?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/66e76931-13da-4284-90c8-18d7cb503a6c?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +82,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:05 GMT + - Tue, 26 Jan 2021 08:48:47 GMT expires: - '-1' pragma: @@ -99,7 +99,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bde39880-aa13-47de-a0a3-aa1fbe12451a + - 9857753b-44c7-4aa7-90b3-ac4ba4b81aba status: code: 200 message: OK @@ -113,30 +113,31 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\",\r\n - \ \"etag\": \"W/\\\"e230821f-38a6-4484-b3e4-924a206ca419\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"24e705d3-20a0-4f27-b4bb-dabf3b2e5332\",\r\n \"prefixLength\": 30,\r\n - \ \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipPrefix\": \"52.234.111.100/30\",\r\n - \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"9ead59c7-53b8-4aaa-a08f-a3ecccb9d898\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"2187d88b-48dc-41f8-81a6-37f3d094722d\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipPrefix\": \"138.91.141.80/30\",\r\n \"ipTags\": []\r\n },\r\n\ + \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '706' + - '705' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:05 GMT + - Tue, 26 Jan 2021 08:48:47 GMT etag: - - W/"e230821f-38a6-4484-b3e4-924a206ca419" + - W/"9ead59c7-53b8-4aaa-a08f-a3ecccb9d898" expires: - '-1' pragma: @@ -153,7 +154,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c5383b3c-f495-40d0-a33f-e920108abf1d + - e8c7da6b-c936-412e-bcc1-0d98d2d6933d status: code: 200 message: OK @@ -171,24 +172,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\",\r\n - \ \"etag\": \"W/\\\"34cd14d9-20b6-4a55-848f-474b925b33e7\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"resourceGuid\": \"dc21a2df-df70-47c6-a16f-e4ef0ff6edae\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"0197bc99-9cd4-45f1-b6f6-69668083be0a\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"resourceGuid\": \"3141f161-ec70-4089-8ae7-9de25d274f9d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8a2cc728-d61e-4832-b5d7-a727bcb5c92b?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6a7f859a-d81f-4aa5-ac58-16b6e8d148e8?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -196,7 +197,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:10 GMT + - Tue, 26 Jan 2021 08:48:51 GMT expires: - '-1' pragma: @@ -209,9 +210,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cc662aff-53c6-47b8-9917-36c8872e42db + - 49f7e181-75bb-4f7b-9dba-6e34c0efe247 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1197' status: code: 201 message: Created @@ -225,9 +226,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/8a2cc728-d61e-4832-b5d7-a727bcb5c92b?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6a7f859a-d81f-4aa5-ac58-16b6e8d148e8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -239,7 +240,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:12 GMT + - Tue, 26 Jan 2021 08:48:53 GMT expires: - '-1' pragma: @@ -256,7 +257,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d9c6e275-d43e-47e8-923e-c88fb033ac72 + - ac3a3fa3-697f-4aa5-87ae-81596b8a93a9 status: code: 200 message: OK @@ -270,19 +271,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\",\r\n - \ \"etag\": \"W/\\\"bafdf1af-bf87-414e-a9cb-b6ab7d5d30cf\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"dc21a2df-df70-47c6-a16f-e4ef0ff6edae\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"e36cac88-6a66-4c5c-a525-4fe14cbef1bb\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"3141f161-ec70-4089-8ae7-9de25d274f9d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -291,9 +292,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:12 GMT + - Tue, 26 Jan 2021 08:48:53 GMT etag: - - W/"bafdf1af-bf87-414e-a9cb-b6ab7d5d30cf" + - W/"e36cac88-6a66-4c5c-a525-4fe14cbef1bb" expires: - '-1' pragma: @@ -310,7 +311,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 388d29e8-6b77-4fdf-8eda-5da2671679b7 + - e56c7d3d-5441-474a-aa22-86ccc974f771 status: code: 200 message: OK @@ -324,19 +325,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\",\r\n - \ \"etag\": \"W/\\\"bafdf1af-bf87-414e-a9cb-b6ab7d5d30cf\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"dc21a2df-df70-47c6-a16f-e4ef0ff6edae\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"e36cac88-6a66-4c5c-a525-4fe14cbef1bb\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"3141f161-ec70-4089-8ae7-9de25d274f9d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -345,9 +346,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:12 GMT + - Tue, 26 Jan 2021 08:48:53 GMT etag: - - W/"bafdf1af-bf87-414e-a9cb-b6ab7d5d30cf" + - W/"e36cac88-6a66-4c5c-a525-4fe14cbef1bb" expires: - '-1' pragma: @@ -364,7 +365,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ca6983e8-cee0-44ac-b070-b010369174da + - b1c5313b-f8e0-44e8-9ce9-30973943bb2f status: code: 200 message: OK @@ -378,30 +379,31 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\",\r\n - \ \"etag\": \"W/\\\"e230821f-38a6-4484-b3e4-924a206ca419\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"westus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"24e705d3-20a0-4f27-b4bb-dabf3b2e5332\",\r\n \"prefixLength\": 30,\r\n - \ \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipPrefix\": \"52.234.111.100/30\",\r\n - \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"9ead59c7-53b8-4aaa-a08f-a3ecccb9d898\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + westus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"2187d88b-48dc-41f8-81a6-37f3d094722d\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipPrefix\": \"138.91.141.80/30\",\r\n \"ipTags\": []\r\n },\r\n\ + \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '706' + - '705' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:13 GMT + - Tue, 26 Jan 2021 08:48:54 GMT etag: - - W/"e230821f-38a6-4484-b3e4-924a206ca419" + - W/"9ead59c7-53b8-4aaa-a08f-a3ecccb9d898" expires: - '-1' pragma: @@ -418,7 +420,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7147c787-09dc-4f69-8ed3-f708f8dec28e + - 785b363e-f1b9-4157-a35e-34c64bc24d70 status: code: 200 message: OK @@ -436,20 +438,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\",\r\n - \ \"etag\": \"W/\\\"9e10fc0a-14fa-49f0-ac8c-f139df638c50\\\"\",\r\n \"location\": - \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": - \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"dc21a2df-df70-47c6-a16f-e4ef0ff6edae\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Dynamic\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddressd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"75be0b67-973b-4349-9740-551f9557fbb3\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\ + \n \"tag2\": \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"3141f161-ec70-4089-8ae7-9de25d274f9d\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Dynamic\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Basic\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -460,7 +462,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:15 GMT + - Tue, 26 Jan 2021 08:48:56 GMT expires: - '-1' pragma: @@ -477,9 +479,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 78934fc2-da90-451f-8cd3-c3caff08ae5f + - 05b2fd1d-317a-455c-92a9-d01717402ed4 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1196' status: code: 200 message: OK @@ -497,31 +499,32 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\",\r\n - \ \"etag\": \"W/\\\"e16721e6-c452-482f-b1b7-be976e59e9da\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"westus\",\r\n - \ \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n - \ },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"24e705d3-20a0-4f27-b4bb-dabf3b2e5332\",\r\n \"prefixLength\": - 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipPrefix\": \"52.234.111.100/30\",\r\n - \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipprefixd3db1381\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381\"\ + ,\r\n \"etag\": \"W/\\\"48317e63-070f-4526-9124-9f6e18c4e7e9\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + westus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"\ + value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"2187d88b-48dc-41f8-81a6-37f3d094722d\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipPrefix\": \"138.91.141.80/30\",\r\n \"ipTags\": []\r\n },\r\n\ + \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: azure-asyncnotification: - Enabled cache-control: - no-cache content-length: - - '770' + - '769' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:18 GMT + - Tue, 26 Jan 2021 08:48:58 GMT expires: - '-1' pragma: @@ -538,9 +541,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d1a70d3b-b73a-4209-b14a-7861cd6c9c4c + - 4a004d2d-5969-45ba-926c-5306bcbf5f70 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1195' status: code: 200 message: OK @@ -556,9 +559,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressd3db1381?api-version=2020-08-01 response: body: string: '' @@ -566,17 +569,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/53d454ac-7597-47ae-b4ea-5f866b3967fc?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6d5d9414-dbdf-4b63-bbf8-c4d46cce3829?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:33:19 GMT + - Tue, 26 Jan 2021 08:48:59 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/53d454ac-7597-47ae-b4ea-5f866b3967fc?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/6d5d9414-dbdf-4b63-bbf8-c4d46cce3829?api-version=2020-08-01 pragma: - no-cache server: @@ -587,7 +590,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 09f96c77-61ab-4d8a-aa2c-80c84dac2a18 + - 31cbb64d-6d41-4338-b6b5-81d3f4f3039d x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -603,9 +606,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/53d454ac-7597-47ae-b4ea-5f866b3967fc?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6d5d9414-dbdf-4b63-bbf8-c4d46cce3829?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -617,7 +620,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:29 GMT + - Tue, 26 Jan 2021 08:49:10 GMT expires: - '-1' pragma: @@ -634,7 +637,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f9453064-e577-4e47-bb64-808c3d05c3bb + - f256f558-6435-4ab4-a880-02d77c515a61 status: code: 200 message: OK @@ -650,9 +653,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefixd3db1381?api-version=2020-08-01 response: body: string: '' @@ -660,17 +663,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/9e3a0b8b-845a-4526-9802-e06a4b1ee8bf?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/ae68457f-02a2-4f82-a23e-0405fc40fe94?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:33:30 GMT + - Tue, 26 Jan 2021 08:49:10 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/9e3a0b8b-845a-4526-9802-e06a4b1ee8bf?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/ae68457f-02a2-4f82-a23e-0405fc40fe94?api-version=2020-08-01 pragma: - no-cache server: @@ -681,7 +684,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 57e1c3a8-927b-4f92-b5c5-964924f25cd0 + - 9f38f0d2-2548-4036-997b-6eb094936330 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -697,9 +700,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/9e3a0b8b-845a-4526-9802-e06a4b1ee8bf?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/ae68457f-02a2-4f82-a23e-0405fc40fe94?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -711,7 +714,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:40 GMT + - Tue, 26 Jan 2021 08:49:21 GMT expires: - '-1' pragma: @@ -728,7 +731,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c5a5671f-2981-4d5a-9f44-a7a967c61006 + - e76db243-c871-4b94-9560-047b78347d58 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_load_balancer.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_load_balancer.test_network.yaml index 662b9cb9f897..4e8324e21ac3 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_load_balancer.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_load_balancer.test_network.yaml @@ -14,24 +14,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/public_ip_address_name?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"public_ip_address_name\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\",\r\n - \ \"etag\": \"W/\\\"fc561e07-d2a4-418c-a495-3c6df2ebc3e2\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"resourceGuid\": \"c51158bc-2dd5-4235-bf45-28a959c8b3c2\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\": - 10,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"public_ip_address_name\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + ,\r\n \"etag\": \"W/\\\"a9883ba6-80a0-4769-b084-bdc64a0e4403\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"resourceGuid\": \"a579a749-89f3-4860-9983-e186fc24ac58\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Static\",\r\n \"idleTimeoutInMinutes\": 10,\r\n \"ipTags\": []\r\ + \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n\ + }" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/2726aeb9-0851-4103-98c3-efec4b837ed3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d7bdd1d8-d434-4881-ae1b-7d2a8ce6f311?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:54 GMT + - Tue, 26 Jan 2021 08:49:38 GMT expires: - '-1' pragma: @@ -52,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f1aa4c32-c26f-47b9-97a2-986dc6844338 + - 8bafa613-3877-48a9-951d-20760b948839 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1194' status: code: 201 message: Created @@ -68,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/2726aeb9-0851-4103-98c3-efec4b837ed3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d7bdd1d8-d434-4881-ae1b-7d2a8ce6f311?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:56 GMT + - Tue, 26 Jan 2021 08:49:39 GMT expires: - '-1' pragma: @@ -99,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7d6b441c-ee46-4cc8-8d32-b1bb872c100e + - 53170c8b-9ee7-48a5-b3e0-3b89a39c7d9e status: code: 200 message: OK @@ -113,30 +114,31 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/public_ip_address_name?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"public_ip_address_name\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\",\r\n - \ \"etag\": \"W/\\\"02dc2183-ec40-4b9b-9f29-085a78abb8ef\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"c51158bc-2dd5-4235-bf45-28a959c8b3c2\",\r\n \"ipAddress\": - \"52.151.213.157\",\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\": - \"Static\",\r\n \"idleTimeoutInMinutes\": 10,\r\n \"ipTags\": []\r\n - \ },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\": - {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"public_ip_address_name\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + ,\r\n \"etag\": \"W/\\\"0ae5239c-65eb-438d-a1f0-eb908f01f34a\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"a579a749-89f3-4860-9983-e186fc24ac58\"\ + ,\r\n \"ipAddress\": \"13.92.41.25\",\r\n \"publicIPAddressVersion\"\ + : \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\"\ + : 10,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\"\ + ,\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '757' + - '754' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:33:56 GMT + - Tue, 26 Jan 2021 08:49:39 GMT etag: - - W/"02dc2183-ec40-4b9b-9f29-085a78abb8ef" + - W/"0ae5239c-65eb-438d-a1f0-eb908f01f34a" expires: - '-1' pragma: @@ -153,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b617c8a5-cb3e-452e-ab99-96854472e314 + - 961f153c-a7f4-45c6-bf8a-6820c0e91628 status: code: 200 message: OK @@ -186,76 +188,79 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"83e911d4-ec43-41a1-ab92-2d743ce4baa4\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\r\n - \ },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n - \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [\r\n {\r\n - \ \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \"name\": - \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 80,\r\n \"backendPort\": - 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\": - 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\": - true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n {\r\n - \ \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \"requestPath\": - \"healthcheck.aspx\",\r\n \"intervalInSeconds\": 15,\r\n \"numberOfProbes\": - 2,\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\": - 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"frontendIPConfigurations\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ }\r\n ]\r\n }\r\n }\r\n ],\r\n \"inboundNatPools\": - []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": - \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"45238cce-a499-4827-ba96-25f555569f49\",\r\n \"\ + frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + \r\n },\r\n \"loadBalancingRules\": [\r\n {\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ],\r\n \"outboundRules\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"backendAddressPools\"\ + : [\r\n {\r\n \"name\": \"myBackendAddressPool\",\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\ + \n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \ + \ \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 80,\r\n \"backendPort\"\ + : 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\"\ + : 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\"\ + : true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n\ + \ {\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \ + \ \"requestPath\": \"healthcheck.aspx\",\r\n \"intervalInSeconds\"\ + : 15,\r\n \"numberOfProbes\": 2,\r\n \"loadBalancingRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"name\": \"myOutboundRule\",\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"allocatedOutboundPorts\": 1024,\r\n \"protocol\"\ + : \"All\",\r\n \"enableTcpReset\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"frontendIPConfigurations\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n }\r\n ]\r\n }\r\n }\r\n ],\r\n \ + \ \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0dc842f5-8254-48da-b0c1-60324d93e5f0?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/04d98285-10f1-441b-a1be-578d8a8da8f3?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -263,7 +268,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:34:00 GMT + - Tue, 26 Jan 2021 08:49:44 GMT expires: - '-1' pragma: @@ -276,9 +281,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4e588f3b-5310-4b31-b847-f226fb309772 + - b6c51a42-2a8a-4e2f-9521-a5fd6799bad0 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1193' status: code: 201 message: Created @@ -292,9 +297,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0dc842f5-8254-48da-b0c1-60324d93e5f0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/04d98285-10f1-441b-a1be-578d8a8da8f3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -306,7 +311,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:34:30 GMT + - Tue, 26 Jan 2021 08:50:14 GMT expires: - '-1' pragma: @@ -323,7 +328,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0000be3f-eaa0-4fb4-895a-ddf503e7a4b5 + - b8730d6e-caed-4d44-93fb-99e5fd845886 status: code: 200 message: OK @@ -337,82 +342,86 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"83e911d4-ec43-41a1-ab92-2d743ce4baa4\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\r\n - \ },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n - \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [\r\n {\r\n - \ \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \"name\": - \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 80,\r\n \"backendPort\": - 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\": - 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\": - true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n {\r\n - \ \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \"requestPath\": - \"healthcheck.aspx\",\r\n \"intervalInSeconds\": 15,\r\n \"numberOfProbes\": - 2,\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\",\r\n - \ \"etag\": \"W/\\\"d3ab9bf3-ef10-45fb-8209-363aa9f53add\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\": - 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"frontendIPConfigurations\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ }\r\n ]\r\n }\r\n }\r\n ],\r\n \"inboundNatPools\": - []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": - \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"45238cce-a499-4827-ba96-25f555569f49\",\r\n \"\ + frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + \r\n },\r\n \"loadBalancingRules\": [\r\n {\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ],\r\n \"outboundRules\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n },\r\n \"zones\": [\r\n \"1\",\r\n \ + \ \"2\",\r\n \"3\"\r\n ]\r\n }\r\n ],\r\n\ + \ \"backendAddressPools\": [\r\n {\r\n \"name\": \"myBackendAddressPool\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\ + \n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \ + \ \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 80,\r\n \"backendPort\"\ + : 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\"\ + : 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\"\ + : true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n\ + \ {\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \ + \ \"requestPath\": \"healthcheck.aspx\",\r\n \"intervalInSeconds\"\ + : 15,\r\n \"numberOfProbes\": 2,\r\n \"loadBalancingRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"name\": \"myOutboundRule\",\r\n \"id\"\ + : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + ,\r\n \"etag\": \"W/\\\"4cce7e0b-d333-40cb-bca9-60abeaab72c4\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"allocatedOutboundPorts\": 1024,\r\n \"protocol\"\ + : \"All\",\r\n \"enableTcpReset\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"frontendIPConfigurations\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n }\r\n ]\r\n }\r\n }\r\n ],\r\n \ + \ \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '7776' + - '7855' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:34:31 GMT + - Tue, 26 Jan 2021 08:50:15 GMT etag: - - W/"d3ab9bf3-ef10-45fb-8209-363aa9f53add" + - W/"4cce7e0b-d333-40cb-bca9-60abeaab72c4" expires: - '-1' pragma: @@ -429,7 +438,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 999a7499-20d4-40b4-8029-795af5ed0a4a + - a9b758ca-46fa-4ed3-a549-2943640f62bf status: code: 200 message: OK @@ -449,23 +458,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n \"enableFloatingIP\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"protocol\": \"Tcp\",\r\n - \ \"enableDestinationServiceEndpoint\": false,\r\n \"enableTcpReset\": - false,\r\n \"allowBackendPortConflict\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n\ + \ \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\": 4,\r\n\ + \ \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": false,\r\ + \n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": false\r\ + \n }\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/76a6ddc0-462f-4679-8347-5db1d44fceb9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37631bb0-9945-4b36-a8b0-458bfb25b298?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -473,7 +483,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:34:31 GMT + - Tue, 26 Jan 2021 08:50:15 GMT expires: - '-1' pragma: @@ -486,9 +496,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4dd0ef8b-d2e2-482e-986d-9e6ab98b3b33 + - 22ad885b-ca29-4565-9e89-4118ceafbfa2 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1192' status: code: 201 message: Created @@ -502,9 +512,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/76a6ddc0-462f-4679-8347-5db1d44fceb9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37631bb0-9945-4b36-a8b0-458bfb25b298?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -516,7 +526,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:01 GMT + - Tue, 26 Jan 2021 08:50:45 GMT expires: - '-1' pragma: @@ -533,7 +543,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d36aa005-3213-4642-a8fe-c64d384017fd + - 54ce76d9-9fd7-4e49-b840-27d517ce69ae status: code: 200 message: OK @@ -547,20 +557,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n \"enableFloatingIP\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"protocol\": \"Tcp\",\r\n - \ \"enableDestinationServiceEndpoint\": false,\r\n \"enableTcpReset\": - false,\r\n \"allowBackendPortConflict\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n\ + \ \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\": 4,\r\n\ + \ \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": false,\r\ + \n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": false\r\ + \n }\r\n}" headers: cache-control: - no-cache @@ -569,9 +580,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:02 GMT + - Tue, 26 Jan 2021 08:50:46 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -588,7 +599,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1b3b66ac-66c1-49f5-b74d-c9944b63e308 + - dbfc2d8b-1a3f-4c99-ab46-c1a536025cd9 status: code: 200 message: OK @@ -602,22 +613,25 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myFrontendIpconfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"privateIPAllocationMethod\": - \"Dynamic\",\r\n \"publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\r\n - \ },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\r\n - \ }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myFrontendIpconfiguration\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \ + \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\":\ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + \r\n },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\":\ + \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + \r\n }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n }\r\ + \n}" headers: cache-control: - no-cache @@ -626,9 +640,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:02 GMT + - Tue, 26 Jan 2021 08:50:46 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -645,7 +659,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 01f43528-3e8c-4e0b-a6dd-63c31fd5e431 + - 7921789c-ca4f-424b-bd4e-660110bf3bb8 status: code: 200 message: OK @@ -659,18 +673,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"loadBalancerBackendAddresses\": - [],\r\n \"outboundRules\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\r\n}" + string: "{\r\n \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + loadBalancerBackendAddresses\": [],\r\n \"outboundRules\": [\r\n {\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\ + \r\n}" headers: cache-control: - no-cache @@ -679,9 +695,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:02 GMT + - Tue, 26 Jan 2021 08:50:46 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -698,7 +714,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9e116f86-c03a-4fd0-94a9-add013cc05b3 + - da040c0c-3a51-4a5a-a06f-1fa2dfb0c420 status: code: 200 message: OK @@ -712,24 +728,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 80,\r\n \"backendPort\": 80,\r\n \"enableFloatingIP\": - true,\r\n \"idleTimeoutInMinutes\": 15,\r\n \"protocol\": \"Tcp\",\r\n - \ \"enableDestinationServiceEndpoint\": false,\r\n \"enableTcpReset\": - false,\r\n \"allowBackendPortConflict\": false,\r\n \"loadDistribution\": - \"Default\",\r\n \"disableOutboundSnat\": true,\r\n \"backendAddressPool\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\r\n - \ }\r\n }\r\n}" + string: "{\r\n \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n \"\ + properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 80,\r\n \"backendPort\": 80,\r\n \ + \ \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\": 15,\r\n \ + \ \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": false,\r\ + \n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": false,\r\ + \n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\": true,\r\ + \n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + \r\n }\r\n }\r\n}" headers: cache-control: - no-cache @@ -738,9 +754,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:03 GMT + - Tue, 26 Jan 2021 08:50:47 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -757,7 +773,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 109f989a-e57c-4867-95cb-57e1200b8808 + - fc2f22b0-4ae1-454d-9a34-a3702c2a3781 status: code: 200 message: OK @@ -771,20 +787,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n \"enableFloatingIP\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"protocol\": \"Tcp\",\r\n - \ \"enableDestinationServiceEndpoint\": false,\r\n \"enableTcpReset\": - false,\r\n \"allowBackendPortConflict\": false\r\n }\r\n}" + string: "{\r\n \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"frontendIPConfiguration\"\ + : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": 3389,\r\n\ + \ \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\": 4,\r\n\ + \ \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": false,\r\ + \n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": false\r\ + \n }\r\n}" headers: cache-control: - no-cache @@ -793,9 +810,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:04 GMT + - Tue, 26 Jan 2021 08:50:47 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -812,7 +829,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - aa1fb4e4-e879-46d6-a7b5-8bf3fb62fd4e + - df3fe233-f139-4231-a8c4-b5cc7f7a88ad status: code: 200 message: OK @@ -826,21 +843,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\": {\r\n - \ \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\": - 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": false,\r\n - \ \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"frontendIPConfigurations\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\"\ + : 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": false,\r\n\ + \ \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"frontendIPConfigurations\": [\r\n {\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -849,9 +866,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:04 GMT + - Tue, 26 Jan 2021 08:50:47 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -868,7 +885,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1f77060b-e3b9-437d-80b8-d29b1c23d200 + - c11df1a6-f23f-49f9-9731-e2a15f7903d6 status: code: 200 message: OK @@ -882,18 +899,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/probes/myProbe?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"protocol\": \"Http\",\r\n - \ \"port\": 80,\r\n \"requestPath\": \"healthcheck.aspx\",\r\n \"intervalInSeconds\": - 15,\r\n \"numberOfProbes\": 2,\r\n \"loadBalancingRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\r\n}" + string: "{\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + protocol\": \"Http\",\r\n \"port\": 80,\r\n \"requestPath\": \"healthcheck.aspx\"\ + ,\r\n \"intervalInSeconds\": 15,\r\n \"numberOfProbes\": 2,\r\n \"\ + loadBalancingRules\": [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\ + \r\n}" headers: cache-control: - no-cache @@ -902,9 +920,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:05 GMT + - Tue, 26 Jan 2021 08:50:48 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -921,7 +939,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 48dd93a5-95e2-44ac-839a-3c7533f34f63 + - 2b9cb010-9175-449f-8366-f445891cffdb status: code: 200 message: OK @@ -935,94 +953,97 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"83e911d4-ec43-41a1-ab92-2d743ce4baa4\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\r\n - \ },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\r\n - \ }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n - \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [\r\n {\r\n - \ \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \"name\": - \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 80,\r\n \"backendPort\": - 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\": - 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\": - true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n {\r\n - \ \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \"requestPath\": - \"healthcheck.aspx\",\r\n \"intervalInSeconds\": 15,\r\n \"numberOfProbes\": - 2,\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \"name\": - \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": - 3389,\r\n \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false\r\n }\r\n }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\",\r\n - \ \"etag\": \"W/\\\"29d8233a-295c-4a1f-802a-367f63f28db2\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\": - 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"frontendIPConfigurations\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ }\r\n ]\r\n }\r\n }\r\n ],\r\n \"inboundNatPools\": - []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": - \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"45238cce-a499-4827-ba96-25f555569f49\",\r\n \"\ + frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + \r\n },\r\n \"loadBalancingRules\": [\r\n {\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [\r\n\ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + \r\n }\r\n ],\r\n \"outboundRules\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n },\r\n \"zones\": [\r\n \"1\",\r\n \ + \ \"2\",\r\n \"3\"\r\n ]\r\n }\r\n ],\r\n\ + \ \"backendAddressPools\": [\r\n {\r\n \"name\": \"myBackendAddressPool\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\ + \n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \ + \ \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 80,\r\n \"backendPort\"\ + : 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\"\ + : 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\"\ + : true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n\ + \ {\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \ + \ \"requestPath\": \"healthcheck.aspx\",\r\n \"intervalInSeconds\"\ + : 15,\r\n \"numberOfProbes\": 2,\r\n \"loadBalancingRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \ + \ \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 3390,\r\n \"backendPort\"\ + : 3389,\r\n \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false\r\n }\r\n }\r\n ],\r\n \"outboundRules\": [\r\n\ + \ {\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + ,\r\n \"etag\": \"W/\\\"8414ad4d-e47e-466b-87eb-3050d553e03f\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"allocatedOutboundPorts\": 1024,\r\n \"protocol\"\ + : \"All\",\r\n \"enableTcpReset\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"frontendIPConfigurations\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n }\r\n ]\r\n }\r\n }\r\n ],\r\n \ + \ \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '9264' + - '9343' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:05 GMT + - Tue, 26 Jan 2021 08:50:48 GMT etag: - - W/"29d8233a-295c-4a1f-802a-367f63f28db2" + - W/"8414ad4d-e47e-466b-87eb-3050d553e03f" expires: - '-1' pragma: @@ -1039,7 +1060,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9aaa25b7-e98f-44fe-aa3c-d93dd4d2c0ae + - 2ea72f8b-ff5a-4652-a4bb-59ffa822d07f status: code: 200 message: OK @@ -1057,84 +1078,86 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n \"type\": - \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"83e911d4-ec43-41a1-ab92-2d743ce4baa4\",\r\n - \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"publicIPAddress\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\r\n - \ },\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\r\n - \ }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"privateIPAddressVersion\": \"IPv4\"\r\n - \ }\r\n }\r\n ],\r\n \"backendAddressPools\": [\r\n {\r\n - \ \"name\": \"myBackendAddressPool\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\": - [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\r\n - \ }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \"name\": - \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 80,\r\n \"backendPort\": - 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\": - 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\": - true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\r\n - \ }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n {\r\n - \ \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \"requestPath\": - \"healthcheck.aspx\",\r\n \"intervalInSeconds\": 15,\r\n \"numberOfProbes\": - 2,\r\n \"loadBalancingRules\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\r\n - \ }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\r\n - \ }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \"name\": - \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ },\r\n \"frontendPort\": 3390,\r\n \"backendPort\": - 3389,\r\n \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\": - false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\": - false\r\n }\r\n }\r\n ],\r\n \"outboundRules\": [\r\n {\r\n - \ \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\",\r\n - \ \"etag\": \"W/\\\"5454bb66-1097-4c4c-9baf-92fe912c3bf8\\\"\",\r\n - \ \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"allocatedOutboundPorts\": - 1024,\r\n \"protocol\": \"All\",\r\n \"enableTcpReset\": - false,\r\n \"idleTimeoutInMinutes\": 4,\r\n \"backendAddressPool\": - {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\r\n - \ },\r\n \"frontendIPConfigurations\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\r\n - \ }\r\n ]\r\n }\r\n }\r\n ],\r\n \"inboundNatPools\": - []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": - \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myLoadBalancer\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/loadBalancers\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"45238cce-a499-4827-ba96-25f555569f49\",\r\n \ + \ \"frontendIPConfigurations\": [\r\n {\r\n \"name\": \"myFrontendIpconfiguration\"\ + ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/frontendIPConfigurations\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ + publicIPAddress\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/public_ip_address_name\"\ + \r\n },\r\n \"loadBalancingRules\": [\r\n {\r\ + \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [\r\n\ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + \r\n }\r\n ],\r\n \"outboundRules\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"privateIPAddressVersion\"\ + : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"backendAddressPools\"\ + : [\r\n {\r\n \"name\": \"myBackendAddressPool\",\r\n \"\ + id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"loadBalancerBackendAddresses\": [],\r\n \"outboundRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\ + \n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/backendAddressPools\"\ + \r\n }\r\n ],\r\n \"loadBalancingRules\": [\r\n {\r\n \ + \ \"name\": \"myLoadBalancingRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/loadBalancingRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 80,\r\n \"backendPort\"\ + : 80,\r\n \"enableFloatingIP\": true,\r\n \"idleTimeoutInMinutes\"\ + : 15,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false,\r\n \"loadDistribution\": \"Default\",\r\n \"disableOutboundSnat\"\ + : true,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"probe\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + \r\n }\r\n }\r\n }\r\n ],\r\n \"probes\": [\r\n\ + \ {\r\n \"name\": \"myProbe\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/probes/myProbe\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"protocol\": \"Http\",\r\n \"port\": 80,\r\n \ + \ \"requestPath\": \"healthcheck.aspx\",\r\n \"intervalInSeconds\"\ + : 15,\r\n \"numberOfProbes\": 2,\r\n \"loadBalancingRules\"\ + : [\r\n {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/loadBalancingRules/myLoadBalancingRule\"\ + \r\n }\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/loadBalancers/probes\"\ + \r\n }\r\n ],\r\n \"inboundNatRules\": [\r\n {\r\n \ + \ \"name\": \"myInboundNatRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/inboundNatRules\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"frontendIPConfiguration\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n },\r\n \"frontendPort\": 3390,\r\n \"backendPort\"\ + : 3389,\r\n \"enableFloatingIP\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"protocol\": \"Tcp\",\r\n \"enableDestinationServiceEndpoint\"\ + : false,\r\n \"enableTcpReset\": false,\r\n \"allowBackendPortConflict\"\ + : false\r\n }\r\n }\r\n ],\r\n \"outboundRules\": [\r\n\ + \ {\r\n \"name\": \"myOutboundRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/outboundRules/myOutboundRule\"\ + ,\r\n \"etag\": \"W/\\\"9265bccb-1283-4b18-b499-fa54ad0db69e\\\"\"\ + ,\r\n \"type\": \"Microsoft.Network/loadBalancers/outboundRules\",\r\ + \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"allocatedOutboundPorts\": 1024,\r\n \"protocol\"\ + : \"All\",\r\n \"enableTcpReset\": false,\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"backendAddressPool\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/backendAddressPools/myBackendAddressPool\"\ + \r\n },\r\n \"frontendIPConfigurations\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/frontendIPConfigurations/myFrontendIpconfiguration\"\ + \r\n }\r\n ]\r\n }\r\n }\r\n ],\r\n \ + \ \"inboundNatPools\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -1145,7 +1168,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:10 GMT + - Tue, 26 Jan 2021 08:50:53 GMT expires: - '-1' pragma: @@ -1162,9 +1185,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 058c816f-2613-481f-83b7-cc7ea27f1503 + - a6cda0eb-7409-400d-b5ca-d93689310196 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1191' status: code: 200 message: OK @@ -1180,25 +1203,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer/inboundNatRules/myInboundNatRule?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f4a64fe6-cbcb-44de-b518-62a76d144fad?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b32a582a-9218-4e8b-b83f-c3f8468375f6?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:35:10 GMT + - Tue, 26 Jan 2021 08:50:53 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f4a64fe6-cbcb-44de-b518-62a76d144fad?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b32a582a-9218-4e8b-b83f-c3f8468375f6?api-version=2020-08-01 pragma: - no-cache server: @@ -1209,9 +1232,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3080ec99-3fce-4f93-a5f5-3c85ae633a74 + - 23ac6a1a-86cb-480e-af7e-242883c3aa2b x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14995' status: code: 202 message: Accepted @@ -1225,9 +1248,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f4a64fe6-cbcb-44de-b518-62a76d144fad?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b32a582a-9218-4e8b-b83f-c3f8468375f6?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1239,7 +1262,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:21 GMT + - Tue, 26 Jan 2021 08:51:03 GMT expires: - '-1' pragma: @@ -1256,7 +1279,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c0738ff1-314b-462c-9b72-f87870c28fdd + - c67fdc3a-19ad-4951-89cc-c69e8600fdfe status: code: 200 message: OK @@ -1272,9 +1295,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/loadBalancers/myLoadBalancer?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/loadBalancers/myLoadBalancer?api-version=2020-08-01 response: body: string: '' @@ -1282,17 +1305,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/7028372b-a7d4-4ae5-90c1-6e2b70e53b13?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a66e0482-14b1-4a30-b6e8-9ae54ab535be?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:35:22 GMT + - Tue, 26 Jan 2021 08:51:04 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/7028372b-a7d4-4ae5-90c1-6e2b70e53b13?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/a66e0482-14b1-4a30-b6e8-9ae54ab535be?api-version=2020-08-01 pragma: - no-cache server: @@ -1303,9 +1326,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bfda6bd9-7e54-40e8-bf85-49b2dea0bb22 + - e86f2577-0241-4764-9be1-a0705960394c x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14994' status: code: 202 message: Accepted @@ -1319,9 +1342,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/7028372b-a7d4-4ae5-90c1-6e2b70e53b13?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a66e0482-14b1-4a30-b6e8-9ae54ab535be?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1333,7 +1356,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:32 GMT + - Tue, 26 Jan 2021 08:51:15 GMT expires: - '-1' pragma: @@ -1350,7 +1373,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8c4d9b1f-81c6-4385-aad3-46800c09a6fa + - f5fbf37d-37ea-4f7d-8c6a-ffdaf5078e8b status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_nat.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_nat.test_network.yaml index b52976e604d3..d27d96362dfa 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_nat.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_nat.test_network.yaml @@ -14,24 +14,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\",\r\n - \ \"etag\": \"W/\\\"c7260d68-1a85-40cf-9672-a578d2776488\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n - \ \"resourceGuid\": \"e1ca6d1c-11d2-49bc-a491-095dbbe98ec1\",\r\n \"publicIPAddressVersion\": - \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\": - 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n - \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + ,\r\n \"etag\": \"W/\\\"af74c4e4-d279-4a9f-b07c-87c2ef03d3ee\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"resourceGuid\": \"4cf7b036-8630-4f07-87ae-37c0d9dd8c1b\"\ + ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ + : \"Static\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\n\ + \ },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ + : {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n\ + }" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a041d851-9235-4eb0-a33f-2de063165c5d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4edb9175-8ba2-4651-b7d5-b0bf158993b3?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -39,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:45 GMT + - Tue, 26 Jan 2021 08:51:36 GMT expires: - '-1' pragma: @@ -52,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6f2b3a6c-c9c6-4de2-8754-d3ade7f2dc9d + - fbf29d70-574d-4ffb-a1bc-ef464739cbe1 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -68,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a041d851-9235-4eb0-a33f-2de063165c5d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4edb9175-8ba2-4651-b7d5-b0bf158993b3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -82,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:47 GMT + - Tue, 26 Jan 2021 08:51:37 GMT expires: - '-1' pragma: @@ -99,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c6a2bad2-d9f5-4a2c-95d3-79cbdfb7102b + - 3b350431-6242-4391-a4bc-db464534cbed status: code: 200 message: OK @@ -113,19 +114,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\",\r\n - \ \"etag\": \"W/\\\"55e10e60-a357-45de-b64d-93ea7bd2a9ce\\\"\",\r\n \"location\": - \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"resourceGuid\": \"e1ca6d1c-11d2-49bc-a491-095dbbe98ec1\",\r\n \"ipAddress\": - \"52.151.213.234\",\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\": - \"Static\",\r\n \"idleTimeoutInMinutes\": 4,\r\n \"ipTags\": []\r\n - \ },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\": - {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipaddress\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + ,\r\n \"etag\": \"W/\\\"c97b0ec9-9c1f-46cb-8c63-e5b475aa7a2b\\\"\",\r\n \ + \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"4cf7b036-8630-4f07-87ae-37c0d9dd8c1b\"\ + ,\r\n \"ipAddress\": \"52.255.177.141\",\r\n \"publicIPAddressVersion\"\ + : \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\"\ + : 4,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\"\ + ,\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache @@ -134,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:47 GMT + - Tue, 26 Jan 2021 08:51:37 GMT etag: - - W/"55e10e60-a357-45de-b64d-93ea7bd2a9ce" + - W/"c97b0ec9-9c1f-46cb-8c63-e5b475aa7a2b" expires: - '-1' pragma: @@ -153,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cb5ae85d-51ad-42a6-8fc1-f2a0e2240d8e + - 7f1fe3bd-711c-40a9-873d-e1c641be3c94 status: code: 200 message: OK @@ -172,24 +174,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefix?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefix\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\",\r\n - \ \"etag\": \"W/\\\"cccca067-3f61-4e0c-9c45-a220b20883e4\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": - \"13cf83ba-f6df-4244-93fc-9bd493a0a4f9\",\r\n \"prefixLength\": 30,\r\n - \ \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipTags\": []\r\n },\r\n - \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\r\n - \ }\r\n}" + string: "{\r\n \"name\": \"publicipprefix\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + ,\r\n \"etag\": \"W/\\\"008c6a89-74c5-488b-a7b6-0c53b573bb99\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ + ,\r\n \"resourceGuid\": \"4cf1c801-7aba-4dd9-959f-f409bed3b6c9\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/6ce679b2-1b91-4bf5-af01-73101cae0d4e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c2e6250b-fc63-4bb7-8ba6-d7cac8c2a6bd?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -197,7 +199,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:51 GMT + - Tue, 26 Jan 2021 08:51:41 GMT expires: - '-1' pragma: @@ -210,9 +212,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 73eb5fb7-dee4-4f7c-9e3d-f705c11b5752 + - c251a2f5-b569-4752-92ff-6164656399b1 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: code: 201 message: Created @@ -226,9 +228,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/6ce679b2-1b91-4bf5-af01-73101cae0d4e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c2e6250b-fc63-4bb7-8ba6-d7cac8c2a6bd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -240,7 +242,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:55 GMT + - Tue, 26 Jan 2021 08:51:44 GMT expires: - '-1' pragma: @@ -257,7 +259,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d462add5-3e00-476a-96cb-53064c322762 + - 70778cef-83dc-4837-ad24-925e8feb8d3c status: code: 200 message: OK @@ -271,30 +273,31 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPPrefixes/publicipprefix?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"publicipprefix\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\",\r\n - \ \"etag\": \"W/\\\"80c94c88-b136-4f26-80f5-dd288f8cd302\\\"\",\r\n \"type\": - \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"eastus\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": - \"13cf83ba-f6df-4244-93fc-9bd493a0a4f9\",\r\n \"prefixLength\": 30,\r\n - \ \"publicIPAddressVersion\": \"IPv4\",\r\n \"ipPrefix\": \"52.151.213.248/30\",\r\n - \ \"ipTags\": []\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"publicipprefix\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + ,\r\n \"etag\": \"W/\\\"820a4fd2-da5e-4197-89b9-0d714ffd3ef6\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/publicIPPrefixes\",\r\n \"location\": \"\ + eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"4cf1c801-7aba-4dd9-959f-f409bed3b6c9\",\r\n \ + \ \"prefixLength\": 30,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n\ + \ \"ipPrefix\": \"40.87.28.120/30\",\r\n \"ipTags\": []\r\n },\r\n\ + \ \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ + \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '690' + - '688' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:55 GMT + - Tue, 26 Jan 2021 08:51:44 GMT etag: - - W/"80c94c88-b136-4f26-80f5-dd288f8cd302" + - W/"820a4fd2-da5e-4197-89b9-0d714ffd3ef6" expires: - '-1' pragma: @@ -311,7 +314,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9f1b935c-7b21-4328-a8d5-d90e1459f4a9 + - 54a855a8-4497-4d6e-b1b2-29dcb8abe70c status: code: 200 message: OK @@ -331,26 +334,27 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/natGateways/myNatGateway?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\",\r\n - \ \"etag\": \"W/\\\"5636bf92-04c8-41c9-870b-d3f5e99616bf\\\"\",\r\n \"type\": - \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": \"7cf62853-c555-4fb1-8900-4e0c0b90a198\",\r\n - \ \"idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\r\n - \ }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\"\ + ,\r\n \"etag\": \"W/\\\"6e31efa4-6f2c-485a-ba25-0d3537fde285\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"d4a3ee26-c77f-4bf7-be11-54841af5f934\",\r\n \"\ + idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n\ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + \r\n }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a10165a7-4f52-406a-abd4-8cc885da444d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/dc00c351-28f3-48ec-9cfc-903ba2e7617f?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -358,7 +362,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:35:59 GMT + - Tue, 26 Jan 2021 08:51:48 GMT expires: - '-1' pragma: @@ -371,9 +375,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6a8b3094-e39c-45b1-aecd-3a149c90f7fc + - f01e0042-4ba4-4e7d-990a-234efd61d98c x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1196' status: code: 201 message: Created @@ -387,9 +391,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a10165a7-4f52-406a-abd4-8cc885da444d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/dc00c351-28f3-48ec-9cfc-903ba2e7617f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -401,7 +405,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:10 GMT + - Tue, 26 Jan 2021 08:51:58 GMT expires: - '-1' pragma: @@ -418,7 +422,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4a159e21-ce1a-4f4d-94be-d92c1a765fa2 + - 7b3fddba-5897-4250-b2f5-cb0fe1634cb6 status: code: 200 message: OK @@ -432,21 +436,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/natGateways/myNatGateway?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\",\r\n - \ \"etag\": \"W/\\\"eef35e97-c787-499a-89fd-e8b8b44208c6\\\"\",\r\n \"type\": - \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"7cf62853-c555-4fb1-8900-4e0c0b90a198\",\r\n - \ \"idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\r\n - \ }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\"\ + ,\r\n \"etag\": \"W/\\\"e0972916-fbd0-4420-827c-b1820579a7e5\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"d4a3ee26-c77f-4bf7-be11-54841af5f934\",\r\n \"\ + idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n\ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + \r\n }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -455,9 +460,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:10 GMT + - Tue, 26 Jan 2021 08:51:59 GMT etag: - - W/"eef35e97-c787-499a-89fd-e8b8b44208c6" + - W/"e0972916-fbd0-4420-827c-b1820579a7e5" expires: - '-1' pragma: @@ -474,7 +479,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9077c356-80de-437d-93e4-d6627354e4dd + - d9453350-78d9-4ec2-81f9-eb75f7974013 status: code: 200 message: OK @@ -488,21 +493,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/natGateways/myNatGateway?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\",\r\n - \ \"etag\": \"W/\\\"eef35e97-c787-499a-89fd-e8b8b44208c6\\\"\",\r\n \"type\": - \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"7cf62853-c555-4fb1-8900-4e0c0b90a198\",\r\n - \ \"idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\r\n - \ }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\"\ + ,\r\n \"etag\": \"W/\\\"e0972916-fbd0-4420-827c-b1820579a7e5\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"d4a3ee26-c77f-4bf7-be11-54841af5f934\",\r\n \"\ + idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n\ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + \r\n }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: cache-control: - no-cache @@ -511,9 +517,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:10 GMT + - Tue, 26 Jan 2021 08:51:59 GMT etag: - - W/"eef35e97-c787-499a-89fd-e8b8b44208c6" + - W/"e0972916-fbd0-4420-827c-b1820579a7e5" expires: - '-1' pragma: @@ -530,7 +536,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cbdc45e6-e82e-47f4-bb9c-8e646f9283a4 + - 9139a5d8-e041-49c8-9960-aa6bb276346e status: code: 200 message: OK @@ -548,22 +554,23 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/natGateways/myNatGateway?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\",\r\n - \ \"etag\": \"W/\\\"592d4923-8ccc-4587-9d7f-d1577ef244ad\\\"\",\r\n \"type\": - \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"7cf62853-c555-4fb1-8900-4e0c0b90a198\",\r\n - \ \"idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n {\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\r\n - \ }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \"id\": - \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\r\n - \ }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n - \ \"tier\": \"Regional\"\r\n }\r\n}" + string: "{\r\n \"name\": \"myNatGateway\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway\"\ + ,\r\n \"etag\": \"W/\\\"9f5b7c34-8ce8-4972-889d-9a928b5afb90\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/natGateways\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"d4a3ee26-c77f-4bf7-be11-54841af5f934\",\r\n \ + \ \"idleTimeoutInMinutes\": 4,\r\n \"publicIpAddresses\": [\r\n \ + \ {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress\"\ + \r\n }\r\n ],\r\n \"publicIpPrefixes\": [\r\n {\r\n \ + \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPPrefixes/publicipprefix\"\ + \r\n }\r\n ]\r\n },\r\n \"sku\": {\r\n \"name\": \"Standard\"\ + ,\r\n \"tier\": \"Regional\"\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -574,7 +581,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:13 GMT + - Tue, 26 Jan 2021 08:52:02 GMT expires: - '-1' pragma: @@ -591,9 +598,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 29a6cf4d-9076-45a6-9367-e7e34b8de1e4 + - f6ad090b-fd58-4ba7-a8f4-746d27045de6 x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1195' status: code: 200 message: OK @@ -609,9 +616,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/natGateways/myNatGateway?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/natGateways/myNatGateway?api-version=2020-08-01 response: body: string: '' @@ -619,17 +626,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acc7e94d-df13-4d11-92bd-d5387500c9e1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37df0277-c5a0-432b-a6e7-108f8b1f4989?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:36:14 GMT + - Tue, 26 Jan 2021 08:52:02 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/acc7e94d-df13-4d11-92bd-d5387500c9e1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/37df0277-c5a0-432b-a6e7-108f8b1f4989?api-version=2020-08-01 pragma: - no-cache server: @@ -640,7 +647,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6e9f5825-f3c3-496d-8854-fc520a9b717c + - dfbfa956-e433-4c65-8e74-60468d28cca5 x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -656,9 +663,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/acc7e94d-df13-4d11-92bd-d5387500c9e1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/37df0277-c5a0-432b-a6e7-108f8b1f4989?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -670,7 +677,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:24 GMT + - Tue, 26 Jan 2021 08:52:13 GMT expires: - '-1' pragma: @@ -687,7 +694,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ef686b15-064d-44d9-9e0f-0dfe309f39b8 + - 8cd15247-d8b8-4015-acbf-43571b261227 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_filter.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_filter.test_network.yaml index a0fe2442b7ea..d50dd60f80a2 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_filter.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_filter.test_network.yaml @@ -14,21 +14,22 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\",\r\n - \ \"etag\": \"W/\\\"45392466-27fe-4f1f-a224-d6f615e664de\\\"\",\r\n \"type\": - \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Updating\",\r\n \"rules\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\"\ + ,\r\n \"etag\": \"W/\\\"0f62c12d-9b60-4ad6-b301-316e38b26078\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Updating\",\r\n \"rules\": []\r\n \ + \ }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/245b88b2-707c-43e3-a78f-3b2076bda8d3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/73134045-137c-44b4-89ba-7be6d1c3f19b?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -36,7 +37,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:42 GMT + - Tue, 26 Jan 2021 08:52:39 GMT expires: - '-1' pragma: @@ -49,9 +50,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f3f2b47d-db32-4907-a53e-c14a50f01fd6 + - 1ad82afb-5c1a-43f2-a668-7735c664dc2f x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1195' status: code: 201 message: Created @@ -65,9 +66,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/245b88b2-707c-43e3-a78f-3b2076bda8d3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/73134045-137c-44b4-89ba-7be6d1c3f19b?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -79,7 +80,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:53 GMT + - Tue, 26 Jan 2021 08:52:49 GMT expires: - '-1' pragma: @@ -96,7 +97,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b48aa0d9-b430-4732-b220-970141395ee9 + - ebc633aa-3854-4705-a032-942ccf1e30a7 status: code: 200 message: OK @@ -110,16 +111,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\",\r\n - \ \"etag\": \"W/\\\"7f43e171-462d-42d9-bab6-db1289dafbf5\\\"\",\r\n \"type\": - \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"rules\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\"\ + ,\r\n \"etag\": \"W/\\\"690829b2-8175-460f-bbdd-b1091af7fb8a\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"rules\": []\r\n\ + \ }\r\n}" headers: cache-control: - no-cache @@ -128,9 +130,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:53 GMT + - Tue, 26 Jan 2021 08:52:49 GMT etag: - - W/"7f43e171-462d-42d9-bab6-db1289dafbf5" + - W/"690829b2-8175-460f-bbdd-b1091af7fb8a" expires: - '-1' pragma: @@ -147,7 +149,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 74052110-43b0-40ed-a09a-f27f5ebcc480 + - 54bffed7-2606-44c1-aa1d-4c463fec84b9 status: code: 200 message: OK @@ -161,15837 +163,19034 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/serviceTags?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/serviceTags?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"Public\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/serviceTags/Public\",\r\n - \ \"type\": \"Microsoft.Network/serviceTags\",\r\n \"changeNumber\": \"67\",\r\n - \ \"cloud\": \"Public\",\r\n \"values\": [\r\n {\r\n \"name\": \"ActionGroup\",\r\n - \ \"id\": \"ActionGroup\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\": - [\r\n \"13.66.143.220/30\",\r\n \"13.67.10.124/30\",\r\n - \ \"13.69.109.132/30\",\r\n \"13.71.199.112/30\",\r\n \"13.77.53.216/30\",\r\n - \ \"13.78.109.156/30\",\r\n \"13.86.221.220/30\",\r\n \"13.106.38.142/32\",\r\n - \ \"13.106.38.148/32\",\r\n \"13.106.54.3/32\",\r\n \"13.106.54.19/32\",\r\n - \ \"13.106.57.181/32\",\r\n \"13.106.57.196/31\",\r\n \"20.38.149.132/30\",\r\n - \ \"20.42.64.36/30\",\r\n \"20.43.121.124/30\",\r\n \"20.44.17.220/30\",\r\n - \ \"20.45.123.236/30\",\r\n \"20.150.172.228/30\",\r\n \"20.192.238.124/30\",\r\n - \ \"20.193.202.4/30\",\r\n \"51.104.9.100/30\",\r\n \"52.183.31.0/32\",\r\n - \ \"52.184.145.166/32\",\r\n \"191.233.50.4/30\",\r\n \"191.233.207.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.AustraliaSoutheast\",\r\n - \ \"id\": \"ActionGroup.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"13.77.53.216/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.BrazilSouth\",\r\n - \ \"id\": \"ActionGroup.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"191.233.207.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.CanadaCentral\",\r\n - \ \"id\": \"ActionGroup.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"20.38.149.132/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.CentralIndia\",\r\n - \ \"id\": \"ActionGroup.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"20.43.121.124/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.EastUS\",\r\n - \ \"id\": \"ActionGroup.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.64.36/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ActionGroup.EastUS2\",\r\n - \ \"id\": \"ActionGroup.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.17.220/30\",\r\n \"52.184.145.166/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.JapanEast\",\r\n - \ \"id\": \"ActionGroup.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.109.156/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ActionGroup.NorthCentralUS\",\r\n - \ \"id\": \"ActionGroup.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"13.106.38.142/32\",\r\n - \ \"13.106.38.148/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ActionGroup.SouthCentralUS\",\r\n \"id\": \"ActionGroup.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\": - [\r\n \"13.106.54.3/32\",\r\n \"13.106.54.19/32\",\r\n \"20.45.123.236/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.SoutheastAsia\",\r\n - \ \"id\": \"ActionGroup.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"13.67.10.124/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.UKSouth\",\r\n - \ \"id\": \"ActionGroup.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"51.104.9.100/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ActionGroup.WestCentralUS\",\r\n - \ \"id\": \"ActionGroup.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"13.71.199.112/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.WestEurope\",\r\n - \ \"id\": \"ActionGroup.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.109.132/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ActionGroup.WestUS\",\r\n - \ \"id\": \"ActionGroup.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.221.220/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ActionGroup.WestUS2\",\r\n - \ \"id\": \"ActionGroup.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.143.220/30\",\r\n \"13.106.57.181/32\",\r\n - \ \"13.106.57.196/31\",\r\n \"52.183.31.0/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement\",\r\n \"id\": - \"ApiManagement\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.64.39.16/32\",\r\n \"13.66.138.92/31\",\r\n \"13.66.140.176/28\",\r\n - \ \"13.67.8.108/31\",\r\n \"13.67.9.208/28\",\r\n \"13.69.64.76/31\",\r\n - \ \"13.69.66.144/28\",\r\n \"13.69.227.76/31\",\r\n \"13.69.229.80/28\",\r\n - \ \"13.70.72.28/31\",\r\n \"13.70.72.240/28\",\r\n \"13.71.49.1/32\",\r\n - \ \"13.71.170.44/31\",\r\n \"13.71.172.144/28\",\r\n \"13.71.194.116/31\",\r\n - \ \"13.71.196.32/28\",\r\n \"13.75.34.148/31\",\r\n \"13.75.38.16/28\",\r\n - \ \"13.75.217.184/32\",\r\n \"13.75.221.78/32\",\r\n \"13.77.50.68/31\",\r\n - \ \"13.77.52.224/28\",\r\n \"13.78.106.92/31\",\r\n \"13.78.108.176/28\",\r\n - \ \"13.84.189.17/32\",\r\n \"13.85.22.63/32\",\r\n \"13.86.102.66/32\",\r\n - \ \"13.87.56.84/31\",\r\n \"13.87.57.144/28\",\r\n \"13.87.122.84/31\",\r\n - \ \"13.87.123.144/28\",\r\n \"13.89.170.204/31\",\r\n \"13.89.174.64/28\",\r\n - \ \"20.36.106.68/31\",\r\n \"20.36.107.176/28\",\r\n \"20.36.114.20/31\",\r\n - \ \"20.36.115.128/28\",\r\n \"20.37.52.67/32\",\r\n \"20.37.74.224/31\",\r\n - \ \"20.37.76.32/28\",\r\n \"20.37.81.41/32\",\r\n \"20.39.80.2/32\",\r\n - \ \"20.39.99.81/32\",\r\n \"20.40.125.155/32\",\r\n \"20.40.160.107/32\",\r\n - \ \"20.44.2.4/31\",\r\n \"20.44.3.224/28\",\r\n \"20.44.33.246/32\",\r\n - \ \"20.44.72.3/32\",\r\n \"20.46.144.85/32\",\r\n \"20.150.170.224/28\",\r\n - \ \"20.188.77.119/32\",\r\n \"20.192.234.160/28\",\r\n \"20.193.202.160/28\",\r\n - \ \"23.96.224.175/32\",\r\n \"23.101.67.140/32\",\r\n \"23.101.166.38/32\",\r\n - \ \"40.66.60.111/32\",\r\n \"40.67.58.224/28\",\r\n \"40.69.106.68/31\",\r\n - \ \"40.69.107.224/28\",\r\n \"40.70.146.76/31\",\r\n \"40.70.148.16/28\",\r\n - \ \"40.71.10.204/31\",\r\n \"40.71.13.128/28\",\r\n \"40.74.100.52/31\",\r\n - \ \"40.74.101.48/28\",\r\n \"40.74.146.80/31\",\r\n \"40.74.147.32/28\",\r\n - \ \"40.78.194.68/31\",\r\n \"40.78.195.224/28\",\r\n \"40.78.202.128/31\",\r\n - \ \"40.78.203.160/28\",\r\n \"40.79.130.44/31\",\r\n \"40.79.131.192/28\",\r\n - \ \"40.79.178.68/31\",\r\n \"40.79.179.192/28\",\r\n \"40.80.232.185/32\",\r\n - \ \"40.81.47.216/32\",\r\n \"40.81.89.24/32\",\r\n \"40.81.185.8/32\",\r\n - \ \"40.82.157.167/32\",\r\n \"40.90.185.46/32\",\r\n \"40.112.242.148/31\",\r\n - \ \"40.112.243.240/28\",\r\n \"51.12.98.224/28\",\r\n \"51.12.202.224/28\",\r\n - \ \"51.107.0.91/32\",\r\n \"51.107.59.0/28\",\r\n \"51.107.96.8/32\",\r\n - \ \"51.107.155.0/28\",\r\n \"51.116.0.0/32\",\r\n \"51.116.59.0/28\",\r\n - \ \"51.116.96.0/32\",\r\n \"51.116.155.64/28\",\r\n \"51.120.2.185/32\",\r\n - \ \"51.120.98.176/28\",\r\n \"51.120.130.134/32\",\r\n \"51.120.218.224/28\",\r\n - \ \"51.137.136.0/32\",\r\n \"51.140.146.60/31\",\r\n \"51.140.149.0/28\",\r\n - \ \"51.140.210.84/31\",\r\n \"51.140.211.176/28\",\r\n \"51.143.127.203/32\",\r\n - \ \"51.145.56.125/32\",\r\n \"51.145.179.78/32\",\r\n \"52.139.20.34/32\",\r\n - \ \"52.139.80.117/32\",\r\n \"52.139.152.27/32\",\r\n \"52.140.238.179/32\",\r\n - \ \"52.142.95.35/32\",\r\n \"52.162.106.148/31\",\r\n \"52.162.110.80/28\",\r\n - \ \"52.224.186.99/32\",\r\n \"52.231.18.44/31\",\r\n \"52.231.19.192/28\",\r\n - \ \"52.231.146.84/31\",\r\n \"52.231.147.176/28\",\r\n \"52.253.135.58/32\",\r\n - \ \"52.253.159.160/32\",\r\n \"52.253.229.253/32\",\r\n \"65.52.164.91/32\",\r\n - \ \"65.52.173.247/32\",\r\n \"65.52.250.4/31\",\r\n \"65.52.252.32/28\",\r\n - \ \"102.133.0.79/32\",\r\n \"102.133.26.4/31\",\r\n \"102.133.28.0/28\",\r\n - \ \"102.133.130.197/32\",\r\n \"102.133.154.4/31\",\r\n \"102.133.156.0/28\",\r\n - \ \"104.41.217.243/32\",\r\n \"104.41.218.160/32\",\r\n \"104.211.81.28/31\",\r\n - \ \"104.211.81.240/28\",\r\n \"104.211.146.68/31\",\r\n \"104.211.147.144/28\",\r\n - \ \"104.214.18.172/31\",\r\n \"104.214.19.224/28\",\r\n \"137.117.160.56/32\",\r\n - \ \"191.233.24.179/32\",\r\n \"191.233.50.192/28\",\r\n \"191.233.203.28/31\",\r\n - \ \"191.233.203.240/28\",\r\n \"191.238.241.97/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.AustraliaCentral\",\r\n - \ \"id\": \"ApiManagement.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"20.36.106.68/31\",\r\n - \ \"20.36.107.176/28\",\r\n \"20.37.52.67/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.AustraliaCentral2\",\r\n - \ \"id\": \"ApiManagement.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.20/31\",\r\n - \ \"20.36.115.128/28\",\r\n \"20.39.99.81/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.AustraliaEast\",\r\n - \ \"id\": \"ApiManagement.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.28/31\",\r\n - \ \"13.70.72.240/28\",\r\n \"13.75.217.184/32\",\r\n \"13.75.221.78/32\",\r\n - \ \"20.40.125.155/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.AustraliaSoutheast\",\r\n \"id\": \"ApiManagement.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.77.50.68/31\",\r\n \"13.77.52.224/28\",\r\n \"20.40.160.107/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.BrazilSouth\",\r\n - \ \"id\": \"ApiManagement.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"191.233.24.179/32\",\r\n - \ \"191.233.203.28/31\",\r\n \"191.233.203.240/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CanadaCentral\",\r\n - \ \"id\": \"ApiManagement.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.44/31\",\r\n - \ \"13.71.172.144/28\",\r\n \"52.139.20.34/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CanadaEast\",\r\n - \ \"id\": \"ApiManagement.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.68/31\",\r\n - \ \"40.69.107.224/28\",\r\n \"52.139.80.117/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CentralIndia\",\r\n - \ \"id\": \"ApiManagement.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.71.49.1/32\",\r\n - \ \"104.211.81.28/31\",\r\n \"104.211.81.240/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CentralUS\",\r\n - \ \"id\": \"ApiManagement.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.86.102.66/32\",\r\n - \ \"13.89.170.204/31\",\r\n \"13.89.174.64/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CentralUSEUAP\",\r\n - \ \"id\": \"ApiManagement.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.128/31\",\r\n - \ \"40.78.203.160/28\",\r\n \"52.253.159.160/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.EastAsia\",\r\n - \ \"id\": \"ApiManagement.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.34.148/31\",\r\n \"13.75.38.16/28\",\r\n - \ \"52.139.152.27/32\",\r\n \"65.52.164.91/32\",\r\n \"65.52.173.247/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.EastUS\",\r\n - \ \"id\": \"ApiManagement.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.71.10.204/31\",\r\n \"40.71.13.128/28\",\r\n - \ \"52.224.186.99/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.EastUS2\",\r\n \"id\": \"ApiManagement.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"20.44.72.3/32\",\r\n \"40.70.146.76/31\",\r\n \"40.70.148.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.EastUS2EUAP\",\r\n - \ \"id\": \"ApiManagement.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.80/31\",\r\n - \ \"40.74.147.32/28\",\r\n \"52.253.229.253/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.FranceCentral\",\r\n - \ \"id\": \"ApiManagement.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.66.60.111/32\",\r\n - \ \"40.79.130.44/31\",\r\n \"40.79.131.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.FranceSouth\",\r\n - \ \"id\": \"ApiManagement.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"20.39.80.2/32\",\r\n - \ \"40.79.178.68/31\",\r\n \"40.79.179.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.GermanyNorth\",\r\n - \ \"id\": \"ApiManagement.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"51.116.0.0/32\",\r\n - \ \"51.116.59.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.GermanyWestCentral\",\r\n \"id\": \"ApiManagement.GermanyWestCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.116.96.0/32\",\r\n \"51.116.155.64/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.JapanEast\",\r\n - \ \"id\": \"ApiManagement.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.78.106.92/31\",\r\n - \ \"13.78.108.176/28\",\r\n \"52.140.238.179/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.JapanWest\",\r\n - \ \"id\": \"ApiManagement.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.74.100.52/31\",\r\n - \ \"40.74.101.48/28\",\r\n \"40.81.185.8/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.KoreaCentral\",\r\n - \ \"id\": \"ApiManagement.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.82.157.167/32\",\r\n - \ \"52.231.18.44/31\",\r\n \"52.231.19.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.KoreaSouth\",\r\n - \ \"id\": \"ApiManagement.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.80.232.185/32\",\r\n - \ \"52.231.146.84/31\",\r\n \"52.231.147.176/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorthCentralUS\",\r\n - \ \"id\": \"ApiManagement.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"23.96.224.175/32\",\r\n - \ \"23.101.166.38/32\",\r\n \"40.81.47.216/32\",\r\n \"52.162.106.148/31\",\r\n - \ \"52.162.110.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.NorthEurope\",\r\n \"id\": \"ApiManagement.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.69.227.76/31\",\r\n \"13.69.229.80/28\",\r\n - \ \"52.142.95.35/32\",\r\n \"104.41.217.243/32\",\r\n \"104.41.218.160/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorwayEast\",\r\n - \ \"id\": \"ApiManagement.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.2.185/32\",\r\n \"51.120.98.176/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorwayWest\",\r\n - \ \"id\": \"ApiManagement.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.130.134/32\",\r\n \"51.120.218.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthAfricaNorth\",\r\n - \ \"id\": \"ApiManagement.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"102.133.130.197/32\",\r\n - \ \"102.133.154.4/31\",\r\n \"102.133.156.0/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthAfricaWest\",\r\n - \ \"id\": \"ApiManagement.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"102.133.0.79/32\",\r\n - \ \"102.133.26.4/31\",\r\n \"102.133.28.0/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthCentralUS\",\r\n - \ \"id\": \"ApiManagement.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.84.189.17/32\",\r\n - \ \"13.85.22.63/32\",\r\n \"20.188.77.119/32\",\r\n \"104.214.18.172/31\",\r\n - \ \"104.214.19.224/28\",\r\n \"191.238.241.97/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SoutheastAsia\",\r\n - \ \"id\": \"ApiManagement.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.108/31\",\r\n - \ \"13.67.9.208/28\",\r\n \"40.90.185.46/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthIndia\",\r\n - \ \"id\": \"ApiManagement.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"20.44.33.246/32\",\r\n - \ \"40.78.194.68/31\",\r\n \"40.78.195.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SwitzerlandNorth\",\r\n - \ \"id\": \"ApiManagement.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"51.107.0.91/32\",\r\n - \ \"51.107.59.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.SwitzerlandWest\",\r\n \"id\": \"ApiManagement.SwitzerlandWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.107.96.8/32\",\r\n \"51.107.155.0/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UAECentral\",\r\n - \ \"id\": \"ApiManagement.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.224/31\",\r\n - \ \"20.37.76.32/28\",\r\n \"20.37.81.41/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UAENorth\",\r\n - \ \"id\": \"ApiManagement.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.46.144.85/32\",\r\n \"65.52.250.4/31\",\r\n - \ \"65.52.252.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.UKNorth\",\r\n \"id\": \"ApiManagement.UKNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.87.122.84/31\",\r\n \"13.87.123.144/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UKSouth\",\r\n - \ \"id\": \"ApiManagement.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.140.146.60/31\",\r\n \"51.140.149.0/28\",\r\n - \ \"51.145.56.125/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.UKSouth2\",\r\n \"id\": \"ApiManagement.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.87.56.84/31\",\r\n \"13.87.57.144/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UKWest\",\r\n - \ \"id\": \"ApiManagement.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.137.136.0/32\",\r\n \"51.140.210.84/31\",\r\n - \ \"51.140.211.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.WestCentralUS\",\r\n \"id\": \"ApiManagement.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.71.194.116/31\",\r\n \"13.71.196.32/28\",\r\n - \ \"52.253.135.58/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.WestEurope\",\r\n \"id\": \"ApiManagement.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.69.64.76/31\",\r\n \"13.69.66.144/28\",\r\n \"23.101.67.140/32\",\r\n - \ \"51.145.179.78/32\",\r\n \"137.117.160.56/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.WestIndia\",\r\n - \ \"id\": \"ApiManagement.WestIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"40.81.89.24/32\",\r\n - \ \"104.211.146.68/31\",\r\n \"104.211.147.144/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.WestUS\",\r\n - \ \"id\": \"ApiManagement.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.39.16/32\",\r\n \"40.112.242.148/31\",\r\n - \ \"40.112.243.240/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApiManagement.WestUS2\",\r\n \"id\": \"ApiManagement.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.92/31\",\r\n \"13.66.140.176/28\",\r\n - \ \"51.143.127.203/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppConfiguration\",\r\n \"id\": \"AppConfiguration\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureAppConfiguration\",\r\n \"addressPrefixes\": [\r\n \"13.66.142.72/29\",\r\n - \ \"13.66.143.192/28\",\r\n \"13.66.143.208/29\",\r\n \"13.67.10.112/29\",\r\n - \ \"13.67.13.192/28\",\r\n \"13.67.13.208/29\",\r\n \"13.69.67.112/29\",\r\n - \ \"13.69.67.240/28\",\r\n \"13.69.71.128/29\",\r\n \"13.69.107.72/29\",\r\n - \ \"13.69.112.144/28\",\r\n \"13.69.112.160/29\",\r\n \"13.69.230.8/29\",\r\n - \ \"13.69.230.40/29\",\r\n \"13.69.231.144/28\",\r\n \"13.70.74.128/29\",\r\n - \ \"13.70.78.144/28\",\r\n \"13.70.78.160/29\",\r\n \"13.71.175.64/28\",\r\n - \ \"13.71.175.96/28\",\r\n \"13.71.196.176/28\",\r\n \"13.71.199.80/28\",\r\n - \ \"13.73.242.56/29\",\r\n \"13.73.244.96/28\",\r\n \"13.73.244.112/29\",\r\n - \ \"13.74.108.160/28\",\r\n \"13.74.108.240/28\",\r\n \"13.77.53.88/29\",\r\n - \ \"13.77.53.192/28\",\r\n \"13.77.53.208/29\",\r\n \"13.78.109.144/29\",\r\n - \ \"13.78.109.208/28\",\r\n \"13.78.111.128/29\",\r\n \"13.86.219.192/29\",\r\n - \ \"13.86.221.192/28\",\r\n \"13.86.221.208/29\",\r\n \"13.87.58.64/29\",\r\n - \ \"13.87.58.80/28\",\r\n \"13.87.58.128/29\",\r\n \"13.87.124.64/29\",\r\n - \ \"13.87.124.80/28\",\r\n \"13.87.124.128/29\",\r\n \"13.89.175.208/28\",\r\n - \ \"13.89.178.16/29\",\r\n \"13.89.178.32/29\",\r\n \"20.36.108.120/29\",\r\n - \ \"20.36.108.136/29\",\r\n \"20.36.108.144/28\",\r\n \"20.36.115.248/29\",\r\n - \ \"20.36.117.40/29\",\r\n \"20.36.117.48/28\",\r\n \"20.36.123.16/28\",\r\n - \ \"20.37.67.96/28\",\r\n \"20.37.76.112/29\",\r\n \"20.37.76.144/28\",\r\n - \ \"20.37.76.192/29\",\r\n \"20.37.198.144/28\",\r\n \"20.37.227.32/28\",\r\n - \ \"20.38.128.96/29\",\r\n \"20.38.128.112/28\",\r\n \"20.38.128.160/29\",\r\n - \ \"20.38.139.96/28\",\r\n \"20.38.147.176/28\",\r\n \"20.38.147.240/28\",\r\n - \ \"20.39.14.16/28\",\r\n \"20.40.206.144/28\",\r\n \"20.40.206.160/28\",\r\n - \ \"20.41.68.64/28\",\r\n \"20.41.197.48/28\",\r\n \"20.42.64.16/28\",\r\n - \ \"20.42.230.144/28\",\r\n \"20.43.44.144/28\",\r\n \"20.43.70.128/28\",\r\n - \ \"20.43.121.40/29\",\r\n \"20.43.121.96/28\",\r\n \"20.43.121.112/29\",\r\n - \ \"20.44.4.96/29\",\r\n \"20.44.4.120/29\",\r\n \"20.44.4.160/28\",\r\n - \ \"20.44.8.168/29\",\r\n \"20.44.10.96/28\",\r\n \"20.44.10.112/29\",\r\n - \ \"20.44.17.56/29\",\r\n \"20.44.17.192/28\",\r\n \"20.44.17.208/29\",\r\n - \ \"20.44.27.224/28\",\r\n \"20.44.29.32/28\",\r\n \"20.45.123.120/29\",\r\n - \ \"20.45.123.176/28\",\r\n \"20.45.123.224/29\",\r\n \"20.45.126.0/27\",\r\n - \ \"20.45.198.0/27\",\r\n \"20.49.83.96/27\",\r\n \"20.49.91.96/27\",\r\n - \ \"20.49.99.80/28\",\r\n \"20.49.109.96/28\",\r\n \"20.49.120.80/28\",\r\n - \ \"20.50.1.240/28\",\r\n \"20.50.65.96/28\",\r\n \"20.150.165.176/28\",\r\n - \ \"20.150.172.64/27\",\r\n \"20.150.173.32/27\",\r\n \"20.150.179.200/29\",\r\n - \ \"20.150.181.0/28\",\r\n \"20.150.181.16/29\",\r\n \"20.150.181.128/27\",\r\n - \ \"20.150.187.200/29\",\r\n \"20.150.189.0/28\",\r\n \"20.150.189.16/29\",\r\n - \ \"20.187.194.224/28\",\r\n \"20.192.99.200/29\",\r\n \"20.192.101.0/28\",\r\n - \ \"20.192.101.16/29\",\r\n \"20.192.235.240/29\",\r\n \"20.192.238.112/29\",\r\n - \ \"20.192.238.192/27\",\r\n \"20.193.203.224/27\",\r\n \"20.194.67.64/27\",\r\n - \ \"23.98.83.72/29\",\r\n \"23.98.86.32/28\",\r\n \"23.98.86.48/29\",\r\n - \ \"23.98.104.176/28\",\r\n \"40.64.132.144/28\",\r\n \"40.67.60.72/29\",\r\n - \ \"40.67.60.112/28\",\r\n \"40.67.60.160/29\",\r\n \"40.69.108.80/29\",\r\n - \ \"40.69.108.176/28\",\r\n \"40.69.110.160/29\",\r\n \"40.70.148.56/29\",\r\n - \ \"40.70.151.48/28\",\r\n \"40.70.151.64/29\",\r\n \"40.71.13.248/29\",\r\n - \ \"40.71.14.120/29\",\r\n \"40.71.15.128/28\",\r\n \"40.74.149.40/29\",\r\n - \ \"40.74.149.56/29\",\r\n \"40.74.149.80/28\",\r\n \"40.75.35.72/29\",\r\n - \ \"40.75.35.192/28\",\r\n \"40.75.35.208/29\",\r\n \"40.78.196.80/29\",\r\n - \ \"40.78.196.144/28\",\r\n \"40.78.196.160/29\",\r\n \"40.78.204.8/29\",\r\n - \ \"40.78.204.144/28\",\r\n \"40.78.204.192/29\",\r\n \"40.78.229.80/28\",\r\n - \ \"40.78.229.112/28\",\r\n \"40.78.236.136/29\",\r\n \"40.78.238.32/28\",\r\n - \ \"40.78.238.48/29\",\r\n \"40.78.243.176/28\",\r\n \"40.78.245.128/28\",\r\n - \ \"40.78.251.144/28\",\r\n \"40.78.251.208/28\",\r\n \"40.79.132.88/29\",\r\n - \ \"40.79.139.64/28\",\r\n \"40.79.139.128/28\",\r\n \"40.79.146.208/28\",\r\n - \ \"40.79.148.64/28\",\r\n \"40.79.156.96/28\",\r\n \"40.79.163.64/29\",\r\n - \ \"40.79.163.128/28\",\r\n \"40.79.163.144/29\",\r\n \"40.79.165.96/27\",\r\n - \ \"40.79.171.112/28\",\r\n \"40.79.171.176/28\",\r\n \"40.79.180.48/29\",\r\n - \ \"40.79.180.128/28\",\r\n \"40.79.180.144/29\",\r\n \"40.79.187.192/29\",\r\n - \ \"40.79.189.32/28\",\r\n \"40.79.189.48/29\",\r\n \"40.79.195.176/28\",\r\n - \ \"40.79.195.240/28\",\r\n \"40.80.51.112/28\",\r\n \"40.80.51.176/28\",\r\n - \ \"40.80.62.32/28\",\r\n \"40.80.172.48/28\",\r\n \"40.80.176.40/29\",\r\n - \ \"40.80.176.56/29\",\r\n \"40.80.176.112/28\",\r\n \"40.80.191.240/28\",\r\n - \ \"40.89.20.160/28\",\r\n \"40.119.11.192/28\",\r\n \"40.120.75.128/27\",\r\n - \ \"51.11.192.0/28\",\r\n \"51.11.192.16/29\",\r\n \"51.12.99.216/29\",\r\n - \ \"51.12.100.48/28\",\r\n \"51.12.100.96/29\",\r\n \"51.12.204.48/28\",\r\n - \ \"51.12.204.96/28\",\r\n \"51.12.227.200/29\",\r\n \"51.12.229.0/28\",\r\n - \ \"51.12.229.16/29\",\r\n \"51.12.235.200/29\",\r\n \"51.12.237.0/28\",\r\n - \ \"51.12.237.16/29\",\r\n \"51.104.9.48/28\",\r\n \"51.104.29.224/28\",\r\n - \ \"51.105.67.184/29\",\r\n \"51.105.67.216/29\",\r\n \"51.105.69.64/28\",\r\n - \ \"51.105.75.224/28\",\r\n \"51.105.77.32/28\",\r\n \"51.105.90.176/28\",\r\n - \ \"51.107.51.48/28\",\r\n \"51.107.60.56/29\",\r\n \"51.107.60.128/28\",\r\n - \ \"51.107.60.144/29\",\r\n \"51.107.147.48/28\",\r\n \"51.107.156.64/29\",\r\n - \ \"51.107.156.136/29\",\r\n \"51.107.156.144/28\",\r\n \"51.116.49.192/28\",\r\n - \ \"51.116.60.56/29\",\r\n \"51.116.60.88/29\",\r\n \"51.116.60.128/28\",\r\n - \ \"51.116.145.176/28\",\r\n \"51.116.156.56/29\",\r\n \"51.116.156.168/29\",\r\n - \ \"51.116.158.32/28\",\r\n \"51.116.158.48/29\",\r\n \"51.116.243.152/29\",\r\n - \ \"51.116.243.192/28\",\r\n \"51.116.243.208/29\",\r\n \"51.116.245.128/27\",\r\n - \ \"51.116.251.40/29\",\r\n \"51.116.251.160/28\",\r\n \"51.116.251.176/29\",\r\n - \ \"51.116.253.64/27\",\r\n \"51.120.43.96/28\",\r\n \"51.120.100.56/29\",\r\n - \ \"51.120.100.128/28\",\r\n \"51.120.100.144/29\",\r\n \"51.120.107.200/29\",\r\n - \ \"51.120.109.0/28\",\r\n \"51.120.109.16/29\",\r\n \"51.120.211.200/29\",\r\n - \ \"51.120.213.0/28\",\r\n \"51.120.213.16/29\",\r\n \"51.120.220.56/29\",\r\n - \ \"51.120.220.96/28\",\r\n \"51.120.220.112/29\",\r\n \"51.120.227.96/28\",\r\n - \ \"51.137.164.128/28\",\r\n \"51.140.148.40/29\",\r\n \"51.140.149.16/29\",\r\n - \ \"51.140.212.96/29\",\r\n \"51.140.212.192/28\",\r\n \"51.140.212.208/29\",\r\n - \ \"52.136.51.96/28\",\r\n \"52.138.92.88/29\",\r\n \"52.138.92.144/28\",\r\n - \ \"52.138.92.160/29\",\r\n \"52.138.227.176/28\",\r\n \"52.138.229.48/28\",\r\n - \ \"52.140.108.112/28\",\r\n \"52.140.108.128/28\",\r\n \"52.150.152.64/28\",\r\n - \ \"52.162.111.32/28\",\r\n \"52.162.111.112/28\",\r\n \"52.167.107.112/28\",\r\n - \ \"52.167.107.240/28\",\r\n \"52.182.141.0/29\",\r\n \"52.182.141.32/28\",\r\n - \ \"52.182.141.48/29\",\r\n \"52.228.85.208/28\",\r\n \"52.231.20.8/29\",\r\n - \ \"52.231.20.80/28\",\r\n \"52.231.23.0/29\",\r\n \"52.231.148.112/29\",\r\n - \ \"52.231.148.176/28\",\r\n \"52.231.148.192/29\",\r\n \"52.236.186.248/29\",\r\n - \ \"52.236.187.96/28\",\r\n \"52.236.189.64/29\",\r\n \"52.246.155.176/28\",\r\n - \ \"52.246.155.240/28\",\r\n \"52.246.157.32/27\",\r\n \"65.52.252.112/29\",\r\n - \ \"65.52.252.224/28\",\r\n \"65.52.252.240/29\",\r\n \"102.133.28.96/29\",\r\n - \ \"102.133.28.152/29\",\r\n \"102.133.28.192/28\",\r\n \"102.133.58.240/28\",\r\n - \ \"102.133.124.80/29\",\r\n \"102.133.124.112/28\",\r\n - \ \"102.133.124.128/29\",\r\n \"102.133.156.120/29\",\r\n - \ \"102.133.156.152/29\",\r\n \"102.133.156.160/28\",\r\n - \ \"102.133.218.160/28\",\r\n \"102.133.251.88/29\",\r\n - \ \"102.133.251.192/28\",\r\n \"102.133.251.208/29\",\r\n - \ \"104.214.161.0/29\",\r\n \"104.214.161.16/28\",\r\n \"104.214.161.32/29\",\r\n - \ \"191.233.11.144/28\",\r\n \"191.233.51.224/27\",\r\n \"191.233.205.112/28\",\r\n - \ \"191.233.205.176/28\",\r\n \"191.234.136.96/28\",\r\n - \ \"191.234.147.200/29\",\r\n \"191.234.149.16/28\",\r\n - \ \"191.234.149.128/29\",\r\n \"191.234.149.192/27\",\r\n - \ \"191.234.155.200/29\",\r\n \"191.234.157.16/28\",\r\n - \ \"191.234.157.32/29\",\r\n \"191.234.157.96/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability\",\r\n - \ \"id\": \"ApplicationInsightsAvailability\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"ApplicationInsightsAvailability\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.97.224/27\",\r\n \"13.86.98.0/27\",\r\n - \ \"13.86.98.48/28\",\r\n \"13.86.98.64/28\",\r\n \"20.37.156.64/27\",\r\n - \ \"20.37.192.80/29\",\r\n \"20.38.80.80/28\",\r\n \"20.40.104.96/27\",\r\n - \ \"20.40.104.128/27\",\r\n \"20.40.124.176/28\",\r\n \"20.40.124.240/28\",\r\n - \ \"20.40.125.80/28\",\r\n \"20.40.129.32/27\",\r\n \"20.40.129.64/26\",\r\n - \ \"20.40.129.128/27\",\r\n \"20.42.4.64/27\",\r\n \"20.42.35.32/28\",\r\n - \ \"20.42.35.64/26\",\r\n \"20.42.35.128/28\",\r\n \"20.42.129.32/27\",\r\n - \ \"20.43.40.80/28\",\r\n \"20.43.64.80/29\",\r\n \"20.43.128.96/29\",\r\n - \ \"20.45.5.160/27\",\r\n \"20.45.5.192/26\",\r\n \"20.189.106.64/29\",\r\n - \ \"23.100.224.16/28\",\r\n \"23.100.224.32/27\",\r\n \"23.100.224.64/26\",\r\n - \ \"23.100.225.0/28\",\r\n \"40.74.24.80/28\",\r\n \"40.80.186.128/26\",\r\n - \ \"40.91.82.48/28\",\r\n \"40.91.82.64/26\",\r\n \"40.91.82.128/28\",\r\n - \ \"40.119.8.96/27\",\r\n \"51.104.24.80/29\",\r\n \"51.105.9.128/27\",\r\n - \ \"51.105.9.160/28\",\r\n \"51.137.160.80/29\",\r\n \"51.144.56.96/27\",\r\n - \ \"51.144.56.128/26\",\r\n \"52.139.250.96/27\",\r\n \"52.139.250.128/27\",\r\n - \ \"52.140.232.160/27\",\r\n \"52.140.232.192/28\",\r\n \"52.158.28.64/26\",\r\n - \ \"52.229.216.48/28\",\r\n \"52.229.216.64/27\",\r\n \"191.233.26.64/28\",\r\n - \ \"191.233.26.128/28\",\r\n \"191.233.26.176/28\",\r\n \"191.235.224.80/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.EastUS\",\r\n - \ \"id\": \"ApplicationInsightsAvailability.EastUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ApplicationInsightsAvailability\",\r\n \"addressPrefixes\": [\r\n - \ \"20.42.4.64/27\",\r\n \"20.42.35.32/28\",\r\n \"20.42.35.64/26\",\r\n - \ \"20.42.35.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ApplicationInsightsAvailability.JapanEast\",\r\n \"id\": - \"ApplicationInsightsAvailability.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ApplicationInsightsAvailability\",\r\n \"addressPrefixes\": [\r\n - \ \"20.43.64.80/29\",\r\n \"52.140.232.160/27\",\r\n \"52.140.232.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.NorthCentralUS\",\r\n - \ \"id\": \"ApplicationInsightsAvailability.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ApplicationInsightsAvailability\",\r\n \"addressPrefixes\": [\r\n - \ \"23.100.224.16/28\",\r\n \"23.100.224.32/27\",\r\n \"23.100.224.64/26\",\r\n - \ \"23.100.225.0/28\",\r\n \"40.80.186.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.SoutheastAsia\",\r\n - \ \"id\": \"ApplicationInsightsAvailability.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"ApplicationInsightsAvailability\",\r\n \"addressPrefixes\": [\r\n - \ \"20.43.128.96/29\",\r\n \"52.139.250.96/27\",\r\n \"52.139.250.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService\",\r\n - \ \"id\": \"AppService\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.64.73.110/32\",\r\n \"13.65.30.245/32\",\r\n - \ \"13.65.37.122/32\",\r\n \"13.65.39.165/32\",\r\n \"13.65.42.35/32\",\r\n - \ \"13.65.42.183/32\",\r\n \"13.65.45.30/32\",\r\n \"13.65.85.146/32\",\r\n - \ \"13.65.89.91/32\",\r\n \"13.65.92.72/32\",\r\n \"13.65.94.204/32\",\r\n - \ \"13.65.95.109/32\",\r\n \"13.65.97.243/32\",\r\n \"13.65.193.29/32\",\r\n - \ \"13.65.210.166/32\",\r\n \"13.65.212.252/32\",\r\n \"13.65.241.130/32\",\r\n - \ \"13.65.243.110/32\",\r\n \"13.66.16.101/32\",\r\n \"13.66.38.99/32\",\r\n - \ \"13.66.39.88/32\",\r\n \"13.66.138.96/27\",\r\n \"13.66.209.135/32\",\r\n - \ \"13.66.212.205/32\",\r\n \"13.66.226.80/32\",\r\n \"13.66.231.217/32\",\r\n - \ \"13.66.241.134/32\",\r\n \"13.66.244.249/32\",\r\n \"13.67.9.0/25\",\r\n - \ \"13.67.56.225/32\",\r\n \"13.67.63.90/32\",\r\n \"13.67.129.26/32\",\r\n - \ \"13.67.141.98/32\",\r\n \"13.68.29.136/32\",\r\n \"13.68.101.62/32\",\r\n - \ \"13.69.68.0/23\",\r\n \"13.69.186.152/32\",\r\n \"13.69.228.0/25\",\r\n - \ \"13.69.253.145/32\",\r\n \"13.70.72.32/27\",\r\n \"13.70.123.149/32\",\r\n - \ \"13.70.146.110/32\",\r\n \"13.70.147.206/32\",\r\n \"13.71.122.35/32\",\r\n - \ \"13.71.123.138/32\",\r\n \"13.71.149.151/32\",\r\n \"13.71.170.128/27\",\r\n - \ \"13.71.194.192/27\",\r\n \"13.73.1.134/32\",\r\n \"13.73.26.73/32\",\r\n - \ \"13.73.116.45/32\",\r\n \"13.73.118.104/32\",\r\n \"13.74.41.233/32\",\r\n - \ \"13.74.147.218/32\",\r\n \"13.74.158.5/32\",\r\n \"13.74.252.44/32\",\r\n - \ \"13.75.34.160/27\",\r\n \"13.75.46.26/32\",\r\n \"13.75.47.15/32\",\r\n - \ \"13.75.89.224/32\",\r\n \"13.75.112.108/32\",\r\n \"13.75.115.40/32\",\r\n - \ \"13.75.138.224/32\",\r\n \"13.75.147.143/32\",\r\n \"13.75.147.201/32\",\r\n - \ \"13.75.218.45/32\",\r\n \"13.76.44.139/32\",\r\n \"13.76.245.96/32\",\r\n - \ \"13.77.7.175/32\",\r\n \"13.77.50.96/27\",\r\n \"13.77.82.141/32\",\r\n - \ \"13.77.83.246/32\",\r\n \"13.77.96.119/32\",\r\n \"13.77.157.133/32\",\r\n - \ \"13.77.160.237/32\",\r\n \"13.77.182.13/32\",\r\n \"13.78.59.237/32\",\r\n - \ \"13.78.106.96/27\",\r\n \"13.78.117.86/32\",\r\n \"13.78.123.87/32\",\r\n - \ \"13.78.150.96/32\",\r\n \"13.78.184.89/32\",\r\n \"13.79.2.71/32\",\r\n - \ \"13.79.38.229/32\",\r\n \"13.79.172.40/32\",\r\n \"13.80.19.74/32\",\r\n - \ \"13.81.7.21/32\",\r\n \"13.81.108.99/32\",\r\n \"13.81.215.235/32\",\r\n - \ \"13.82.93.245/32\",\r\n \"13.82.101.179/32\",\r\n \"13.82.175.96/32\",\r\n - \ \"13.84.36.2/32\",\r\n \"13.84.40.227/32\",\r\n \"13.84.42.35/32\",\r\n - \ \"13.84.46.29/32\",\r\n \"13.84.55.137/32\",\r\n \"13.84.146.60/32\",\r\n - \ \"13.84.180.32/32\",\r\n \"13.84.181.47/32\",\r\n \"13.84.188.162/32\",\r\n - \ \"13.84.189.137/32\",\r\n \"13.84.227.164/32\",\r\n \"13.85.15.194/32\",\r\n - \ \"13.85.16.224/32\",\r\n \"13.85.20.144/32\",\r\n \"13.85.24.220/32\",\r\n - \ \"13.85.27.14/32\",\r\n \"13.85.31.243/32\",\r\n \"13.85.72.129/32\",\r\n - \ \"13.85.77.179/32\",\r\n \"13.85.82.0/32\",\r\n \"13.89.57.7/32\",\r\n - \ \"13.89.172.0/23\",\r\n \"13.89.238.239/32\",\r\n \"13.90.143.69/32\",\r\n - \ \"13.90.213.204/32\",\r\n \"13.91.40.166/32\",\r\n \"13.91.242.166/32\",\r\n - \ \"13.92.139.214/32\",\r\n \"13.92.193.110/32\",\r\n \"13.92.237.218/32\",\r\n - \ \"13.93.141.10/32\",\r\n \"13.93.158.16/32\",\r\n \"13.93.220.109/32\",\r\n - \ \"13.93.231.75/32\",\r\n \"13.94.47.87/32\",\r\n \"13.94.143.57/32\",\r\n - \ \"13.94.192.98/32\",\r\n \"13.94.211.38/32\",\r\n \"13.95.82.181/32\",\r\n - \ \"13.95.93.152/32\",\r\n \"13.95.150.128/32\",\r\n \"13.95.238.192/32\",\r\n - \ \"20.36.43.207/32\",\r\n \"20.36.72.230/32\",\r\n \"20.36.106.96/27\",\r\n - \ \"20.36.117.0/27\",\r\n \"20.36.122.0/27\",\r\n \"20.37.66.0/27\",\r\n - \ \"20.37.74.96/27\",\r\n \"20.37.196.192/27\",\r\n \"20.37.226.0/27\",\r\n - \ \"20.38.138.0/27\",\r\n \"20.38.146.160/27\",\r\n \"20.39.11.104/29\",\r\n - \ \"20.40.202.0/23\",\r\n \"20.41.66.224/27\",\r\n \"20.41.195.192/27\",\r\n - \ \"20.42.26.252/32\",\r\n \"20.42.128.96/27\",\r\n \"20.42.228.160/27\",\r\n - \ \"20.43.43.32/27\",\r\n \"20.43.67.32/27\",\r\n \"20.43.132.128/25\",\r\n - \ \"20.44.2.32/27\",\r\n \"20.44.26.160/27\",\r\n \"20.45.122.160/27\",\r\n - \ \"20.45.196.16/29\",\r\n \"20.49.82.32/27\",\r\n \"20.49.90.32/27\",\r\n - \ \"20.49.97.0/25\",\r\n \"20.49.104.0/25\",\r\n \"20.50.2.0/23\",\r\n - \ \"20.50.64.0/25\",\r\n \"20.150.170.192/27\",\r\n \"20.150.178.160/27\",\r\n - \ \"20.150.186.160/27\",\r\n \"20.188.98.74/32\",\r\n \"20.189.104.96/27\",\r\n - \ \"20.189.109.96/27\",\r\n \"20.189.112.66/32\",\r\n \"20.192.98.160/27\",\r\n - \ \"20.192.234.128/27\",\r\n \"20.193.202.128/27\",\r\n \"20.194.66.32/27\",\r\n - \ \"23.96.0.52/32\",\r\n \"23.96.1.109/32\",\r\n \"23.96.13.243/32\",\r\n - \ \"23.96.32.128/32\",\r\n \"23.96.96.142/32\",\r\n \"23.96.103.159/32\",\r\n - \ \"23.96.112.53/32\",\r\n \"23.96.113.128/32\",\r\n \"23.96.124.25/32\",\r\n - \ \"23.96.187.5/32\",\r\n \"23.96.201.21/32\",\r\n \"23.96.207.177/32\",\r\n - \ \"23.96.209.155/32\",\r\n \"23.96.220.116/32\",\r\n \"23.97.56.169/32\",\r\n - \ \"23.97.79.119/32\",\r\n \"23.97.96.32/32\",\r\n \"23.97.160.56/32\",\r\n - \ \"23.97.160.74/32\",\r\n \"23.97.162.202/32\",\r\n \"23.97.195.129/32\",\r\n - \ \"23.97.208.18/32\",\r\n \"23.97.214.177/32\",\r\n \"23.97.216.47/32\",\r\n - \ \"23.97.224.11/32\",\r\n \"23.98.64.36/32\",\r\n \"23.98.64.158/32\",\r\n - \ \"23.99.0.12/32\",\r\n \"23.99.65.65/32\",\r\n \"23.99.91.55/32\",\r\n - \ \"23.99.110.192/32\",\r\n \"23.99.116.70/32\",\r\n \"23.99.128.52/32\",\r\n - \ \"23.99.183.149/32\",\r\n \"23.99.192.132/32\",\r\n \"23.99.196.180/32\",\r\n - \ \"23.99.206.151/32\",\r\n \"23.99.224.56/32\",\r\n \"23.100.1.29/32\",\r\n - \ \"23.100.46.198/32\",\r\n \"23.100.48.106/32\",\r\n \"23.100.50.51/32\",\r\n - \ \"23.100.52.22/32\",\r\n \"23.100.56.27/32\",\r\n \"23.100.72.240/32\",\r\n - \ \"23.100.82.11/32\",\r\n \"23.101.10.141/32\",\r\n \"23.101.27.182/32\",\r\n - \ \"23.101.54.230/32\",\r\n \"23.101.63.214/32\",\r\n \"23.101.67.245/32\",\r\n - \ \"23.101.118.145/32\",\r\n \"23.101.119.44/32\",\r\n \"23.101.119.163/32\",\r\n - \ \"23.101.120.195/32\",\r\n \"23.101.125.65/32\",\r\n \"23.101.147.117/32\",\r\n - \ \"23.101.169.175/32\",\r\n \"23.101.171.94/32\",\r\n \"23.101.172.244/32\",\r\n - \ \"23.101.180.75/32\",\r\n \"23.101.203.117/32\",\r\n \"23.101.203.214/32\",\r\n - \ \"23.101.207.250/32\",\r\n \"23.101.208.52/32\",\r\n \"23.101.224.24/32\",\r\n - \ \"23.101.230.162/32\",\r\n \"23.102.12.43/32\",\r\n \"23.102.21.198/32\",\r\n - \ \"23.102.21.212/32\",\r\n \"23.102.25.149/32\",\r\n \"23.102.28.178/32\",\r\n - \ \"23.102.154.38/32\",\r\n \"23.102.161.217/32\",\r\n \"23.102.191.170/32\",\r\n - \ \"40.64.128.224/27\",\r\n \"40.67.58.192/27\",\r\n \"40.68.40.55/32\",\r\n - \ \"40.68.205.178/32\",\r\n \"40.68.208.131/32\",\r\n \"40.68.210.104/32\",\r\n - \ \"40.68.214.185/32\",\r\n \"40.69.43.225/32\",\r\n \"40.69.88.149/32\",\r\n - \ \"40.69.106.96/27\",\r\n \"40.69.190.41/32\",\r\n \"40.69.200.124/32\",\r\n - \ \"40.69.210.172/32\",\r\n \"40.69.218.150/32\",\r\n \"40.70.27.35/32\",\r\n - \ \"40.70.147.0/25\",\r\n \"40.71.0.179/32\",\r\n \"40.71.11.128/25\",\r\n - \ \"40.71.177.34/32\",\r\n \"40.71.199.117/32\",\r\n \"40.71.234.254/32\",\r\n - \ \"40.71.250.191/32\",\r\n \"40.74.100.128/27\",\r\n \"40.74.133.20/32\",\r\n - \ \"40.74.245.188/32\",\r\n \"40.74.253.108/32\",\r\n \"40.74.255.112/32\",\r\n - \ \"40.76.5.137/32\",\r\n \"40.76.192.15/32\",\r\n \"40.76.210.54/32\",\r\n - \ \"40.76.218.33/32\",\r\n \"40.76.223.101/32\",\r\n \"40.77.56.174/32\",\r\n - \ \"40.78.18.232/32\",\r\n \"40.78.25.157/32\",\r\n \"40.78.48.219/32\",\r\n - \ \"40.78.194.96/27\",\r\n \"40.78.204.160/27\",\r\n \"40.79.65.200/32\",\r\n - \ \"40.79.130.128/27\",\r\n \"40.79.154.192/27\",\r\n \"40.79.163.160/27\",\r\n - \ \"40.79.171.64/27\",\r\n \"40.79.178.96/27\",\r\n \"40.79.195.0/27\",\r\n - \ \"40.80.50.160/27\",\r\n \"40.80.58.224/27\",\r\n \"40.80.155.102/32\",\r\n - \ \"40.80.156.205/32\",\r\n \"40.80.170.224/27\",\r\n \"40.80.191.0/25\",\r\n - \ \"40.82.191.84/32\",\r\n \"40.82.217.93/32\",\r\n \"40.82.255.128/25\",\r\n - \ \"40.83.16.172/32\",\r\n \"40.83.72.59/32\",\r\n \"40.83.124.73/32\",\r\n - \ \"40.83.145.50/32\",\r\n \"40.83.150.233/32\",\r\n \"40.83.182.206/32\",\r\n - \ \"40.83.183.236/32\",\r\n \"40.83.184.25/32\",\r\n \"40.84.54.203/32\",\r\n - \ \"40.84.59.174/32\",\r\n \"40.84.148.247/32\",\r\n \"40.84.159.58/32\",\r\n - \ \"40.84.194.106/32\",\r\n \"40.84.226.176/32\",\r\n \"40.84.227.180/32\",\r\n - \ \"40.84.232.28/32\",\r\n \"40.85.74.227/32\",\r\n \"40.85.92.115/32\",\r\n - \ \"40.85.96.208/32\",\r\n \"40.85.190.10/32\",\r\n \"40.85.212.173/32\",\r\n - \ \"40.85.230.182/32\",\r\n \"40.86.86.144/32\",\r\n \"40.86.91.212/32\",\r\n - \ \"40.86.96.177/32\",\r\n \"40.86.99.202/32\",\r\n \"40.86.225.89/32\",\r\n - \ \"40.86.230.96/32\",\r\n \"40.87.65.131/32\",\r\n \"40.87.70.95/32\",\r\n - \ \"40.89.19.0/27\",\r\n \"40.89.131.148/32\",\r\n \"40.89.141.103/32\",\r\n - \ \"40.112.69.156/32\",\r\n \"40.112.90.244/32\",\r\n \"40.112.93.201/32\",\r\n - \ \"40.112.142.148/32\",\r\n \"40.112.143.134/32\",\r\n \"40.112.143.140/32\",\r\n - \ \"40.112.143.214/32\",\r\n \"40.112.165.44/32\",\r\n \"40.112.166.161/32\",\r\n - \ \"40.112.191.159/32\",\r\n \"40.112.192.69/32\",\r\n \"40.112.216.189/32\",\r\n - \ \"40.112.243.0/25\",\r\n \"40.113.2.52/32\",\r\n \"40.113.65.9/32\",\r\n - \ \"40.113.71.148/32\",\r\n \"40.113.81.82/32\",\r\n \"40.113.90.202/32\",\r\n - \ \"40.113.126.251/32\",\r\n \"40.113.131.37/32\",\r\n \"40.113.136.240/32\",\r\n - \ \"40.113.142.219/32\",\r\n \"40.113.204.88/32\",\r\n \"40.113.232.243/32\",\r\n - \ \"40.113.236.45/32\",\r\n \"40.114.13.25/32\",\r\n \"40.114.41.245/32\",\r\n - \ \"40.114.51.68/32\",\r\n \"40.114.68.21/32\",\r\n \"40.114.106.25/32\",\r\n - \ \"40.114.194.188/32\",\r\n \"40.114.210.78/32\",\r\n \"40.114.228.161/32\",\r\n - \ \"40.114.237.65/32\",\r\n \"40.114.243.70/32\",\r\n \"40.115.55.251/32\",\r\n - \ \"40.115.98.85/32\",\r\n \"40.115.179.121/32\",\r\n \"40.115.251.148/32\",\r\n - \ \"40.117.154.240/32\",\r\n \"40.117.188.126/32\",\r\n \"40.117.190.72/32\",\r\n - \ \"40.118.29.72/32\",\r\n \"40.118.71.240/32\",\r\n \"40.118.96.231/32\",\r\n - \ \"40.118.100.127/32\",\r\n \"40.118.101.67/32\",\r\n \"40.118.102.46/32\",\r\n - \ \"40.118.185.161/32\",\r\n \"40.118.235.113/32\",\r\n \"40.118.246.51/32\",\r\n - \ \"40.118.255.59/32\",\r\n \"40.119.12.0/23\",\r\n \"40.120.74.32/27\",\r\n - \ \"40.121.8.241/32\",\r\n \"40.121.16.193/32\",\r\n \"40.121.32.232/32\",\r\n - \ \"40.121.35.221/32\",\r\n \"40.121.91.199/32\",\r\n \"40.121.212.165/32\",\r\n - \ \"40.121.221.52/32\",\r\n \"40.122.36.65/32\",\r\n \"40.122.65.162/32\",\r\n - \ \"40.122.110.154/32\",\r\n \"40.122.114.229/32\",\r\n \"40.123.45.47/32\",\r\n - \ \"40.123.47.58/32\",\r\n \"40.124.12.75/32\",\r\n \"40.124.13.58/32\",\r\n - \ \"40.126.227.158/32\",\r\n \"40.126.236.22/32\",\r\n \"40.126.242.59/32\",\r\n - \ \"40.126.245.169/32\",\r\n \"40.127.132.204/32\",\r\n \"40.127.139.252/32\",\r\n - \ \"40.127.192.244/32\",\r\n \"40.127.196.56/32\",\r\n \"51.12.98.192/27\",\r\n - \ \"51.12.202.192/27\",\r\n \"51.12.226.160/27\",\r\n \"51.12.234.160/27\",\r\n - \ \"51.104.28.64/26\",\r\n \"51.105.66.160/27\",\r\n \"51.105.74.160/27\",\r\n - \ \"51.105.90.32/27\",\r\n \"51.105.172.25/32\",\r\n \"51.107.50.0/27\",\r\n - \ \"51.107.58.160/27\",\r\n \"51.107.146.0/27\",\r\n \"51.107.154.160/27\",\r\n - \ \"51.116.49.32/27\",\r\n \"51.116.58.160/27\",\r\n \"51.116.145.32/27\",\r\n - \ \"51.116.154.224/27\",\r\n \"51.116.242.160/27\",\r\n \"51.116.250.160/27\",\r\n - \ \"51.120.42.0/27\",\r\n \"51.120.98.192/27\",\r\n \"51.120.106.160/27\",\r\n - \ \"51.120.210.160/27\",\r\n \"51.120.218.192/27\",\r\n \"51.120.226.0/27\",\r\n - \ \"51.136.14.31/32\",\r\n \"51.137.106.13/32\",\r\n \"51.137.163.32/27\",\r\n - \ \"51.140.37.241/32\",\r\n \"51.140.57.176/32\",\r\n \"51.140.59.233/32\",\r\n - \ \"51.140.75.147/32\",\r\n \"51.140.84.145/32\",\r\n \"51.140.85.106/32\",\r\n - \ \"51.140.87.39/32\",\r\n \"51.140.122.226/32\",\r\n \"51.140.146.128/26\",\r\n - \ \"51.140.152.154/32\",\r\n \"51.140.153.150/32\",\r\n \"51.140.180.76/32\",\r\n - \ \"51.140.185.151/32\",\r\n \"51.140.191.223/32\",\r\n \"51.140.210.96/27\",\r\n - \ \"51.140.244.162/32\",\r\n \"51.140.245.89/32\",\r\n \"51.141.12.112/32\",\r\n - \ \"51.141.37.245/32\",\r\n \"51.141.44.139/32\",\r\n \"51.141.45.207/32\",\r\n - \ \"51.141.90.252/32\",\r\n \"51.143.102.21/32\",\r\n \"51.143.191.44/32\",\r\n - \ \"51.144.7.192/32\",\r\n \"51.144.107.53/32\",\r\n \"51.144.116.43/32\",\r\n - \ \"51.144.164.215/32\",\r\n \"51.144.182.8/32\",\r\n \"52.136.50.0/27\",\r\n - \ \"52.136.138.55/32\",\r\n \"52.138.196.70/32\",\r\n \"52.138.218.121/32\",\r\n - \ \"52.140.106.224/27\",\r\n \"52.143.137.150/32\",\r\n \"52.150.140.224/27\",\r\n - \ \"52.151.62.51/32\",\r\n \"52.160.40.218/32\",\r\n \"52.161.96.193/32\",\r\n - \ \"52.162.107.0/25\",\r\n \"52.162.208.73/32\",\r\n \"52.163.122.160/32\",\r\n - \ \"52.164.201.186/32\",\r\n \"52.164.250.133/32\",\r\n \"52.165.129.203/32\",\r\n - \ \"52.165.135.234/32\",\r\n \"52.165.155.12/32\",\r\n \"52.165.155.237/32\",\r\n - \ \"52.165.163.223/32\",\r\n \"52.165.168.40/32\",\r\n \"52.165.174.123/32\",\r\n - \ \"52.165.184.170/32\",\r\n \"52.165.220.33/32\",\r\n \"52.165.224.81/32\",\r\n - \ \"52.165.237.15/32\",\r\n \"52.166.78.97/32\",\r\n \"52.166.113.188/32\",\r\n - \ \"52.166.119.99/32\",\r\n \"52.166.178.208/32\",\r\n \"52.166.181.85/32\",\r\n - \ \"52.166.198.163/32\",\r\n \"52.168.125.188/32\",\r\n \"52.169.73.236/32\",\r\n - \ \"52.169.78.163/32\",\r\n \"52.169.180.223/32\",\r\n \"52.169.184.163/32\",\r\n - \ \"52.169.188.236/32\",\r\n \"52.169.191.40/32\",\r\n \"52.170.7.25/32\",\r\n - \ \"52.170.46.174/32\",\r\n \"52.171.56.101/32\",\r\n \"52.171.56.110/32\",\r\n - \ \"52.171.136.200/32\",\r\n \"52.171.140.237/32\",\r\n \"52.171.218.239/32\",\r\n - \ \"52.171.221.170/32\",\r\n \"52.171.222.247/32\",\r\n \"52.172.54.225/32\",\r\n - \ \"52.172.195.80/32\",\r\n \"52.172.204.196/32\",\r\n \"52.172.219.121/32\",\r\n - \ \"52.173.28.95/32\",\r\n \"52.173.36.83/32\",\r\n \"52.173.76.33/32\",\r\n - \ \"52.173.77.140/32\",\r\n \"52.173.83.49/32\",\r\n \"52.173.84.157/32\",\r\n - \ \"52.173.87.130/32\",\r\n \"52.173.94.173/32\",\r\n \"52.173.134.115/32\",\r\n - \ \"52.173.139.99/32\",\r\n \"52.173.139.125/32\",\r\n \"52.173.149.254/32\",\r\n - \ \"52.173.151.229/32\",\r\n \"52.173.184.147/32\",\r\n \"52.173.245.249/32\",\r\n - \ \"52.173.249.137/32\",\r\n \"52.174.3.80/32\",\r\n \"52.174.7.133/32\",\r\n - \ \"52.174.35.5/32\",\r\n \"52.174.106.15/32\",\r\n \"52.174.150.25/32\",\r\n - \ \"52.174.181.178/32\",\r\n \"52.174.184.18/32\",\r\n \"52.174.193.210/32\",\r\n - \ \"52.174.235.29/32\",\r\n \"52.175.158.219/32\",\r\n \"52.175.202.25/32\",\r\n - \ \"52.175.254.10/32\",\r\n \"52.176.2.229/32\",\r\n \"52.176.5.241/32\",\r\n - \ \"52.176.6.0/32\",\r\n \"52.176.6.37/32\",\r\n \"52.176.61.128/32\",\r\n - \ \"52.176.104.120/32\",\r\n \"52.176.149.197/32\",\r\n \"52.176.165.69/32\",\r\n - \ \"52.177.169.150/32\",\r\n \"52.177.189.138/32\",\r\n \"52.177.206.73/32\",\r\n - \ \"52.178.29.39/32\",\r\n \"52.178.37.244/32\",\r\n \"52.178.43.209/32\",\r\n - \ \"52.178.45.139/32\",\r\n \"52.178.46.181/32\",\r\n \"52.178.75.200/32\",\r\n - \ \"52.178.79.163/32\",\r\n \"52.178.89.129/32\",\r\n \"52.178.90.230/32\",\r\n - \ \"52.178.92.96/32\",\r\n \"52.178.105.179/32\",\r\n \"52.178.114.226/32\",\r\n - \ \"52.178.158.175/32\",\r\n \"52.178.164.235/32\",\r\n \"52.178.179.169/32\",\r\n - \ \"52.178.190.191/32\",\r\n \"52.178.201.147/32\",\r\n \"52.178.208.12/32\",\r\n - \ \"52.178.212.17/32\",\r\n \"52.178.214.89/32\",\r\n \"52.179.97.15/32\",\r\n - \ \"52.179.188.206/32\",\r\n \"52.180.178.6/32\",\r\n \"52.180.183.66/32\",\r\n - \ \"52.183.82.125/32\",\r\n \"52.184.162.135/32\",\r\n \"52.184.193.103/32\",\r\n - \ \"52.184.193.104/32\",\r\n \"52.187.17.126/32\",\r\n \"52.187.36.104/32\",\r\n - \ \"52.187.52.94/32\",\r\n \"52.187.135.79/32\",\r\n \"52.187.206.243/32\",\r\n - \ \"52.187.229.23/32\",\r\n \"52.189.213.49/32\",\r\n \"52.225.179.39/32\",\r\n - \ \"52.225.190.65/32\",\r\n \"52.226.134.64/32\",\r\n \"52.228.42.76/32\",\r\n - \ \"52.228.84.32/27\",\r\n \"52.228.121.123/32\",\r\n \"52.229.30.210/32\",\r\n - \ \"52.229.115.84/32\",\r\n \"52.230.1.186/32\",\r\n \"52.231.18.128/27\",\r\n - \ \"52.231.32.120/32\",\r\n \"52.231.38.95/32\",\r\n \"52.231.77.58/32\",\r\n - \ \"52.231.146.96/27\",\r\n \"52.231.200.101/32\",\r\n \"52.231.200.179/32\",\r\n - \ \"52.232.19.237/32\",\r\n \"52.232.26.228/32\",\r\n \"52.232.33.202/32\",\r\n - \ \"52.232.56.79/32\",\r\n \"52.232.127.196/32\",\r\n \"52.233.38.143/32\",\r\n - \ \"52.233.128.61/32\",\r\n \"52.233.133.18/32\",\r\n \"52.233.133.121/32\",\r\n - \ \"52.233.155.168/32\",\r\n \"52.233.164.195/32\",\r\n \"52.233.175.59/32\",\r\n - \ \"52.233.184.181/32\",\r\n \"52.233.198.206/32\",\r\n \"52.234.209.94/32\",\r\n - \ \"52.237.18.220/32\",\r\n \"52.237.22.139/32\",\r\n \"52.237.130.0/32\",\r\n - \ \"52.237.205.163/32\",\r\n \"52.237.214.221/32\",\r\n \"52.237.246.162/32\",\r\n - \ \"52.240.149.243/32\",\r\n \"52.240.155.58/32\",\r\n \"52.242.22.213/32\",\r\n - \ \"52.242.27.213/32\",\r\n \"52.243.39.89/32\",\r\n \"52.246.154.160/27\",\r\n - \ \"52.252.160.21/32\",\r\n \"52.253.224.223/32\",\r\n \"52.255.35.249/32\",\r\n - \ \"52.255.54.134/32\",\r\n \"65.52.24.41/32\",\r\n \"65.52.128.33/32\",\r\n - \ \"65.52.130.1/32\",\r\n \"65.52.160.119/32\",\r\n \"65.52.168.70/32\",\r\n - \ \"65.52.213.73/32\",\r\n \"65.52.217.59/32\",\r\n \"65.52.218.253/32\",\r\n - \ \"65.52.250.96/27\",\r\n \"94.245.104.73/32\",\r\n \"102.133.26.32/27\",\r\n - \ \"102.133.57.128/27\",\r\n \"102.133.122.160/27\",\r\n - \ \"102.133.154.32/27\",\r\n \"102.133.218.32/28\",\r\n \"102.133.250.160/27\",\r\n - \ \"104.40.3.53/32\",\r\n \"104.40.11.192/32\",\r\n \"104.40.28.133/32\",\r\n - \ \"104.40.53.219/32\",\r\n \"104.40.63.98/32\",\r\n \"104.40.84.133/32\",\r\n - \ \"104.40.92.107/32\",\r\n \"104.40.129.89/32\",\r\n \"104.40.147.180/32\",\r\n - \ \"104.40.147.216/32\",\r\n \"104.40.158.55/32\",\r\n \"104.40.179.243/32\",\r\n - \ \"104.40.183.236/32\",\r\n \"104.40.185.192/32\",\r\n \"104.40.187.26/32\",\r\n - \ \"104.40.191.174/32\",\r\n \"104.40.210.25/32\",\r\n \"104.40.215.219/32\",\r\n - \ \"104.40.222.81/32\",\r\n \"104.40.250.100/32\",\r\n \"104.41.9.139/32\",\r\n - \ \"104.41.13.179/32\",\r\n \"104.41.63.108/32\",\r\n \"104.41.186.103/32\",\r\n - \ \"104.41.216.137/32\",\r\n \"104.41.229.199/32\",\r\n \"104.42.53.248/32\",\r\n - \ \"104.42.78.153/32\",\r\n \"104.42.128.171/32\",\r\n \"104.42.148.55/32\",\r\n - \ \"104.42.152.64/32\",\r\n \"104.42.154.105/32\",\r\n \"104.42.188.146/32\",\r\n - \ \"104.42.231.5/32\",\r\n \"104.43.129.105/32\",\r\n \"104.43.140.101/32\",\r\n - \ \"104.43.142.33/32\",\r\n \"104.43.221.31/32\",\r\n \"104.43.246.71/32\",\r\n - \ \"104.43.254.102/32\",\r\n \"104.44.128.13/32\",\r\n \"104.44.130.38/32\",\r\n - \ \"104.45.1.117/32\",\r\n \"104.45.14.249/32\",\r\n \"104.45.81.79/32\",\r\n - \ \"104.45.95.61/32\",\r\n \"104.45.129.178/32\",\r\n \"104.45.141.247/32\",\r\n - \ \"104.45.152.13/32\",\r\n \"104.45.152.60/32\",\r\n \"104.45.154.200/32\",\r\n - \ \"104.45.226.98/32\",\r\n \"104.45.231.79/32\",\r\n \"104.46.38.245/32\",\r\n - \ \"104.46.44.78/32\",\r\n \"104.46.61.116/32\",\r\n \"104.46.101.59/32\",\r\n - \ \"104.47.137.62/32\",\r\n \"104.47.151.115/32\",\r\n \"104.47.160.14/32\",\r\n - \ \"104.47.164.119/32\",\r\n \"104.208.48.107/32\",\r\n \"104.209.178.67/32\",\r\n - \ \"104.209.192.206/32\",\r\n \"104.209.197.87/32\",\r\n - \ \"104.210.38.149/32\",\r\n \"104.210.69.241/32\",\r\n \"104.210.92.71/32\",\r\n - \ \"104.210.145.181/32\",\r\n \"104.210.147.57/32\",\r\n - \ \"104.210.152.76/32\",\r\n \"104.210.152.122/32\",\r\n - \ \"104.210.153.116/32\",\r\n \"104.210.158.20/32\",\r\n - \ \"104.211.26.212/32\",\r\n \"104.211.81.32/27\",\r\n \"104.211.97.138/32\",\r\n - \ \"104.211.146.96/27\",\r\n \"104.211.160.159/32\",\r\n - \ \"104.211.179.11/32\",\r\n \"104.211.184.197/32\",\r\n - \ \"104.211.224.252/32\",\r\n \"104.211.225.167/32\",\r\n - \ \"104.214.20.0/23\",\r\n \"104.214.29.203/32\",\r\n \"104.214.64.238/32\",\r\n - \ \"104.214.74.110/32\",\r\n \"104.214.77.221/32\",\r\n \"104.214.110.60/32\",\r\n - \ \"104.214.110.226/32\",\r\n \"104.214.118.174/32\",\r\n - \ \"104.214.119.36/32\",\r\n \"104.214.137.236/32\",\r\n - \ \"104.214.231.110/32\",\r\n \"104.214.236.47/32\",\r\n - \ \"104.214.237.135/32\",\r\n \"104.215.11.176/32\",\r\n - \ \"104.215.58.230/32\",\r\n \"104.215.73.236/32\",\r\n \"104.215.78.13/32\",\r\n - \ \"104.215.89.22/32\",\r\n \"104.215.147.45/32\",\r\n \"104.215.155.1/32\",\r\n - \ \"111.221.95.27/32\",\r\n \"137.116.78.243/32\",\r\n \"137.116.88.213/32\",\r\n - \ \"137.116.128.188/32\",\r\n \"137.116.153.238/32\",\r\n - \ \"137.117.9.212/32\",\r\n \"137.117.17.70/32\",\r\n \"137.117.58.204/32\",\r\n - \ \"137.117.66.167/32\",\r\n \"137.117.84.54/32\",\r\n \"137.117.90.63/32\",\r\n - \ \"137.117.93.87/32\",\r\n \"137.117.166.35/32\",\r\n \"137.117.175.14/32\",\r\n - \ \"137.117.203.130/32\",\r\n \"137.117.211.244/32\",\r\n - \ \"137.117.218.101/32\",\r\n \"137.117.224.218/32\",\r\n - \ \"137.117.225.87/32\",\r\n \"137.135.91.176/32\",\r\n \"137.135.107.235/32\",\r\n - \ \"137.135.129.175/32\",\r\n \"137.135.133.221/32\",\r\n - \ \"138.91.0.30/32\",\r\n \"138.91.16.18/32\",\r\n \"138.91.224.84/32\",\r\n - \ \"138.91.225.40/32\",\r\n \"138.91.240.81/32\",\r\n \"157.56.13.114/32\",\r\n - \ \"168.61.152.29/32\",\r\n \"168.61.159.114/32\",\r\n \"168.61.217.214/32\",\r\n - \ \"168.61.218.125/32\",\r\n \"168.62.20.37/32\",\r\n \"168.62.48.183/32\",\r\n - \ \"168.62.180.173/32\",\r\n \"168.62.224.13/32\",\r\n \"168.62.225.23/32\",\r\n - \ \"168.63.5.231/32\",\r\n \"168.63.53.239/32\",\r\n \"168.63.107.5/32\",\r\n - \ \"191.232.38.77/32\",\r\n \"191.232.176.16/32\",\r\n \"191.233.50.32/27\",\r\n - \ \"191.233.82.44/32\",\r\n \"191.233.85.165/32\",\r\n \"191.233.87.194/32\",\r\n - \ \"191.233.203.32/27\",\r\n \"191.234.16.188/32\",\r\n \"191.234.146.160/27\",\r\n - \ \"191.234.154.160/27\",\r\n \"191.235.81.73/32\",\r\n \"191.235.90.70/32\",\r\n - \ \"191.235.160.13/32\",\r\n \"191.235.176.12/32\",\r\n \"191.235.177.30/32\",\r\n - \ \"191.235.208.12/32\",\r\n \"191.235.215.184/32\",\r\n - \ \"191.235.228.32/27\",\r\n \"191.236.16.12/32\",\r\n \"191.236.59.67/32\",\r\n - \ \"191.236.80.12/32\",\r\n \"191.236.106.123/32\",\r\n \"191.236.148.9/32\",\r\n - \ \"191.236.192.121/32\",\r\n \"191.237.24.89/32\",\r\n \"191.237.27.74/32\",\r\n - \ \"191.237.128.238/32\",\r\n \"191.238.8.26/32\",\r\n \"191.238.33.50/32\",\r\n - \ \"191.238.176.139/32\",\r\n \"191.238.240.12/32\",\r\n - \ \"191.239.58.162/32\",\r\n \"191.239.188.11/32\",\r\n \"207.46.144.49/32\",\r\n - \ \"207.46.147.148/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.AustraliaCentral\",\r\n \"id\": \"AppService.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.36.43.207/32\",\r\n \"20.36.106.96/27\",\r\n - \ \"20.37.226.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.AustraliaCentral2\",\r\n \"id\": \"AppService.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.36.72.230/32\",\r\n \"20.36.117.0/27\",\r\n \"20.36.122.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaEast\",\r\n - \ \"id\": \"AppService.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.70.72.32/27\",\r\n \"13.70.123.149/32\",\r\n - \ \"13.75.138.224/32\",\r\n \"13.75.147.143/32\",\r\n \"13.75.147.201/32\",\r\n - \ \"13.75.218.45/32\",\r\n \"20.37.196.192/27\",\r\n \"23.101.208.52/32\",\r\n - \ \"40.79.163.160/27\",\r\n \"40.79.171.64/27\",\r\n \"40.82.217.93/32\",\r\n - \ \"40.126.227.158/32\",\r\n \"40.126.236.22/32\",\r\n \"40.126.242.59/32\",\r\n - \ \"40.126.245.169/32\",\r\n \"52.187.206.243/32\",\r\n \"52.187.229.23/32\",\r\n - \ \"52.237.205.163/32\",\r\n \"52.237.214.221/32\",\r\n \"52.237.246.162/32\",\r\n - \ \"104.210.69.241/32\",\r\n \"104.210.92.71/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaSoutheast\",\r\n - \ \"id\": \"AppService.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.70.146.110/32\",\r\n \"13.70.147.206/32\",\r\n - \ \"13.73.116.45/32\",\r\n \"13.73.118.104/32\",\r\n \"13.77.7.175/32\",\r\n - \ \"13.77.50.96/27\",\r\n \"20.42.228.160/27\",\r\n \"23.101.224.24/32\",\r\n - \ \"23.101.230.162/32\",\r\n \"52.189.213.49/32\",\r\n \"52.255.35.249/32\",\r\n - \ \"52.255.54.134/32\",\r\n \"191.239.188.11/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.BrazilSouth\",\r\n - \ \"id\": \"AppService.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"23.97.96.32/32\",\r\n - \ \"104.41.9.139/32\",\r\n \"104.41.13.179/32\",\r\n \"104.41.63.108/32\",\r\n - \ \"191.232.38.77/32\",\r\n \"191.232.176.16/32\",\r\n \"191.233.203.32/27\",\r\n - \ \"191.234.146.160/27\",\r\n \"191.234.154.160/27\",\r\n - \ \"191.235.81.73/32\",\r\n \"191.235.90.70/32\",\r\n \"191.235.228.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.CanadaCentral\",\r\n - \ \"id\": \"AppService.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.71.170.128/27\",\r\n \"20.38.146.160/27\",\r\n - \ \"40.82.191.84/32\",\r\n \"40.85.212.173/32\",\r\n \"40.85.230.182/32\",\r\n - \ \"52.228.42.76/32\",\r\n \"52.228.84.32/27\",\r\n \"52.228.121.123/32\",\r\n - \ \"52.233.38.143/32\",\r\n \"52.237.18.220/32\",\r\n \"52.237.22.139/32\",\r\n - \ \"52.246.154.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.CanadaEast\",\r\n \"id\": \"AppService.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"40.69.106.96/27\",\r\n \"40.86.225.89/32\",\r\n - \ \"40.86.230.96/32\",\r\n \"40.89.19.0/27\",\r\n \"52.229.115.84/32\",\r\n - \ \"52.242.22.213/32\",\r\n \"52.242.27.213/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.CentralIndia\",\r\n - \ \"id\": \"AppService.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.192.98.160/27\",\r\n \"40.80.50.160/27\",\r\n - \ \"52.140.106.224/27\",\r\n \"52.172.195.80/32\",\r\n \"52.172.204.196/32\",\r\n - \ \"52.172.219.121/32\",\r\n \"104.211.81.32/27\",\r\n \"104.211.97.138/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.CentralUS\",\r\n - \ \"id\": \"AppService.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.67.129.26/32\",\r\n - \ \"13.67.141.98/32\",\r\n \"13.89.57.7/32\",\r\n \"13.89.172.0/23\",\r\n - \ \"13.89.238.239/32\",\r\n \"20.40.202.0/23\",\r\n \"23.99.128.52/32\",\r\n - \ \"23.99.183.149/32\",\r\n \"23.99.192.132/32\",\r\n \"23.99.196.180/32\",\r\n - \ \"23.99.206.151/32\",\r\n \"23.99.224.56/32\",\r\n \"23.100.82.11/32\",\r\n - \ \"23.101.118.145/32\",\r\n \"23.101.119.44/32\",\r\n \"23.101.119.163/32\",\r\n - \ \"23.101.120.195/32\",\r\n \"23.101.125.65/32\",\r\n \"40.69.190.41/32\",\r\n - \ \"40.77.56.174/32\",\r\n \"40.83.16.172/32\",\r\n \"40.86.86.144/32\",\r\n - \ \"40.86.91.212/32\",\r\n \"40.86.96.177/32\",\r\n \"40.86.99.202/32\",\r\n - \ \"40.113.204.88/32\",\r\n \"40.113.232.243/32\",\r\n \"40.113.236.45/32\",\r\n - \ \"40.122.36.65/32\",\r\n \"40.122.65.162/32\",\r\n \"40.122.110.154/32\",\r\n - \ \"40.122.114.229/32\",\r\n \"52.165.129.203/32\",\r\n \"52.165.135.234/32\",\r\n - \ \"52.165.155.12/32\",\r\n \"52.165.155.237/32\",\r\n \"52.165.163.223/32\",\r\n - \ \"52.165.168.40/32\",\r\n \"52.165.174.123/32\",\r\n \"52.165.184.170/32\",\r\n - \ \"52.165.220.33/32\",\r\n \"52.165.224.81/32\",\r\n \"52.165.237.15/32\",\r\n - \ \"52.173.28.95/32\",\r\n \"52.173.36.83/32\",\r\n \"52.173.76.33/32\",\r\n - \ \"52.173.77.140/32\",\r\n \"52.173.83.49/32\",\r\n \"52.173.84.157/32\",\r\n - \ \"52.173.87.130/32\",\r\n \"52.173.94.173/32\",\r\n \"52.173.134.115/32\",\r\n - \ \"52.173.139.99/32\",\r\n \"52.173.139.125/32\",\r\n \"52.173.149.254/32\",\r\n - \ \"52.173.151.229/32\",\r\n \"52.173.184.147/32\",\r\n \"52.173.245.249/32\",\r\n - \ \"52.173.249.137/32\",\r\n \"52.176.2.229/32\",\r\n \"52.176.5.241/32\",\r\n - \ \"52.176.6.0/32\",\r\n \"52.176.6.37/32\",\r\n \"52.176.61.128/32\",\r\n - \ \"52.176.104.120/32\",\r\n \"52.176.149.197/32\",\r\n \"52.176.165.69/32\",\r\n - \ \"104.43.129.105/32\",\r\n \"104.43.140.101/32\",\r\n \"104.43.142.33/32\",\r\n - \ \"104.43.221.31/32\",\r\n \"104.43.246.71/32\",\r\n \"104.43.254.102/32\",\r\n - \ \"168.61.152.29/32\",\r\n \"168.61.159.114/32\",\r\n \"168.61.217.214/32\",\r\n - \ \"168.61.218.125/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.CentralUSEUAP\",\r\n \"id\": \"AppService.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.45.196.16/29\",\r\n \"40.78.204.160/27\",\r\n - \ \"52.180.178.6/32\",\r\n \"52.180.183.66/32\",\r\n \"104.208.48.107/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.EastAsia\",\r\n - \ \"id\": \"AppService.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.75.34.160/27\",\r\n - \ \"13.75.46.26/32\",\r\n \"13.75.47.15/32\",\r\n \"13.75.89.224/32\",\r\n - \ \"13.75.112.108/32\",\r\n \"13.75.115.40/32\",\r\n \"13.94.47.87/32\",\r\n - \ \"20.189.104.96/27\",\r\n \"20.189.109.96/27\",\r\n \"20.189.112.66/32\",\r\n - \ \"23.97.79.119/32\",\r\n \"23.99.110.192/32\",\r\n \"23.99.116.70/32\",\r\n - \ \"23.101.10.141/32\",\r\n \"40.83.72.59/32\",\r\n \"40.83.124.73/32\",\r\n - \ \"65.52.160.119/32\",\r\n \"65.52.168.70/32\",\r\n \"191.234.16.188/32\",\r\n - \ \"207.46.144.49/32\",\r\n \"207.46.147.148/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.EastUS\",\r\n \"id\": - \"AppService.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.82.93.245/32\",\r\n - \ \"13.82.101.179/32\",\r\n \"13.82.175.96/32\",\r\n \"13.90.143.69/32\",\r\n - \ \"13.90.213.204/32\",\r\n \"13.92.139.214/32\",\r\n \"13.92.193.110/32\",\r\n - \ \"13.92.237.218/32\",\r\n \"20.42.26.252/32\",\r\n \"20.49.104.0/25\",\r\n - \ \"23.96.0.52/32\",\r\n \"23.96.1.109/32\",\r\n \"23.96.13.243/32\",\r\n - \ \"23.96.32.128/32\",\r\n \"23.96.96.142/32\",\r\n \"23.96.103.159/32\",\r\n - \ \"23.96.112.53/32\",\r\n \"23.96.113.128/32\",\r\n \"23.96.124.25/32\",\r\n - \ \"40.71.0.179/32\",\r\n \"40.71.11.128/25\",\r\n \"40.71.177.34/32\",\r\n - \ \"40.71.199.117/32\",\r\n \"40.71.234.254/32\",\r\n \"40.71.250.191/32\",\r\n - \ \"40.76.5.137/32\",\r\n \"40.76.192.15/32\",\r\n \"40.76.210.54/32\",\r\n - \ \"40.76.218.33/32\",\r\n \"40.76.223.101/32\",\r\n \"40.79.154.192/27\",\r\n - \ \"40.85.190.10/32\",\r\n \"40.87.65.131/32\",\r\n \"40.87.70.95/32\",\r\n - \ \"40.114.13.25/32\",\r\n \"40.114.41.245/32\",\r\n \"40.114.51.68/32\",\r\n - \ \"40.114.68.21/32\",\r\n \"40.114.106.25/32\",\r\n \"40.117.154.240/32\",\r\n - \ \"40.117.188.126/32\",\r\n \"40.117.190.72/32\",\r\n \"40.121.8.241/32\",\r\n - \ \"40.121.16.193/32\",\r\n \"40.121.32.232/32\",\r\n \"40.121.35.221/32\",\r\n - \ \"40.121.91.199/32\",\r\n \"40.121.212.165/32\",\r\n \"40.121.221.52/32\",\r\n - \ \"52.168.125.188/32\",\r\n \"52.170.7.25/32\",\r\n \"52.170.46.174/32\",\r\n - \ \"52.179.97.15/32\",\r\n \"52.226.134.64/32\",\r\n \"52.234.209.94/32\",\r\n - \ \"104.45.129.178/32\",\r\n \"104.45.141.247/32\",\r\n \"104.45.152.13/32\",\r\n - \ \"104.45.152.60/32\",\r\n \"104.45.154.200/32\",\r\n \"104.211.26.212/32\",\r\n - \ \"137.117.58.204/32\",\r\n \"137.117.66.167/32\",\r\n \"137.117.84.54/32\",\r\n - \ \"137.117.90.63/32\",\r\n \"137.117.93.87/32\",\r\n \"137.135.91.176/32\",\r\n - \ \"137.135.107.235/32\",\r\n \"168.62.48.183/32\",\r\n \"168.62.180.173/32\",\r\n - \ \"191.236.16.12/32\",\r\n \"191.236.59.67/32\",\r\n \"191.237.24.89/32\",\r\n - \ \"191.237.27.74/32\",\r\n \"191.238.8.26/32\",\r\n \"191.238.33.50/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.EastUS2\",\r\n - \ \"id\": \"AppService.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.68.29.136/32\",\r\n - \ \"13.68.101.62/32\",\r\n \"13.77.82.141/32\",\r\n \"13.77.83.246/32\",\r\n - \ \"13.77.96.119/32\",\r\n \"20.49.97.0/25\",\r\n \"23.101.147.117/32\",\r\n - \ \"40.70.27.35/32\",\r\n \"40.70.147.0/25\",\r\n \"40.79.65.200/32\",\r\n - \ \"40.84.54.203/32\",\r\n \"40.84.59.174/32\",\r\n \"40.123.45.47/32\",\r\n - \ \"40.123.47.58/32\",\r\n \"52.177.169.150/32\",\r\n \"52.177.189.138/32\",\r\n - \ \"52.177.206.73/32\",\r\n \"52.179.188.206/32\",\r\n \"52.184.162.135/32\",\r\n - \ \"52.184.193.103/32\",\r\n \"52.184.193.104/32\",\r\n \"104.46.101.59/32\",\r\n - \ \"104.209.178.67/32\",\r\n \"104.209.192.206/32\",\r\n - \ \"104.209.197.87/32\",\r\n \"137.116.78.243/32\",\r\n \"137.116.88.213/32\",\r\n - \ \"191.236.192.121/32\",\r\n \"191.237.128.238/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.EastUS2EUAP\",\r\n - \ \"id\": \"AppService.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.39.11.104/29\",\r\n - \ \"52.225.179.39/32\",\r\n \"52.225.190.65/32\",\r\n \"52.253.224.223/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.FranceCentral\",\r\n - \ \"id\": \"AppService.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.43.43.32/27\",\r\n \"40.79.130.128/27\",\r\n - \ \"40.89.131.148/32\",\r\n \"40.89.141.103/32\",\r\n \"52.143.137.150/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.FranceSouth\",\r\n - \ \"id\": \"AppService.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"40.79.178.96/27\",\r\n - \ \"51.105.90.32/27\",\r\n \"52.136.138.55/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.GermanyNorth\",\r\n - \ \"id\": \"AppService.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"51.116.49.32/27\",\r\n \"51.116.58.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.GermanyWestCentral\",\r\n - \ \"id\": \"AppService.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"51.116.145.32/27\",\r\n \"51.116.154.224/27\",\r\n - \ \"51.116.242.160/27\",\r\n \"51.116.250.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.JapanEast\",\r\n - \ \"id\": \"AppService.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.71.149.151/32\",\r\n - \ \"13.73.1.134/32\",\r\n \"13.73.26.73/32\",\r\n \"13.78.59.237/32\",\r\n - \ \"13.78.106.96/27\",\r\n \"13.78.117.86/32\",\r\n \"13.78.123.87/32\",\r\n - \ \"20.43.67.32/27\",\r\n \"40.79.195.0/27\",\r\n \"40.115.179.121/32\",\r\n - \ \"40.115.251.148/32\",\r\n \"52.243.39.89/32\",\r\n \"104.41.186.103/32\",\r\n - \ \"138.91.0.30/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.JapanWest\",\r\n \"id\": \"AppService.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.128/27\",\r\n \"40.74.133.20/32\",\r\n - \ \"40.80.58.224/27\",\r\n \"52.175.158.219/32\",\r\n \"104.214.137.236/32\",\r\n - \ \"104.215.11.176/32\",\r\n \"104.215.58.230/32\",\r\n \"138.91.16.18/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.KoreaCentral\",\r\n - \ \"id\": \"AppService.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.41.66.224/27\",\r\n \"20.44.26.160/27\",\r\n - \ \"20.194.66.32/27\",\r\n \"52.231.18.128/27\",\r\n \"52.231.32.120/32\",\r\n - \ \"52.231.38.95/32\",\r\n \"52.231.77.58/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.KoreaSouth\",\r\n - \ \"id\": \"AppService.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"40.80.170.224/27\",\r\n - \ \"52.231.146.96/27\",\r\n \"52.231.200.101/32\",\r\n \"52.231.200.179/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.NorthCentralUS\",\r\n - \ \"id\": \"AppService.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"23.96.187.5/32\",\r\n \"23.96.201.21/32\",\r\n \"23.96.207.177/32\",\r\n - \ \"23.96.209.155/32\",\r\n \"23.96.220.116/32\",\r\n \"23.100.72.240/32\",\r\n - \ \"23.101.169.175/32\",\r\n \"23.101.171.94/32\",\r\n \"23.101.172.244/32\",\r\n - \ \"40.80.191.0/25\",\r\n \"52.162.107.0/25\",\r\n \"52.162.208.73/32\",\r\n - \ \"52.237.130.0/32\",\r\n \"52.240.149.243/32\",\r\n \"52.240.155.58/32\",\r\n - \ \"52.252.160.21/32\",\r\n \"65.52.24.41/32\",\r\n \"65.52.213.73/32\",\r\n - \ \"65.52.217.59/32\",\r\n \"65.52.218.253/32\",\r\n \"157.56.13.114/32\",\r\n - \ \"168.62.224.13/32\",\r\n \"168.62.225.23/32\",\r\n \"191.236.148.9/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.NorthEurope\",\r\n - \ \"id\": \"AppService.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.69.186.152/32\",\r\n - \ \"13.69.228.0/25\",\r\n \"13.69.253.145/32\",\r\n \"13.74.41.233/32\",\r\n - \ \"13.74.147.218/32\",\r\n \"13.74.158.5/32\",\r\n \"13.74.252.44/32\",\r\n - \ \"13.79.2.71/32\",\r\n \"13.79.38.229/32\",\r\n \"13.79.172.40/32\",\r\n - \ \"20.50.64.0/25\",\r\n \"23.100.48.106/32\",\r\n \"23.100.50.51/32\",\r\n - \ \"23.100.52.22/32\",\r\n \"23.100.56.27/32\",\r\n \"23.101.54.230/32\",\r\n - \ \"23.101.63.214/32\",\r\n \"23.102.12.43/32\",\r\n \"23.102.21.198/32\",\r\n - \ \"23.102.21.212/32\",\r\n \"23.102.25.149/32\",\r\n \"23.102.28.178/32\",\r\n - \ \"40.69.43.225/32\",\r\n \"40.69.88.149/32\",\r\n \"40.69.200.124/32\",\r\n - \ \"40.69.210.172/32\",\r\n \"40.69.218.150/32\",\r\n \"40.85.74.227/32\",\r\n - \ \"40.85.92.115/32\",\r\n \"40.85.96.208/32\",\r\n \"40.112.69.156/32\",\r\n - \ \"40.112.90.244/32\",\r\n \"40.112.93.201/32\",\r\n \"40.113.2.52/32\",\r\n - \ \"40.113.65.9/32\",\r\n \"40.113.71.148/32\",\r\n \"40.113.81.82/32\",\r\n - \ \"40.113.90.202/32\",\r\n \"40.115.98.85/32\",\r\n \"40.127.132.204/32\",\r\n - \ \"40.127.139.252/32\",\r\n \"40.127.192.244/32\",\r\n \"40.127.196.56/32\",\r\n - \ \"52.138.196.70/32\",\r\n \"52.138.218.121/32\",\r\n \"52.164.201.186/32\",\r\n - \ \"52.164.250.133/32\",\r\n \"52.169.73.236/32\",\r\n \"52.169.78.163/32\",\r\n - \ \"52.169.180.223/32\",\r\n \"52.169.184.163/32\",\r\n \"52.169.188.236/32\",\r\n - \ \"52.169.191.40/32\",\r\n \"52.178.158.175/32\",\r\n \"52.178.164.235/32\",\r\n - \ \"52.178.179.169/32\",\r\n \"52.178.190.191/32\",\r\n \"52.178.201.147/32\",\r\n - \ \"52.178.208.12/32\",\r\n \"52.178.212.17/32\",\r\n \"52.178.214.89/32\",\r\n - \ \"94.245.104.73/32\",\r\n \"104.41.216.137/32\",\r\n \"104.41.229.199/32\",\r\n - \ \"104.45.81.79/32\",\r\n \"104.45.95.61/32\",\r\n \"137.135.129.175/32\",\r\n - \ \"137.135.133.221/32\",\r\n \"168.63.53.239/32\",\r\n \"191.235.160.13/32\",\r\n - \ \"191.235.176.12/32\",\r\n \"191.235.177.30/32\",\r\n \"191.235.208.12/32\",\r\n - \ \"191.235.215.184/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.NorwayEast\",\r\n \"id\": \"AppService.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"51.120.42.0/27\",\r\n \"51.120.98.192/27\",\r\n - \ \"51.120.106.160/27\",\r\n \"51.120.210.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.NorwayWest\",\r\n - \ \"id\": \"AppService.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.192/27\",\r\n - \ \"51.120.226.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.SouthAfricaNorth\",\r\n \"id\": \"AppService.SouthAfricaNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"102.133.122.160/27\",\r\n \"102.133.154.32/27\",\r\n - \ \"102.133.218.32/28\",\r\n \"102.133.250.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.SouthAfricaWest\",\r\n - \ \"id\": \"AppService.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"102.133.26.32/27\",\r\n \"102.133.57.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.SouthCentralUS\",\r\n - \ \"id\": \"AppService.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.65.30.245/32\",\r\n \"13.65.37.122/32\",\r\n - \ \"13.65.39.165/32\",\r\n \"13.65.42.35/32\",\r\n \"13.65.42.183/32\",\r\n - \ \"13.65.45.30/32\",\r\n \"13.65.85.146/32\",\r\n \"13.65.89.91/32\",\r\n - \ \"13.65.92.72/32\",\r\n \"13.65.94.204/32\",\r\n \"13.65.95.109/32\",\r\n - \ \"13.65.97.243/32\",\r\n \"13.65.193.29/32\",\r\n \"13.65.210.166/32\",\r\n - \ \"13.65.212.252/32\",\r\n \"13.65.241.130/32\",\r\n \"13.65.243.110/32\",\r\n - \ \"13.66.16.101/32\",\r\n \"13.66.38.99/32\",\r\n \"13.66.39.88/32\",\r\n - \ \"13.84.36.2/32\",\r\n \"13.84.40.227/32\",\r\n \"13.84.42.35/32\",\r\n - \ \"13.84.46.29/32\",\r\n \"13.84.55.137/32\",\r\n \"13.84.146.60/32\",\r\n - \ \"13.84.180.32/32\",\r\n \"13.84.181.47/32\",\r\n \"13.84.188.162/32\",\r\n - \ \"13.84.189.137/32\",\r\n \"13.84.227.164/32\",\r\n \"13.85.15.194/32\",\r\n - \ \"13.85.16.224/32\",\r\n \"13.85.20.144/32\",\r\n \"13.85.24.220/32\",\r\n - \ \"13.85.27.14/32\",\r\n \"13.85.31.243/32\",\r\n \"13.85.72.129/32\",\r\n - \ \"13.85.77.179/32\",\r\n \"13.85.82.0/32\",\r\n \"20.45.122.160/27\",\r\n - \ \"20.49.90.32/27\",\r\n \"23.101.180.75/32\",\r\n \"23.102.154.38/32\",\r\n - \ \"23.102.161.217/32\",\r\n \"23.102.191.170/32\",\r\n \"40.74.245.188/32\",\r\n - \ \"40.74.253.108/32\",\r\n \"40.74.255.112/32\",\r\n \"40.84.148.247/32\",\r\n - \ \"40.84.159.58/32\",\r\n \"40.84.194.106/32\",\r\n \"40.84.226.176/32\",\r\n - \ \"40.84.227.180/32\",\r\n \"40.84.232.28/32\",\r\n \"40.119.12.0/23\",\r\n - \ \"40.124.12.75/32\",\r\n \"40.124.13.58/32\",\r\n \"52.171.56.101/32\",\r\n - \ \"52.171.56.110/32\",\r\n \"52.171.136.200/32\",\r\n \"52.171.140.237/32\",\r\n - \ \"52.171.218.239/32\",\r\n \"52.171.221.170/32\",\r\n \"52.171.222.247/32\",\r\n - \ \"104.44.128.13/32\",\r\n \"104.44.130.38/32\",\r\n \"104.210.145.181/32\",\r\n - \ \"104.210.147.57/32\",\r\n \"104.210.152.76/32\",\r\n \"104.210.152.122/32\",\r\n - \ \"104.210.153.116/32\",\r\n \"104.210.158.20/32\",\r\n - \ \"104.214.20.0/23\",\r\n \"104.214.29.203/32\",\r\n \"104.214.64.238/32\",\r\n - \ \"104.214.74.110/32\",\r\n \"104.214.77.221/32\",\r\n \"104.214.110.60/32\",\r\n - \ \"104.214.110.226/32\",\r\n \"104.214.118.174/32\",\r\n - \ \"104.214.119.36/32\",\r\n \"104.215.73.236/32\",\r\n \"104.215.78.13/32\",\r\n - \ \"104.215.89.22/32\",\r\n \"191.238.176.139/32\",\r\n \"191.238.240.12/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.SoutheastAsia\",\r\n - \ \"id\": \"AppService.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.67.9.0/25\",\r\n \"13.67.56.225/32\",\r\n \"13.67.63.90/32\",\r\n - \ \"13.76.44.139/32\",\r\n \"13.76.245.96/32\",\r\n \"20.43.132.128/25\",\r\n - \ \"20.188.98.74/32\",\r\n \"23.97.56.169/32\",\r\n \"23.98.64.36/32\",\r\n - \ \"23.98.64.158/32\",\r\n \"23.101.27.182/32\",\r\n \"52.163.122.160/32\",\r\n - \ \"52.187.17.126/32\",\r\n \"52.187.36.104/32\",\r\n \"52.187.52.94/32\",\r\n - \ \"52.187.135.79/32\",\r\n \"52.230.1.186/32\",\r\n \"104.215.147.45/32\",\r\n - \ \"104.215.155.1/32\",\r\n \"111.221.95.27/32\",\r\n \"137.116.128.188/32\",\r\n - \ \"137.116.153.238/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.SouthIndia\",\r\n \"id\": \"AppService.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.71.122.35/32\",\r\n \"13.71.123.138/32\",\r\n - \ \"20.41.195.192/27\",\r\n \"40.78.194.96/27\",\r\n \"52.172.54.225/32\",\r\n - \ \"104.211.224.252/32\",\r\n \"104.211.225.167/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.SwitzerlandNorth\",\r\n - \ \"id\": \"AppService.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"51.107.50.0/27\",\r\n \"51.107.58.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.SwitzerlandWest\",\r\n - \ \"id\": \"AppService.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"51.107.146.0/27\",\r\n \"51.107.154.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.UAECentral\",\r\n - \ \"id\": \"AppService.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.37.66.0/27\",\r\n - \ \"20.37.74.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppService.UAENorth\",\r\n \"id\": \"AppService.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"20.38.138.0/27\",\r\n \"40.120.74.32/27\",\r\n \"65.52.250.96/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.UKSouth\",\r\n - \ \"id\": \"AppService.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"51.104.28.64/26\",\r\n - \ \"51.105.66.160/27\",\r\n \"51.105.74.160/27\",\r\n \"51.140.37.241/32\",\r\n - \ \"51.140.57.176/32\",\r\n \"51.140.59.233/32\",\r\n \"51.140.75.147/32\",\r\n - \ \"51.140.84.145/32\",\r\n \"51.140.85.106/32\",\r\n \"51.140.87.39/32\",\r\n - \ \"51.140.122.226/32\",\r\n \"51.140.146.128/26\",\r\n \"51.140.152.154/32\",\r\n - \ \"51.140.153.150/32\",\r\n \"51.140.180.76/32\",\r\n \"51.140.185.151/32\",\r\n - \ \"51.140.191.223/32\",\r\n \"51.143.191.44/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.UKWest\",\r\n \"id\": - \"AppService.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"51.137.163.32/27\",\r\n - \ \"51.140.210.96/27\",\r\n \"51.140.244.162/32\",\r\n \"51.140.245.89/32\",\r\n - \ \"51.141.12.112/32\",\r\n \"51.141.37.245/32\",\r\n \"51.141.44.139/32\",\r\n - \ \"51.141.45.207/32\",\r\n \"51.141.90.252/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.WestCentralUS\",\r\n - \ \"id\": \"AppService.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\": - [\r\n \"13.71.194.192/27\",\r\n \"13.78.150.96/32\",\r\n - \ \"13.78.184.89/32\",\r\n \"52.150.140.224/27\",\r\n \"52.161.96.193/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.WestEurope\",\r\n - \ \"id\": \"AppService.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.69.68.0/23\",\r\n - \ \"13.80.19.74/32\",\r\n \"13.81.7.21/32\",\r\n \"13.81.108.99/32\",\r\n - \ \"13.81.215.235/32\",\r\n \"13.94.143.57/32\",\r\n \"13.94.192.98/32\",\r\n - \ \"13.94.211.38/32\",\r\n \"13.95.82.181/32\",\r\n \"13.95.93.152/32\",\r\n - \ \"13.95.150.128/32\",\r\n \"13.95.238.192/32\",\r\n \"20.50.2.0/23\",\r\n - \ \"23.97.160.56/32\",\r\n \"23.97.160.74/32\",\r\n \"23.97.162.202/32\",\r\n - \ \"23.97.195.129/32\",\r\n \"23.97.208.18/32\",\r\n \"23.97.214.177/32\",\r\n - \ \"23.97.216.47/32\",\r\n \"23.97.224.11/32\",\r\n \"23.100.1.29/32\",\r\n - \ \"23.101.67.245/32\",\r\n \"40.68.40.55/32\",\r\n \"40.68.205.178/32\",\r\n - \ \"40.68.208.131/32\",\r\n \"40.68.210.104/32\",\r\n \"40.68.214.185/32\",\r\n - \ \"40.113.126.251/32\",\r\n \"40.113.131.37/32\",\r\n \"40.113.136.240/32\",\r\n - \ \"40.113.142.219/32\",\r\n \"40.114.194.188/32\",\r\n \"40.114.210.78/32\",\r\n - \ \"40.114.228.161/32\",\r\n \"40.114.237.65/32\",\r\n \"40.114.243.70/32\",\r\n - \ \"40.115.55.251/32\",\r\n \"40.118.29.72/32\",\r\n \"40.118.71.240/32\",\r\n - \ \"40.118.96.231/32\",\r\n \"40.118.100.127/32\",\r\n \"40.118.101.67/32\",\r\n - \ \"40.118.102.46/32\",\r\n \"51.105.172.25/32\",\r\n \"51.136.14.31/32\",\r\n - \ \"51.137.106.13/32\",\r\n \"51.144.7.192/32\",\r\n \"51.144.107.53/32\",\r\n - \ \"51.144.116.43/32\",\r\n \"51.144.164.215/32\",\r\n \"51.144.182.8/32\",\r\n - \ \"52.166.78.97/32\",\r\n \"52.166.113.188/32\",\r\n \"52.166.119.99/32\",\r\n - \ \"52.166.178.208/32\",\r\n \"52.166.181.85/32\",\r\n \"52.166.198.163/32\",\r\n - \ \"52.174.3.80/32\",\r\n \"52.174.7.133/32\",\r\n \"52.174.35.5/32\",\r\n - \ \"52.174.106.15/32\",\r\n \"52.174.150.25/32\",\r\n \"52.174.181.178/32\",\r\n - \ \"52.174.184.18/32\",\r\n \"52.174.193.210/32\",\r\n \"52.174.235.29/32\",\r\n - \ \"52.178.29.39/32\",\r\n \"52.178.37.244/32\",\r\n \"52.178.43.209/32\",\r\n - \ \"52.178.45.139/32\",\r\n \"52.178.46.181/32\",\r\n \"52.178.75.200/32\",\r\n - \ \"52.178.79.163/32\",\r\n \"52.178.89.129/32\",\r\n \"52.178.90.230/32\",\r\n - \ \"52.178.92.96/32\",\r\n \"52.178.105.179/32\",\r\n \"52.178.114.226/32\",\r\n - \ \"52.232.19.237/32\",\r\n \"52.232.26.228/32\",\r\n \"52.232.33.202/32\",\r\n - \ \"52.232.56.79/32\",\r\n \"52.232.127.196/32\",\r\n \"52.233.128.61/32\",\r\n - \ \"52.233.133.18/32\",\r\n \"52.233.133.121/32\",\r\n \"52.233.155.168/32\",\r\n - \ \"52.233.164.195/32\",\r\n \"52.233.175.59/32\",\r\n \"52.233.184.181/32\",\r\n - \ \"52.233.198.206/32\",\r\n \"65.52.128.33/32\",\r\n \"65.52.130.1/32\",\r\n - \ \"104.40.129.89/32\",\r\n \"104.40.147.180/32\",\r\n \"104.40.147.216/32\",\r\n - \ \"104.40.158.55/32\",\r\n \"104.40.179.243/32\",\r\n \"104.40.183.236/32\",\r\n - \ \"104.40.185.192/32\",\r\n \"104.40.187.26/32\",\r\n \"104.40.191.174/32\",\r\n - \ \"104.40.210.25/32\",\r\n \"104.40.215.219/32\",\r\n \"104.40.222.81/32\",\r\n - \ \"104.40.250.100/32\",\r\n \"104.45.1.117/32\",\r\n \"104.45.14.249/32\",\r\n - \ \"104.46.38.245/32\",\r\n \"104.46.44.78/32\",\r\n \"104.46.61.116/32\",\r\n - \ \"104.47.137.62/32\",\r\n \"104.47.151.115/32\",\r\n \"104.47.160.14/32\",\r\n - \ \"104.47.164.119/32\",\r\n \"104.214.231.110/32\",\r\n - \ \"104.214.236.47/32\",\r\n \"104.214.237.135/32\",\r\n - \ \"137.117.166.35/32\",\r\n \"137.117.175.14/32\",\r\n \"137.117.203.130/32\",\r\n - \ \"137.117.211.244/32\",\r\n \"137.117.218.101/32\",\r\n - \ \"137.117.224.218/32\",\r\n \"137.117.225.87/32\",\r\n - \ \"168.63.5.231/32\",\r\n \"168.63.107.5/32\",\r\n \"191.233.82.44/32\",\r\n - \ \"191.233.85.165/32\",\r\n \"191.233.87.194/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.WestIndia\",\r\n - \ \"id\": \"AppService.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"52.136.50.0/27\",\r\n - \ \"104.211.146.96/27\",\r\n \"104.211.160.159/32\",\r\n - \ \"104.211.179.11/32\",\r\n \"104.211.184.197/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppService.WestUS\",\r\n \"id\": - \"AppService.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.64.73.110/32\",\r\n - \ \"13.91.40.166/32\",\r\n \"13.91.242.166/32\",\r\n \"13.93.141.10/32\",\r\n - \ \"13.93.158.16/32\",\r\n \"13.93.220.109/32\",\r\n \"13.93.231.75/32\",\r\n - \ \"23.99.0.12/32\",\r\n \"23.99.65.65/32\",\r\n \"23.99.91.55/32\",\r\n - \ \"23.100.46.198/32\",\r\n \"23.101.203.117/32\",\r\n \"23.101.203.214/32\",\r\n - \ \"23.101.207.250/32\",\r\n \"40.78.18.232/32\",\r\n \"40.78.25.157/32\",\r\n - \ \"40.78.48.219/32\",\r\n \"40.80.155.102/32\",\r\n \"40.80.156.205/32\",\r\n - \ \"40.82.255.128/25\",\r\n \"40.83.145.50/32\",\r\n \"40.83.150.233/32\",\r\n - \ \"40.83.182.206/32\",\r\n \"40.83.183.236/32\",\r\n \"40.83.184.25/32\",\r\n - \ \"40.112.142.148/32\",\r\n \"40.112.143.134/32\",\r\n \"40.112.143.140/32\",\r\n - \ \"40.112.143.214/32\",\r\n \"40.112.165.44/32\",\r\n \"40.112.166.161/32\",\r\n - \ \"40.112.191.159/32\",\r\n \"40.112.192.69/32\",\r\n \"40.112.216.189/32\",\r\n - \ \"40.112.243.0/25\",\r\n \"40.118.185.161/32\",\r\n \"40.118.235.113/32\",\r\n - \ \"40.118.246.51/32\",\r\n \"40.118.255.59/32\",\r\n \"52.160.40.218/32\",\r\n - \ \"104.40.3.53/32\",\r\n \"104.40.11.192/32\",\r\n \"104.40.28.133/32\",\r\n - \ \"104.40.53.219/32\",\r\n \"104.40.63.98/32\",\r\n \"104.40.84.133/32\",\r\n - \ \"104.40.92.107/32\",\r\n \"104.42.53.248/32\",\r\n \"104.42.78.153/32\",\r\n - \ \"104.42.128.171/32\",\r\n \"104.42.148.55/32\",\r\n \"104.42.152.64/32\",\r\n - \ \"104.42.154.105/32\",\r\n \"104.42.188.146/32\",\r\n \"104.42.231.5/32\",\r\n - \ \"104.45.226.98/32\",\r\n \"104.45.231.79/32\",\r\n \"104.210.38.149/32\",\r\n - \ \"137.117.9.212/32\",\r\n \"137.117.17.70/32\",\r\n \"138.91.224.84/32\",\r\n - \ \"138.91.225.40/32\",\r\n \"138.91.240.81/32\",\r\n \"168.62.20.37/32\",\r\n - \ \"191.236.80.12/32\",\r\n \"191.236.106.123/32\",\r\n \"191.239.58.162/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.WestUS2\",\r\n - \ \"id\": \"AppService.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.66.138.96/27\",\r\n - \ \"13.66.209.135/32\",\r\n \"13.66.212.205/32\",\r\n \"13.66.226.80/32\",\r\n - \ \"13.66.231.217/32\",\r\n \"13.66.241.134/32\",\r\n \"13.66.244.249/32\",\r\n - \ \"13.77.157.133/32\",\r\n \"13.77.160.237/32\",\r\n \"13.77.182.13/32\",\r\n - \ \"20.42.128.96/27\",\r\n \"40.64.128.224/27\",\r\n \"51.143.102.21/32\",\r\n - \ \"52.151.62.51/32\",\r\n \"52.175.202.25/32\",\r\n \"52.175.254.10/32\",\r\n - \ \"52.183.82.125/32\",\r\n \"52.229.30.210/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement\",\r\n - \ \"id\": \"AppServiceManagement\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.64.115.203/32\",\r\n \"13.66.140.0/26\",\r\n - \ \"13.67.8.128/26\",\r\n \"13.69.64.128/26\",\r\n \"13.69.227.128/26\",\r\n - \ \"13.70.72.64/26\",\r\n \"13.70.73.128/26\",\r\n \"13.71.170.64/26\",\r\n - \ \"13.71.173.0/26\",\r\n \"13.71.173.128/26\",\r\n \"13.71.194.128/26\",\r\n - \ \"13.73.240.128/26\",\r\n \"13.73.242.64/26\",\r\n \"13.75.34.192/26\",\r\n - \ \"13.75.127.117/32\",\r\n \"13.77.50.128/26\",\r\n \"13.78.106.128/26\",\r\n - \ \"13.78.109.0/26\",\r\n \"13.87.56.128/26\",\r\n \"13.87.122.128/26\",\r\n - \ \"13.89.171.0/26\",\r\n \"13.94.141.115/32\",\r\n \"13.94.143.126/32\",\r\n - \ \"13.94.149.179/32\",\r\n \"20.36.106.128/26\",\r\n \"20.36.114.64/26\",\r\n - \ \"20.37.74.128/26\",\r\n \"20.43.120.128/26\",\r\n \"20.44.2.192/26\",\r\n - \ \"20.44.27.0/26\",\r\n \"20.45.125.128/26\",\r\n \"20.49.82.128/26\",\r\n - \ \"20.49.90.128/26\",\r\n \"20.150.171.0/26\",\r\n \"20.150.179.0/26\",\r\n - \ \"20.150.187.0/26\",\r\n \"20.192.99.0/26\",\r\n \"20.192.234.192/26\",\r\n - \ \"20.193.202.192/26\",\r\n \"20.194.66.128/26\",\r\n \"23.96.195.3/32\",\r\n - \ \"23.100.226.236/32\",\r\n \"23.102.188.65/32\",\r\n \"40.67.59.0/26\",\r\n - \ \"40.69.106.128/26\",\r\n \"40.70.146.128/26\",\r\n \"40.71.11.0/26\",\r\n - \ \"40.71.13.64/26\",\r\n \"40.74.100.64/26\",\r\n \"40.78.194.128/26\",\r\n - \ \"40.79.130.64/26\",\r\n \"40.79.165.0/26\",\r\n \"40.79.178.128/26\",\r\n - \ \"40.83.120.64/32\",\r\n \"40.83.121.56/32\",\r\n \"40.83.125.161/32\",\r\n - \ \"40.90.240.166/32\",\r\n \"40.91.126.196/32\",\r\n \"40.112.242.192/26\",\r\n - \ \"40.119.4.111/32\",\r\n \"40.120.74.128/26\",\r\n \"40.124.47.188/32\",\r\n - \ \"51.12.99.0/26\",\r\n \"51.12.203.0/26\",\r\n \"51.12.227.0/26\",\r\n - \ \"51.12.235.0/26\",\r\n \"51.104.8.0/26\",\r\n \"51.104.8.128/26\",\r\n - \ \"51.107.58.192/26\",\r\n \"51.107.154.192/26\",\r\n \"51.116.58.192/26\",\r\n - \ \"51.116.155.0/26\",\r\n \"51.116.156.64/26\",\r\n \"51.116.243.64/26\",\r\n - \ \"51.116.251.192/26\",\r\n \"51.120.99.0/26\",\r\n \"51.120.107.0/26\",\r\n - \ \"51.120.211.0/26\",\r\n \"51.120.219.0/26\",\r\n \"51.140.146.64/26\",\r\n - \ \"51.140.210.128/26\",\r\n \"52.151.25.45/32\",\r\n \"52.162.80.89/32\",\r\n - \ \"52.162.106.192/26\",\r\n \"52.165.152.214/32\",\r\n \"52.165.153.122/32\",\r\n - \ \"52.165.154.193/32\",\r\n \"52.165.158.140/32\",\r\n \"52.174.22.21/32\",\r\n - \ \"52.178.177.147/32\",\r\n \"52.178.184.149/32\",\r\n \"52.178.190.65/32\",\r\n - \ \"52.178.195.197/32\",\r\n \"52.187.56.50/32\",\r\n \"52.187.59.251/32\",\r\n - \ \"52.187.63.19/32\",\r\n \"52.187.63.37/32\",\r\n \"52.224.105.172/32\",\r\n - \ \"52.225.177.15/32\",\r\n \"52.225.177.153/32\",\r\n \"52.231.18.64/26\",\r\n - \ \"52.231.146.128/26\",\r\n \"52.246.157.64/26\",\r\n \"65.52.14.230/32\",\r\n - \ \"65.52.172.237/32\",\r\n \"65.52.193.203/32\",\r\n \"65.52.250.128/26\",\r\n - \ \"70.37.57.58/32\",\r\n \"70.37.89.222/32\",\r\n \"102.133.26.192/26\",\r\n - \ \"102.133.123.0/26\",\r\n \"102.133.123.128/26\",\r\n \"102.133.154.192/26\",\r\n - \ \"104.43.242.137/32\",\r\n \"104.44.129.141/32\",\r\n \"104.44.129.243/32\",\r\n - \ \"104.44.129.255/32\",\r\n \"104.44.134.255/32\",\r\n \"104.208.54.11/32\",\r\n - \ \"104.211.81.64/26\",\r\n \"104.211.146.128/26\",\r\n \"104.214.18.192/26\",\r\n - \ \"104.214.49.0/32\",\r\n \"157.55.176.93/32\",\r\n \"157.55.208.185/32\",\r\n - \ \"191.233.50.128/26\",\r\n \"191.233.203.64/26\",\r\n \"191.234.147.0/26\",\r\n - \ \"191.234.155.0/26\",\r\n \"191.236.154.88/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaCentral\",\r\n - \ \"id\": \"AppServiceManagement.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"20.36.106.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaCentral2\",\r\n - \ \"id\": \"AppServiceManagement.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaEast\",\r\n - \ \"id\": \"AppServiceManagement.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.64/26\",\r\n - \ \"13.70.73.128/26\",\r\n \"40.79.165.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaSoutheast\",\r\n - \ \"id\": \"AppServiceManagement.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.77.50.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.BrazilSouth\",\r\n - \ \"id\": \"AppServiceManagement.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"191.233.203.64/26\",\r\n - \ \"191.234.147.0/26\",\r\n \"191.234.155.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CanadaCentral\",\r\n - \ \"id\": \"AppServiceManagement.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.64/26\",\r\n - \ \"13.71.173.0/26\",\r\n \"13.71.173.128/26\",\r\n \"52.246.157.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CanadaEast\",\r\n - \ \"id\": \"AppServiceManagement.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CentralIndia\",\r\n - \ \"id\": \"AppServiceManagement.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"20.43.120.128/26\",\r\n - \ \"20.192.99.0/26\",\r\n \"104.211.81.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CentralUS\",\r\n - \ \"id\": \"AppServiceManagement.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.0/26\",\r\n - \ \"52.165.152.214/32\",\r\n \"52.165.153.122/32\",\r\n \"52.165.154.193/32\",\r\n - \ \"52.165.158.140/32\",\r\n \"104.43.242.137/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CentralUSEUAP\",\r\n - \ \"id\": \"AppServiceManagement.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"104.208.54.11/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastAsia\",\r\n - \ \"id\": \"AppServiceManagement.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.75.34.192/26\",\r\n - \ \"13.75.127.117/32\",\r\n \"40.83.120.64/32\",\r\n \"40.83.121.56/32\",\r\n - \ \"40.83.125.161/32\",\r\n \"65.52.172.237/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastUS\",\r\n - \ \"id\": \"AppServiceManagement.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.71.11.0/26\",\r\n \"40.71.13.64/26\",\r\n - \ \"40.90.240.166/32\",\r\n \"52.224.105.172/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastUS2\",\r\n - \ \"id\": \"AppServiceManagement.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.70.146.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastUS2EUAP\",\r\n - \ \"id\": \"AppServiceManagement.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"52.225.177.15/32\",\r\n - \ \"52.225.177.153/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.FranceCentral\",\r\n \"id\": \"AppServiceManagement.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"40.79.130.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.FranceSouth\",\r\n \"id\": \"AppServiceManagement.FranceSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"40.79.178.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AppServiceManagement.GermanyNorth\",\r\n \"id\": - \"AppServiceManagement.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.58.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.GermanyWestCentral\",\r\n - \ \"id\": \"AppServiceManagement.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"51.116.155.0/26\",\r\n - \ \"51.116.156.64/26\",\r\n \"51.116.243.64/26\",\r\n \"51.116.251.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.JapanEast\",\r\n - \ \"id\": \"AppServiceManagement.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.78.106.128/26\",\r\n - \ \"13.78.109.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.JapanWest\",\r\n \"id\": \"AppServiceManagement.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.KoreaCentral\",\r\n \"id\": \"AppServiceManagement.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"20.44.27.0/26\",\r\n \"20.194.66.128/26\",\r\n \"52.231.18.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.KoreaSouth\",\r\n - \ \"id\": \"AppServiceManagement.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"52.231.146.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.NorthCentralUS\",\r\n - \ \"id\": \"AppServiceManagement.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"23.96.195.3/32\",\r\n - \ \"23.100.226.236/32\",\r\n \"52.162.80.89/32\",\r\n \"52.162.106.192/26\",\r\n - \ \"65.52.14.230/32\",\r\n \"65.52.193.203/32\",\r\n \"157.55.208.185/32\",\r\n - \ \"191.236.154.88/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.NorthEurope\",\r\n \"id\": \"AppServiceManagement.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.69.227.128/26\",\r\n \"52.178.177.147/32\",\r\n - \ \"52.178.184.149/32\",\r\n \"52.178.190.65/32\",\r\n \"52.178.195.197/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.NorwayEast\",\r\n - \ \"id\": \"AppServiceManagement.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"51.120.99.0/26\",\r\n - \ \"51.120.107.0/26\",\r\n \"51.120.211.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.NorwayWest\",\r\n - \ \"id\": \"AppServiceManagement.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"51.120.219.0/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.SouthAfricaNorth\",\r\n - \ \"id\": \"AppServiceManagement.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"102.133.123.0/26\",\r\n - \ \"102.133.123.128/26\",\r\n \"102.133.154.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.SouthAfricaWest\",\r\n - \ \"id\": \"AppServiceManagement.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.SouthCentralUS\",\r\n - \ \"id\": \"AppServiceManagement.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.73.240.128/26\",\r\n - \ \"13.73.242.64/26\",\r\n \"20.45.125.128/26\",\r\n \"20.49.90.128/26\",\r\n - \ \"23.102.188.65/32\",\r\n \"40.119.4.111/32\",\r\n \"40.124.47.188/32\",\r\n - \ \"70.37.57.58/32\",\r\n \"70.37.89.222/32\",\r\n \"104.44.129.141/32\",\r\n - \ \"104.44.129.243/32\",\r\n \"104.44.129.255/32\",\r\n \"104.44.134.255/32\",\r\n - \ \"104.214.18.192/26\",\r\n \"104.214.49.0/32\",\r\n \"157.55.176.93/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.SoutheastAsia\",\r\n - \ \"id\": \"AppServiceManagement.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.128/26\",\r\n - \ \"52.187.56.50/32\",\r\n \"52.187.59.251/32\",\r\n \"52.187.63.19/32\",\r\n - \ \"52.187.63.37/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.SouthIndia\",\r\n \"id\": \"AppServiceManagement.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"40.78.194.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AppServiceManagement.SwitzerlandNorth\",\r\n \"id\": - \"AppServiceManagement.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"51.107.58.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.SwitzerlandWest\",\r\n - \ \"id\": \"AppServiceManagement.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"51.107.154.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.UAECentral\",\r\n - \ \"id\": \"AppServiceManagement.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.UAENorth\",\r\n - \ \"id\": \"AppServiceManagement.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.128/26\",\r\n - \ \"65.52.250.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.UKNorth\",\r\n \"id\": \"AppServiceManagement.UKNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.87.122.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AppServiceManagement.UKSouth\",\r\n \"id\": - \"AppServiceManagement.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.104.8.0/26\",\r\n \"51.104.8.128/26\",\r\n - \ \"51.140.146.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.UKSouth2\",\r\n \"id\": \"AppServiceManagement.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.87.56.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.UKWest\",\r\n \"id\": \"AppServiceManagement.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.140.210.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AppServiceManagement.WestCentralUS\",\r\n \"id\": - \"AppServiceManagement.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.WestEurope\",\r\n - \ \"id\": \"AppServiceManagement.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.128/26\",\r\n - \ \"13.94.141.115/32\",\r\n \"13.94.143.126/32\",\r\n \"13.94.149.179/32\",\r\n - \ \"52.174.22.21/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AppServiceManagement.WestIndia\",\r\n \"id\": \"AppServiceManagement.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": - [\r\n \"104.211.146.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AppServiceManagement.WestUS\",\r\n \"id\": - \"AppServiceManagement.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.115.203/32\",\r\n \"40.112.242.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.WestUS2\",\r\n - \ \"id\": \"AppServiceManagement.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.140.0/26\",\r\n \"40.91.126.196/32\",\r\n - \ \"52.151.25.45/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureActiveDirectory\",\r\n \"id\": \"AzureActiveDirectory\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureAD\",\r\n \"addressPrefixes\": - [\r\n \"13.64.151.161/32\",\r\n \"13.66.141.64/27\",\r\n - \ \"13.67.9.224/27\",\r\n \"13.69.66.160/27\",\r\n \"13.69.229.96/27\",\r\n - \ \"13.70.73.32/27\",\r\n \"13.71.172.160/27\",\r\n \"13.71.195.224/27\",\r\n - \ \"13.71.201.64/26\",\r\n \"13.73.240.32/27\",\r\n \"13.74.104.0/26\",\r\n - \ \"13.74.249.156/32\",\r\n \"13.75.38.32/27\",\r\n \"13.75.105.168/32\",\r\n - \ \"13.77.52.160/27\",\r\n \"13.78.108.192/27\",\r\n \"13.78.172.246/32\",\r\n - \ \"13.79.37.247/32\",\r\n \"13.86.219.0/27\",\r\n \"13.87.16.0/26\",\r\n - \ \"13.87.57.160/27\",\r\n \"13.87.123.160/27\",\r\n \"13.89.174.0/27\",\r\n - \ \"20.36.107.192/27\",\r\n \"20.36.115.64/27\",\r\n \"20.37.75.96/27\",\r\n - \ \"20.43.120.32/27\",\r\n \"20.44.3.160/27\",\r\n \"20.44.16.32/27\",\r\n - \ \"20.190.128.0/18\",\r\n \"23.101.0.70/32\",\r\n \"23.101.6.190/32\",\r\n - \ \"40.68.160.142/32\",\r\n \"40.69.107.160/27\",\r\n \"40.71.13.0/27\",\r\n - \ \"40.74.101.64/27\",\r\n \"40.74.146.192/27\",\r\n \"40.78.195.160/27\",\r\n - \ \"40.78.203.64/27\",\r\n \"40.79.131.128/27\",\r\n \"40.79.179.128/27\",\r\n - \ \"40.83.144.56/32\",\r\n \"40.126.0.0/18\",\r\n \"51.140.148.192/27\",\r\n - \ \"51.140.208.0/26\",\r\n \"51.140.211.192/27\",\r\n \"52.138.65.157/32\",\r\n - \ \"52.138.68.41/32\",\r\n \"52.161.13.71/32\",\r\n \"52.161.13.95/32\",\r\n - \ \"52.161.110.169/32\",\r\n \"52.162.110.96/27\",\r\n \"52.169.125.119/32\",\r\n - \ \"52.169.218.0/32\",\r\n \"52.174.189.149/32\",\r\n \"52.175.18.134/32\",\r\n - \ \"52.178.27.112/32\",\r\n \"52.179.122.218/32\",\r\n \"52.179.126.223/32\",\r\n - \ \"52.180.177.87/32\",\r\n \"52.180.179.108/32\",\r\n \"52.180.181.61/32\",\r\n - \ \"52.180.183.8/32\",\r\n \"52.187.19.1/32\",\r\n \"52.187.113.48/32\",\r\n - \ \"52.187.117.83/32\",\r\n \"52.187.120.237/32\",\r\n \"52.225.184.198/32\",\r\n - \ \"52.225.188.89/32\",\r\n \"52.231.19.128/27\",\r\n \"52.231.147.192/27\",\r\n - \ \"65.52.251.96/27\",\r\n \"104.40.84.19/32\",\r\n \"104.40.87.209/32\",\r\n - \ \"104.40.156.18/32\",\r\n \"104.40.168.0/26\",\r\n \"104.41.159.212/32\",\r\n - \ \"104.45.138.161/32\",\r\n \"104.211.147.160/27\",\r\n - \ \"191.233.204.160/27\",\r\n \"2603:1006:2000::/48\",\r\n - \ \"2603:1007:200::/48\",\r\n \"2603:1016:1400::/48\",\r\n - \ \"2603:1017::/48\",\r\n \"2603:1026:3000::/48\",\r\n \"2603:1027:1::/48\",\r\n - \ \"2603:1036:3000::/48\",\r\n \"2603:1037:1::/48\",\r\n - \ \"2603:1046:2000::/48\",\r\n \"2603:1047:1::/48\",\r\n - \ \"2603:1056:2000::/48\",\r\n \"2603:1057:2::/48\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureActiveDirectory.ServiceEndpoint\",\r\n - \ \"id\": \"AzureActiveDirectory.ServiceEndpoint\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureIdentity\",\r\n \"addressPrefixes\": - [\r\n \"20.190.128.0/26\",\r\n \"20.190.128.64/28\",\r\n - \ \"20.190.128.128/27\",\r\n \"20.190.128.160/29\",\r\n \"20.190.129.0/26\",\r\n - \ \"20.190.129.64/28\",\r\n \"20.190.129.128/27\",\r\n \"20.190.129.160/29\",\r\n - \ \"20.190.130.0/27\",\r\n \"20.190.130.32/29\",\r\n \"20.190.131.0/27\",\r\n - \ \"20.190.131.32/29\",\r\n \"20.190.131.64/27\",\r\n \"20.190.131.96/29\",\r\n - \ \"20.190.132.0/27\",\r\n \"20.190.132.32/29\",\r\n \"20.190.132.64/27\",\r\n - \ \"20.190.132.96/29\",\r\n \"20.190.133.0/27\",\r\n \"20.190.133.32/29\",\r\n - \ \"20.190.133.64/27\",\r\n \"20.190.133.96/29\",\r\n \"20.190.134.0/27\",\r\n - \ \"20.190.134.32/29\",\r\n \"20.190.134.64/27\",\r\n \"20.190.134.96/29\",\r\n - \ \"20.190.135.0/27\",\r\n \"20.190.135.32/29\",\r\n \"20.190.135.64/27\",\r\n - \ \"20.190.135.96/29\",\r\n \"20.190.136.0/27\",\r\n \"20.190.136.32/29\",\r\n - \ \"20.190.137.0/27\",\r\n \"20.190.137.32/29\",\r\n \"20.190.137.64/27\",\r\n - \ \"20.190.137.96/29\",\r\n \"20.190.138.0/27\",\r\n \"20.190.138.32/29\",\r\n - \ \"20.190.138.64/27\",\r\n \"20.190.138.96/29\",\r\n \"20.190.138.128/27\",\r\n - \ \"20.190.138.160/29\",\r\n \"20.190.139.0/27\",\r\n \"20.190.139.32/29\",\r\n - \ \"20.190.139.64/27\",\r\n \"20.190.139.96/29\",\r\n \"20.190.139.128/27\",\r\n - \ \"20.190.139.160/29\",\r\n \"20.190.140.0/27\",\r\n \"20.190.140.32/29\",\r\n - \ \"20.190.140.64/27\",\r\n \"20.190.140.96/29\",\r\n \"20.190.140.128/27\",\r\n - \ \"20.190.140.160/29\",\r\n \"20.190.140.192/27\",\r\n \"20.190.140.224/29\",\r\n - \ \"20.190.141.0/27\",\r\n \"20.190.141.32/29\",\r\n \"20.190.141.128/27\",\r\n - \ \"20.190.141.160/29\",\r\n \"20.190.141.192/27\",\r\n \"20.190.141.224/29\",\r\n - \ \"20.190.142.0/27\",\r\n \"20.190.142.32/29\",\r\n \"20.190.142.64/27\",\r\n - \ \"20.190.142.96/29\",\r\n \"20.190.142.128/27\",\r\n \"20.190.142.160/29\",\r\n - \ \"20.190.143.0/27\",\r\n \"20.190.143.32/29\",\r\n \"20.190.143.64/27\",\r\n - \ \"20.190.143.96/29\",\r\n \"20.190.143.128/27\",\r\n \"20.190.143.160/29\",\r\n - \ \"20.190.144.0/27\",\r\n \"20.190.144.32/29\",\r\n \"20.190.144.128/27\",\r\n - \ \"20.190.144.160/29\",\r\n \"20.190.144.192/27\",\r\n \"20.190.144.224/29\",\r\n - \ \"20.190.145.0/27\",\r\n \"20.190.145.32/29\",\r\n \"20.190.145.64/27\",\r\n - \ \"20.190.145.96/29\",\r\n \"20.190.145.128/27\",\r\n \"20.190.145.160/29\",\r\n - \ \"20.190.146.0/27\",\r\n \"20.190.146.32/29\",\r\n \"20.190.146.64/27\",\r\n - \ \"20.190.146.96/29\",\r\n \"20.190.146.128/27\",\r\n \"20.190.146.160/29\",\r\n - \ \"20.190.147.0/27\",\r\n \"20.190.147.32/29\",\r\n \"20.190.147.64/27\",\r\n - \ \"20.190.147.96/29\",\r\n \"20.190.147.128/27\",\r\n \"20.190.147.160/29\",\r\n - \ \"20.190.148.0/27\",\r\n \"20.190.148.32/29\",\r\n \"20.190.148.128/27\",\r\n - \ \"20.190.148.160/29\",\r\n \"20.190.148.192/27\",\r\n \"20.190.148.224/29\",\r\n - \ \"20.190.149.0/28\",\r\n \"20.190.149.16/29\",\r\n \"20.190.149.64/28\",\r\n - \ \"20.190.149.80/29\",\r\n \"20.190.149.128/28\",\r\n \"20.190.149.144/29\",\r\n - \ \"20.190.150.0/28\",\r\n \"20.190.150.16/29\",\r\n \"20.190.150.64/27\",\r\n - \ \"20.190.150.96/28\",\r\n \"20.190.151.0/28\",\r\n \"20.190.151.16/29\",\r\n - \ \"20.190.151.64/28\",\r\n \"20.190.151.80/29\",\r\n \"20.190.151.128/28\",\r\n - \ \"20.190.151.144/29\",\r\n \"20.190.152.0/28\",\r\n \"20.190.152.16/29\",\r\n - \ \"20.190.152.64/28\",\r\n \"20.190.152.80/29\",\r\n \"20.190.152.128/28\",\r\n - \ \"20.190.152.144/29\",\r\n \"20.190.153.0/28\",\r\n \"20.190.153.16/29\",\r\n - \ \"20.190.153.64/27\",\r\n \"20.190.153.96/28\",\r\n \"20.190.154.0/28\",\r\n - \ \"20.190.154.16/29\",\r\n \"20.190.154.64/28\",\r\n \"20.190.154.80/29\",\r\n - \ \"20.190.154.128/28\",\r\n \"20.190.154.144/29\",\r\n \"20.190.155.0/28\",\r\n - \ \"20.190.155.16/29\",\r\n \"20.190.155.64/28\",\r\n \"20.190.155.80/29\",\r\n - \ \"20.190.155.128/28\",\r\n \"20.190.155.144/29\",\r\n \"20.190.156.0/28\",\r\n - \ \"20.190.156.16/29\",\r\n \"20.190.156.64/27\",\r\n \"20.190.156.96/28\",\r\n - \ \"20.190.157.0/28\",\r\n \"20.190.157.16/29\",\r\n \"20.190.157.64/28\",\r\n - \ \"20.190.157.80/29\",\r\n \"20.190.157.128/28\",\r\n \"20.190.157.144/29\",\r\n - \ \"20.190.158.0/28\",\r\n \"20.190.158.16/29\",\r\n \"20.190.158.64/27\",\r\n - \ \"20.190.158.96/28\",\r\n \"20.190.159.0/28\",\r\n \"20.190.159.16/29\",\r\n - \ \"20.190.159.64/28\",\r\n \"20.190.159.80/29\",\r\n \"20.190.159.128/28\",\r\n - \ \"20.190.159.144/29\",\r\n \"20.190.160.0/28\",\r\n \"20.190.160.16/29\",\r\n - \ \"20.190.160.64/28\",\r\n \"20.190.160.80/29\",\r\n \"20.190.160.128/28\",\r\n - \ \"20.190.160.144/29\",\r\n \"20.190.161.0/28\",\r\n \"20.190.161.16/29\",\r\n - \ \"20.190.161.64/28\",\r\n \"20.190.161.80/29\",\r\n \"20.190.161.128/28\",\r\n - \ \"20.190.161.144/29\",\r\n \"20.190.162.0/28\",\r\n \"20.190.162.16/29\",\r\n - \ \"20.190.162.64/27\",\r\n \"20.190.162.96/28\",\r\n \"20.190.163.0/28\",\r\n - \ \"20.190.163.16/29\",\r\n \"20.190.163.64/28\",\r\n \"20.190.163.80/29\",\r\n - \ \"20.190.163.128/28\",\r\n \"20.190.163.144/29\",\r\n \"20.190.164.0/28\",\r\n - \ \"20.190.164.16/29\",\r\n \"20.190.164.64/27\",\r\n \"20.190.164.96/28\",\r\n - \ \"20.190.165.0/28\",\r\n \"20.190.165.16/29\",\r\n \"20.190.165.64/27\",\r\n - \ \"20.190.165.96/28\",\r\n \"20.190.166.0/28\",\r\n \"20.190.166.16/29\",\r\n - \ \"20.190.166.64/28\",\r\n \"20.190.166.80/29\",\r\n \"20.190.166.128/28\",\r\n - \ \"20.190.166.144/29\",\r\n \"20.190.167.0/28\",\r\n \"20.190.167.16/29\",\r\n - \ \"20.190.167.64/28\",\r\n \"20.190.167.80/29\",\r\n \"20.190.167.128/28\",\r\n - \ \"20.190.167.144/29\",\r\n \"20.190.168.0/28\",\r\n \"20.190.168.16/29\",\r\n - \ \"20.190.168.64/27\",\r\n \"20.190.168.96/28\",\r\n \"20.190.169.0/28\",\r\n - \ \"20.190.169.16/29\",\r\n \"20.190.169.64/28\",\r\n \"20.190.169.80/29\",\r\n - \ \"20.190.169.128/28\",\r\n \"20.190.169.144/29\",\r\n \"20.190.170.0/28\",\r\n - \ \"20.190.170.16/29\",\r\n \"20.190.170.64/27\",\r\n \"20.190.170.96/28\",\r\n - \ \"20.190.171.0/28\",\r\n \"20.190.171.16/29\",\r\n \"20.190.171.64/27\",\r\n - \ \"20.190.171.96/28\",\r\n \"20.190.172.0/28\",\r\n \"20.190.172.16/29\",\r\n - \ \"20.190.172.64/27\",\r\n \"20.190.172.96/28\",\r\n \"20.190.173.0/28\",\r\n - \ \"20.190.173.16/29\",\r\n \"20.190.173.64/28\",\r\n \"20.190.173.80/29\",\r\n - \ \"20.190.173.128/28\",\r\n \"20.190.173.144/29\",\r\n \"20.190.174.0/28\",\r\n - \ \"20.190.174.16/29\",\r\n \"20.190.174.64/27\",\r\n \"20.190.174.96/28\",\r\n - \ \"20.190.175.0/28\",\r\n \"20.190.175.16/29\",\r\n \"20.190.175.64/28\",\r\n - \ \"20.190.175.80/29\",\r\n \"20.190.175.128/28\",\r\n \"20.190.175.144/29\",\r\n - \ \"20.190.176.0/28\",\r\n \"20.190.176.16/29\",\r\n \"20.190.176.64/27\",\r\n - \ \"20.190.176.96/28\",\r\n \"20.190.177.0/28\",\r\n \"20.190.177.16/29\",\r\n - \ \"20.190.177.64/28\",\r\n \"20.190.177.80/29\",\r\n \"20.190.177.128/28\",\r\n - \ \"20.190.177.144/29\",\r\n \"20.190.178.0/28\",\r\n \"20.190.178.16/29\",\r\n - \ \"20.190.178.64/27\",\r\n \"20.190.178.96/28\",\r\n \"20.190.179.0/28\",\r\n - \ \"20.190.179.16/29\",\r\n \"20.190.179.64/27\",\r\n \"20.190.179.96/28\",\r\n - \ \"20.190.180.0/28\",\r\n \"20.190.180.16/29\",\r\n \"20.190.180.64/28\",\r\n - \ \"20.190.180.80/29\",\r\n \"20.190.180.128/28\",\r\n \"20.190.180.144/29\",\r\n - \ \"20.190.181.0/28\",\r\n \"20.190.181.16/29\",\r\n \"20.190.181.64/27\",\r\n - \ \"20.190.181.96/28\",\r\n \"20.190.182.0/28\",\r\n \"20.190.182.16/29\",\r\n - \ \"20.190.182.64/27\",\r\n \"20.190.182.96/28\",\r\n \"20.190.183.0/28\",\r\n - \ \"20.190.183.16/29\",\r\n \"20.190.183.64/27\",\r\n \"20.190.183.96/28\",\r\n - \ \"20.190.184.0/28\",\r\n \"20.190.184.16/29\",\r\n \"20.190.184.64/27\",\r\n - \ \"20.190.184.96/28\",\r\n \"20.190.186.0/28\",\r\n \"20.190.186.16/29\",\r\n - \ \"20.190.186.64/27\",\r\n \"20.190.186.96/28\",\r\n \"20.190.187.0/28\",\r\n - \ \"20.190.187.16/29\",\r\n \"20.190.187.64/27\",\r\n \"20.190.187.96/28\",\r\n - \ \"20.190.188.0/28\",\r\n \"20.190.188.16/29\",\r\n \"20.190.188.64/27\",\r\n - \ \"20.190.188.96/28\",\r\n \"40.126.0.0/26\",\r\n \"40.126.0.64/28\",\r\n - \ \"40.126.0.128/27\",\r\n \"40.126.0.160/29\",\r\n \"40.126.1.0/26\",\r\n - \ \"40.126.1.64/28\",\r\n \"40.126.1.128/27\",\r\n \"40.126.1.160/29\",\r\n - \ \"40.126.2.0/27\",\r\n \"40.126.2.32/29\",\r\n \"40.126.3.0/27\",\r\n - \ \"40.126.3.32/29\",\r\n \"40.126.3.64/27\",\r\n \"40.126.3.96/29\",\r\n - \ \"40.126.4.0/27\",\r\n \"40.126.4.32/29\",\r\n \"40.126.4.64/27\",\r\n - \ \"40.126.4.96/29\",\r\n \"40.126.5.0/27\",\r\n \"40.126.5.32/29\",\r\n - \ \"40.126.5.64/27\",\r\n \"40.126.5.96/29\",\r\n \"40.126.6.0/27\",\r\n - \ \"40.126.6.32/29\",\r\n \"40.126.6.64/27\",\r\n \"40.126.6.96/29\",\r\n - \ \"40.126.7.0/27\",\r\n \"40.126.7.32/29\",\r\n \"40.126.7.64/27\",\r\n - \ \"40.126.7.96/29\",\r\n \"40.126.8.0/27\",\r\n \"40.126.8.32/29\",\r\n - \ \"40.126.9.0/27\",\r\n \"40.126.9.32/29\",\r\n \"40.126.9.64/27\",\r\n - \ \"40.126.9.96/29\",\r\n \"40.126.10.0/27\",\r\n \"40.126.10.32/29\",\r\n - \ \"40.126.10.64/27\",\r\n \"40.126.10.96/29\",\r\n \"40.126.10.128/27\",\r\n - \ \"40.126.10.160/29\",\r\n \"40.126.11.0/27\",\r\n \"40.126.11.32/29\",\r\n - \ \"40.126.11.64/27\",\r\n \"40.126.11.96/29\",\r\n \"40.126.11.128/27\",\r\n - \ \"40.126.11.160/29\",\r\n \"40.126.12.0/27\",\r\n \"40.126.12.32/29\",\r\n - \ \"40.126.12.64/27\",\r\n \"40.126.12.96/29\",\r\n \"40.126.12.128/27\",\r\n - \ \"40.126.12.160/29\",\r\n \"40.126.12.192/27\",\r\n \"40.126.12.224/29\",\r\n - \ \"40.126.13.0/27\",\r\n \"40.126.13.32/29\",\r\n \"40.126.13.128/27\",\r\n - \ \"40.126.13.160/29\",\r\n \"40.126.13.192/27\",\r\n \"40.126.13.224/29\",\r\n - \ \"40.126.14.0/27\",\r\n \"40.126.14.32/29\",\r\n \"40.126.14.64/27\",\r\n - \ \"40.126.14.96/29\",\r\n \"40.126.14.128/27\",\r\n \"40.126.14.160/29\",\r\n - \ \"40.126.15.0/27\",\r\n \"40.126.15.32/29\",\r\n \"40.126.15.64/27\",\r\n - \ \"40.126.15.96/29\",\r\n \"40.126.15.128/27\",\r\n \"40.126.15.160/29\",\r\n - \ \"40.126.16.0/27\",\r\n \"40.126.16.32/29\",\r\n \"40.126.16.128/27\",\r\n - \ \"40.126.16.160/29\",\r\n \"40.126.16.192/27\",\r\n \"40.126.16.224/29\",\r\n - \ \"40.126.17.0/27\",\r\n \"40.126.17.32/29\",\r\n \"40.126.17.64/27\",\r\n - \ \"40.126.17.96/29\",\r\n \"40.126.17.128/27\",\r\n \"40.126.17.160/29\",\r\n - \ \"40.126.18.0/27\",\r\n \"40.126.18.32/29\",\r\n \"40.126.18.64/27\",\r\n - \ \"40.126.18.96/29\",\r\n \"40.126.18.128/27\",\r\n \"40.126.18.160/29\",\r\n - \ \"40.126.19.0/27\",\r\n \"40.126.19.32/29\",\r\n \"40.126.19.64/27\",\r\n - \ \"40.126.19.96/29\",\r\n \"40.126.19.128/27\",\r\n \"40.126.19.160/29\",\r\n - \ \"40.126.20.0/27\",\r\n \"40.126.20.32/29\",\r\n \"40.126.20.128/27\",\r\n - \ \"40.126.20.160/29\",\r\n \"40.126.20.192/27\",\r\n \"40.126.20.224/29\",\r\n - \ \"40.126.21.0/28\",\r\n \"40.126.21.16/29\",\r\n \"40.126.21.64/28\",\r\n - \ \"40.126.21.80/29\",\r\n \"40.126.21.128/28\",\r\n \"40.126.21.144/29\",\r\n - \ \"40.126.22.0/28\",\r\n \"40.126.22.16/29\",\r\n \"40.126.22.64/27\",\r\n - \ \"40.126.22.96/28\",\r\n \"40.126.23.0/28\",\r\n \"40.126.23.16/29\",\r\n - \ \"40.126.23.64/28\",\r\n \"40.126.23.80/29\",\r\n \"40.126.23.128/28\",\r\n - \ \"40.126.23.144/29\",\r\n \"40.126.24.0/28\",\r\n \"40.126.24.16/29\",\r\n - \ \"40.126.24.64/28\",\r\n \"40.126.24.80/29\",\r\n \"40.126.24.128/28\",\r\n - \ \"40.126.24.144/29\",\r\n \"40.126.25.0/28\",\r\n \"40.126.25.16/29\",\r\n - \ \"40.126.25.64/27\",\r\n \"40.126.25.96/28\",\r\n \"40.126.26.0/28\",\r\n - \ \"40.126.26.16/29\",\r\n \"40.126.26.64/28\",\r\n \"40.126.26.80/29\",\r\n - \ \"40.126.26.128/28\",\r\n \"40.126.26.144/29\",\r\n \"40.126.27.0/28\",\r\n - \ \"40.126.27.16/29\",\r\n \"40.126.27.64/28\",\r\n \"40.126.27.80/29\",\r\n - \ \"40.126.27.128/28\",\r\n \"40.126.27.144/29\",\r\n \"40.126.28.0/28\",\r\n - \ \"40.126.28.16/29\",\r\n \"40.126.28.64/27\",\r\n \"40.126.28.96/28\",\r\n - \ \"40.126.29.0/28\",\r\n \"40.126.29.16/29\",\r\n \"40.126.29.64/28\",\r\n - \ \"40.126.29.80/29\",\r\n \"40.126.29.128/28\",\r\n \"40.126.29.144/29\",\r\n - \ \"40.126.30.0/28\",\r\n \"40.126.30.16/29\",\r\n \"40.126.30.64/27\",\r\n - \ \"40.126.30.96/28\",\r\n \"40.126.31.0/28\",\r\n \"40.126.31.16/29\",\r\n - \ \"40.126.31.64/28\",\r\n \"40.126.31.80/29\",\r\n \"40.126.31.128/28\",\r\n - \ \"40.126.31.144/29\",\r\n \"40.126.32.0/28\",\r\n \"40.126.32.16/29\",\r\n - \ \"40.126.32.64/28\",\r\n \"40.126.32.80/29\",\r\n \"40.126.32.128/28\",\r\n - \ \"40.126.32.144/29\",\r\n \"40.126.33.0/28\",\r\n \"40.126.33.16/29\",\r\n - \ \"40.126.33.64/28\",\r\n \"40.126.33.80/29\",\r\n \"40.126.33.128/28\",\r\n - \ \"40.126.33.144/29\",\r\n \"40.126.34.0/28\",\r\n \"40.126.34.16/29\",\r\n - \ \"40.126.34.64/27\",\r\n \"40.126.34.96/28\",\r\n \"40.126.35.0/28\",\r\n - \ \"40.126.35.16/29\",\r\n \"40.126.35.64/28\",\r\n \"40.126.35.80/29\",\r\n - \ \"40.126.35.128/28\",\r\n \"40.126.35.144/29\",\r\n \"40.126.36.0/28\",\r\n - \ \"40.126.36.16/29\",\r\n \"40.126.36.64/27\",\r\n \"40.126.36.96/28\",\r\n - \ \"40.126.37.0/28\",\r\n \"40.126.37.16/29\",\r\n \"40.126.37.64/27\",\r\n - \ \"40.126.37.96/28\",\r\n \"40.126.38.0/28\",\r\n \"40.126.38.16/29\",\r\n - \ \"40.126.38.64/28\",\r\n \"40.126.38.80/29\",\r\n \"40.126.38.128/28\",\r\n - \ \"40.126.38.144/29\",\r\n \"40.126.39.0/28\",\r\n \"40.126.39.16/29\",\r\n - \ \"40.126.39.64/28\",\r\n \"40.126.39.80/29\",\r\n \"40.126.39.128/28\",\r\n - \ \"40.126.39.144/29\",\r\n \"40.126.40.0/28\",\r\n \"40.126.40.16/29\",\r\n - \ \"40.126.40.64/27\",\r\n \"40.126.40.96/28\",\r\n \"40.126.41.0/28\",\r\n - \ \"40.126.41.16/29\",\r\n \"40.126.41.64/28\",\r\n \"40.126.41.80/29\",\r\n - \ \"40.126.41.128/28\",\r\n \"40.126.41.144/29\",\r\n \"40.126.42.0/28\",\r\n - \ \"40.126.42.16/29\",\r\n \"40.126.42.64/27\",\r\n \"40.126.42.96/28\",\r\n - \ \"40.126.43.0/28\",\r\n \"40.126.43.16/29\",\r\n \"40.126.43.64/27\",\r\n - \ \"40.126.43.96/28\",\r\n \"40.126.44.0/28\",\r\n \"40.126.44.16/29\",\r\n - \ \"40.126.44.64/27\",\r\n \"40.126.44.96/28\",\r\n \"40.126.45.0/28\",\r\n - \ \"40.126.45.16/29\",\r\n \"40.126.45.64/28\",\r\n \"40.126.45.80/29\",\r\n - \ \"40.126.45.128/28\",\r\n \"40.126.45.144/29\",\r\n \"40.126.46.0/28\",\r\n - \ \"40.126.46.16/29\",\r\n \"40.126.46.64/27\",\r\n \"40.126.46.96/28\",\r\n - \ \"40.126.47.0/28\",\r\n \"40.126.47.16/29\",\r\n \"40.126.47.64/28\",\r\n - \ \"40.126.47.80/29\",\r\n \"40.126.47.128/28\",\r\n \"40.126.47.144/29\",\r\n - \ \"40.126.48.0/28\",\r\n \"40.126.48.16/29\",\r\n \"40.126.48.64/27\",\r\n - \ \"40.126.48.96/28\",\r\n \"40.126.49.0/28\",\r\n \"40.126.49.16/29\",\r\n - \ \"40.126.49.64/28\",\r\n \"40.126.49.80/29\",\r\n \"40.126.49.128/28\",\r\n - \ \"40.126.49.144/29\",\r\n \"40.126.50.0/28\",\r\n \"40.126.50.16/29\",\r\n - \ \"40.126.50.64/27\",\r\n \"40.126.50.96/28\",\r\n \"40.126.51.0/28\",\r\n - \ \"40.126.51.16/29\",\r\n \"40.126.51.64/27\",\r\n \"40.126.51.96/28\",\r\n - \ \"40.126.52.0/28\",\r\n \"40.126.52.16/29\",\r\n \"40.126.52.64/28\",\r\n - \ \"40.126.52.80/29\",\r\n \"40.126.52.128/28\",\r\n \"40.126.52.144/29\",\r\n - \ \"40.126.53.0/28\",\r\n \"40.126.53.16/29\",\r\n \"40.126.53.64/27\",\r\n - \ \"40.126.53.96/28\",\r\n \"40.126.54.0/28\",\r\n \"40.126.54.16/29\",\r\n - \ \"40.126.54.64/27\",\r\n \"40.126.54.96/28\",\r\n \"40.126.55.0/28\",\r\n - \ \"40.126.55.16/29\",\r\n \"40.126.55.64/27\",\r\n \"40.126.55.96/28\",\r\n - \ \"40.126.56.0/28\",\r\n \"40.126.56.16/29\",\r\n \"40.126.56.64/27\",\r\n - \ \"40.126.56.96/28\",\r\n \"40.126.58.0/28\",\r\n \"40.126.58.16/29\",\r\n - \ \"40.126.58.64/27\",\r\n \"40.126.58.96/28\",\r\n \"40.126.59.0/28\",\r\n - \ \"40.126.59.16/29\",\r\n \"40.126.59.64/27\",\r\n \"40.126.59.96/28\",\r\n - \ \"40.126.60.0/28\",\r\n \"40.126.60.16/29\",\r\n \"40.126.60.64/27\",\r\n - \ \"40.126.60.96/28\",\r\n \"2603:1006:2000::/121\",\r\n - \ \"2603:1006:2000:20::/121\",\r\n \"2603:1007:200::/121\",\r\n - \ \"2603:1007:200:20::/121\",\r\n \"2603:1016:1400::/121\",\r\n - \ \"2603:1016:1400:20::/121\",\r\n \"2603:1016:1400:40::/121\",\r\n - \ \"2603:1016:1400:60::/121\",\r\n \"2603:1016:1400:68::/121\",\r\n - \ \"2603:1016:1400:70::/121\",\r\n \"2603:1016:1400:78::/121\",\r\n - \ \"2603:1017::/121\",\r\n \"2603:1017:0:20::/121\",\r\n - \ \"2603:1017:0:40::/121\",\r\n \"2603:1017:0:60::/121\",\r\n - \ \"2603:1017:0:68::/121\",\r\n \"2603:1017:0:70::/121\",\r\n - \ \"2603:1017:0:78::/121\",\r\n \"2603:1026:3000::/121\",\r\n - \ \"2603:1026:3000:20::/121\",\r\n \"2603:1026:3000:40::/121\",\r\n - \ \"2603:1026:3000:60::/121\",\r\n \"2603:1026:3000:80::/121\",\r\n - \ \"2603:1026:3000:a0::/121\",\r\n \"2603:1026:3000:c0::/121\",\r\n - \ \"2603:1026:3000:c8::/121\",\r\n \"2603:1026:3000:d0::/121\",\r\n - \ \"2603:1026:3000:d8::/121\",\r\n \"2603:1026:3000:e0::/121\",\r\n - \ \"2603:1026:3000:e8::/121\",\r\n \"2603:1026:3000:f0::/121\",\r\n - \ \"2603:1026:3000:f8::/121\",\r\n \"2603:1026:3000:100::/121\",\r\n - \ \"2603:1026:3000:108::/121\",\r\n \"2603:1026:3000:110::/121\",\r\n - \ \"2603:1026:3000:118::/121\",\r\n \"2603:1026:3000:120::/121\",\r\n - \ \"2603:1026:3000:140::/121\",\r\n \"2603:1026:3000:148::/121\",\r\n - \ \"2603:1026:3000:150::/121\",\r\n \"2603:1026:3000:158::/121\",\r\n - \ \"2603:1026:3000:160::/121\",\r\n \"2603:1026:3000:1a0::/121\",\r\n - \ \"2603:1026:3000:1c0::/121\",\r\n \"2603:1026:3000:1e0::/121\",\r\n - \ \"2603:1026:3000:200::/121\",\r\n \"2603:1026:3000:220::/121\",\r\n - \ \"2603:1027:1::/121\",\r\n \"2603:1027:1:20::/121\",\r\n - \ \"2603:1027:1:40::/121\",\r\n \"2603:1027:1:60::/121\",\r\n - \ \"2603:1027:1:80::/121\",\r\n \"2603:1027:1:a0::/121\",\r\n - \ \"2603:1027:1:c0::/121\",\r\n \"2603:1027:1:c8::/121\",\r\n - \ \"2603:1027:1:d0::/121\",\r\n \"2603:1027:1:d8::/121\",\r\n - \ \"2603:1027:1:e0::/121\",\r\n \"2603:1027:1:e8::/121\",\r\n - \ \"2603:1027:1:f0::/121\",\r\n \"2603:1027:1:f8::/121\",\r\n - \ \"2603:1027:1:100::/121\",\r\n \"2603:1027:1:108::/121\",\r\n - \ \"2603:1027:1:110::/121\",\r\n \"2603:1027:1:118::/121\",\r\n - \ \"2603:1027:1:120::/121\",\r\n \"2603:1027:1:140::/121\",\r\n - \ \"2603:1027:1:148::/121\",\r\n \"2603:1027:1:150::/121\",\r\n - \ \"2603:1027:1:158::/121\",\r\n \"2603:1027:1:160::/121\",\r\n - \ \"2603:1027:1:1a0::/121\",\r\n \"2603:1027:1:1c0::/121\",\r\n - \ \"2603:1027:1:1e0::/121\",\r\n \"2603:1027:1:200::/121\",\r\n - \ \"2603:1027:1:220::/121\",\r\n \"2603:1036:3000::/121\",\r\n - \ \"2603:1036:3000:8::/121\",\r\n \"2603:1036:3000:10::/121\",\r\n - \ \"2603:1036:3000:18::/121\",\r\n \"2603:1036:3000:20::/121\",\r\n - \ \"2603:1036:3000:28::/121\",\r\n \"2603:1036:3000:30::/121\",\r\n - \ \"2603:1036:3000:38::/121\",\r\n \"2603:1036:3000:40::/121\",\r\n - \ \"2603:1036:3000:48::/121\",\r\n \"2603:1036:3000:50::/121\",\r\n - \ \"2603:1036:3000:58::/121\",\r\n \"2603:1036:3000:60::/121\",\r\n - \ \"2603:1036:3000:80::/121\",\r\n \"2603:1036:3000:a0::/121\",\r\n - \ \"2603:1036:3000:c0::/121\",\r\n \"2603:1036:3000:c8::/121\",\r\n - \ \"2603:1036:3000:d0::/121\",\r\n \"2603:1036:3000:d8::/121\",\r\n - \ \"2603:1036:3000:e0::/121\",\r\n \"2603:1036:3000:100::/121\",\r\n - \ \"2603:1036:3000:108::/121\",\r\n \"2603:1036:3000:110::/121\",\r\n - \ \"2603:1036:3000:118::/121\",\r\n \"2603:1036:3000:120::/121\",\r\n - \ \"2603:1036:3000:128::/121\",\r\n \"2603:1036:3000:130::/121\",\r\n - \ \"2603:1036:3000:138::/121\",\r\n \"2603:1036:3000:140::/121\",\r\n - \ \"2603:1036:3000:148::/121\",\r\n \"2603:1036:3000:150::/121\",\r\n - \ \"2603:1036:3000:158::/121\",\r\n \"2603:1036:3000:160::/121\",\r\n - \ \"2603:1036:3000:180::/121\",\r\n \"2603:1036:3000:1a0::/121\",\r\n - \ \"2603:1036:3000:1c0::/121\",\r\n \"2603:1037:1::/121\",\r\n - \ \"2603:1037:1:8::/121\",\r\n \"2603:1037:1:10::/121\",\r\n - \ \"2603:1037:1:18::/121\",\r\n \"2603:1037:1:20::/121\",\r\n - \ \"2603:1037:1:28::/121\",\r\n \"2603:1037:1:30::/121\",\r\n - \ \"2603:1037:1:38::/121\",\r\n \"2603:1037:1:40::/121\",\r\n - \ \"2603:1037:1:48::/121\",\r\n \"2603:1037:1:50::/121\",\r\n - \ \"2603:1037:1:58::/121\",\r\n \"2603:1037:1:60::/121\",\r\n - \ \"2603:1037:1:80::/121\",\r\n \"2603:1037:1:a0::/121\",\r\n - \ \"2603:1037:1:c0::/121\",\r\n \"2603:1037:1:c8::/121\",\r\n - \ \"2603:1037:1:d0::/121\",\r\n \"2603:1037:1:d8::/121\",\r\n - \ \"2603:1037:1:e0::/121\",\r\n \"2603:1037:1:100::/121\",\r\n - \ \"2603:1037:1:108::/121\",\r\n \"2603:1037:1:110::/121\",\r\n - \ \"2603:1037:1:118::/121\",\r\n \"2603:1037:1:120::/121\",\r\n - \ \"2603:1037:1:128::/121\",\r\n \"2603:1037:1:130::/121\",\r\n - \ \"2603:1037:1:138::/121\",\r\n \"2603:1037:1:140::/121\",\r\n - \ \"2603:1037:1:148::/121\",\r\n \"2603:1037:1:150::/121\",\r\n - \ \"2603:1037:1:158::/121\",\r\n \"2603:1037:1:160::/121\",\r\n - \ \"2603:1037:1:180::/121\",\r\n \"2603:1037:1:1a0::/121\",\r\n - \ \"2603:1037:1:1c0::/121\",\r\n \"2603:1046:2000:20::/121\",\r\n - \ \"2603:1046:2000:40::/121\",\r\n \"2603:1046:2000:60::/121\",\r\n - \ \"2603:1046:2000:80::/121\",\r\n \"2603:1046:2000:88::/121\",\r\n - \ \"2603:1046:2000:90::/121\",\r\n \"2603:1046:2000:98::/121\",\r\n - \ \"2603:1046:2000:a0::/121\",\r\n \"2603:1046:2000:e0::/121\",\r\n - \ \"2603:1046:2000:100::/121\",\r\n \"2603:1046:2000:120::/121\",\r\n - \ \"2603:1046:2000:140::/121\",\r\n \"2603:1046:2000:148::/121\",\r\n - \ \"2603:1046:2000:150::/121\",\r\n \"2603:1046:2000:158::/121\",\r\n - \ \"2603:1046:2000:160::/121\",\r\n \"2603:1046:2000:168::/121\",\r\n - \ \"2603:1046:2000:170::/121\",\r\n \"2603:1046:2000:178::/121\",\r\n - \ \"2603:1046:2000:180::/121\",\r\n \"2603:1046:2000:188::/121\",\r\n - \ \"2603:1046:2000:190::/121\",\r\n \"2603:1046:2000:198::/121\",\r\n - \ \"2603:1047:1:20::/121\",\r\n \"2603:1047:1:40::/121\",\r\n - \ \"2603:1047:1:60::/121\",\r\n \"2603:1047:1:80::/121\",\r\n - \ \"2603:1047:1:88::/121\",\r\n \"2603:1047:1:90::/121\",\r\n - \ \"2603:1047:1:98::/121\",\r\n \"2603:1047:1:a0::/121\",\r\n - \ \"2603:1047:1:e0::/121\",\r\n \"2603:1047:1:100::/121\",\r\n - \ \"2603:1047:1:120::/121\",\r\n \"2603:1047:1:140::/121\",\r\n - \ \"2603:1047:1:148::/121\",\r\n \"2603:1047:1:150::/121\",\r\n - \ \"2603:1047:1:158::/121\",\r\n \"2603:1047:1:160::/121\",\r\n - \ \"2603:1047:1:168::/121\",\r\n \"2603:1047:1:170::/121\",\r\n - \ \"2603:1047:1:178::/121\",\r\n \"2603:1047:1:180::/121\",\r\n - \ \"2603:1047:1:188::/121\",\r\n \"2603:1047:1:190::/121\",\r\n - \ \"2603:1047:1:198::/121\",\r\n \"2603:1056:2000::/121\",\r\n - \ \"2603:1056:2000:20::/121\",\r\n \"2603:1056:2000:28::/121\",\r\n - \ \"2603:1056:2000:30::/121\",\r\n \"2603:1056:2000:38::/121\",\r\n - \ \"2603:1056:2000:60::/121\",\r\n \"2603:1057:2::/121\",\r\n - \ \"2603:1057:2:20::/121\",\r\n \"2603:1057:2:28::/121\",\r\n - \ \"2603:1057:2:30::/121\",\r\n \"2603:1057:2:38::/121\",\r\n - \ \"2603:1057:2:60::/121\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureActiveDirectoryDomainServices\",\r\n \"id\": \"AzureActiveDirectoryDomainServices\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureIdentity\",\r\n \"addressPrefixes\": [\r\n \"13.64.151.161/32\",\r\n - \ \"13.66.141.64/27\",\r\n \"13.67.9.224/27\",\r\n \"13.69.66.160/27\",\r\n - \ \"13.69.229.96/27\",\r\n \"13.70.73.32/27\",\r\n \"13.71.172.160/27\",\r\n - \ \"13.71.195.224/27\",\r\n \"13.73.240.32/27\",\r\n \"13.74.249.156/32\",\r\n - \ \"13.75.38.32/27\",\r\n \"13.75.105.168/32\",\r\n \"13.77.52.160/27\",\r\n - \ \"13.78.108.192/27\",\r\n \"13.78.172.246/32\",\r\n \"13.79.37.247/32\",\r\n - \ \"13.86.219.0/27\",\r\n \"13.87.57.160/27\",\r\n \"13.87.123.160/27\",\r\n - \ \"13.89.174.0/27\",\r\n \"20.36.107.192/27\",\r\n \"20.36.115.64/27\",\r\n - \ \"20.37.75.96/27\",\r\n \"20.43.120.32/27\",\r\n \"20.44.3.160/27\",\r\n - \ \"20.44.16.32/27\",\r\n \"23.101.0.70/32\",\r\n \"23.101.6.190/32\",\r\n - \ \"40.68.160.142/32\",\r\n \"40.69.107.160/27\",\r\n \"40.71.13.0/27\",\r\n - \ \"40.74.101.64/27\",\r\n \"40.74.146.192/27\",\r\n \"40.78.195.160/27\",\r\n - \ \"40.78.203.64/27\",\r\n \"40.79.131.128/27\",\r\n \"40.79.179.128/27\",\r\n - \ \"40.83.144.56/32\",\r\n \"51.140.148.192/27\",\r\n \"51.140.211.192/27\",\r\n - \ \"52.138.65.157/32\",\r\n \"52.138.68.41/32\",\r\n \"52.161.13.71/32\",\r\n - \ \"52.161.13.95/32\",\r\n \"52.161.110.169/32\",\r\n \"52.162.110.96/27\",\r\n - \ \"52.169.125.119/32\",\r\n \"52.169.218.0/32\",\r\n \"52.174.189.149/32\",\r\n - \ \"52.175.18.134/32\",\r\n \"52.178.27.112/32\",\r\n \"52.179.122.218/32\",\r\n - \ \"52.179.126.223/32\",\r\n \"52.180.177.87/32\",\r\n \"52.180.179.108/32\",\r\n - \ \"52.180.181.61/32\",\r\n \"52.180.183.8/32\",\r\n \"52.187.19.1/32\",\r\n - \ \"52.187.113.48/32\",\r\n \"52.187.117.83/32\",\r\n \"52.187.120.237/32\",\r\n - \ \"52.225.184.198/32\",\r\n \"52.225.188.89/32\",\r\n \"52.231.19.128/27\",\r\n - \ \"52.231.147.192/27\",\r\n \"65.52.251.96/27\",\r\n \"104.40.84.19/32\",\r\n - \ \"104.40.87.209/32\",\r\n \"104.40.156.18/32\",\r\n \"104.41.159.212/32\",\r\n - \ \"104.45.138.161/32\",\r\n \"104.211.147.160/27\",\r\n - \ \"191.233.204.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureAdvancedThreatProtection\",\r\n \"id\": \"AzureAdvancedThreatProtection\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": - [\r\n \"13.72.105.31/32\",\r\n \"13.72.105.76/32\",\r\n - \ \"13.93.176.195/32\",\r\n \"13.93.176.215/32\",\r\n \"20.36.120.112/29\",\r\n - \ \"20.37.64.112/29\",\r\n \"20.37.156.192/29\",\r\n \"20.37.195.8/29\",\r\n - \ \"20.37.224.112/29\",\r\n \"20.38.84.96/29\",\r\n \"20.38.136.112/29\",\r\n - \ \"20.39.11.16/29\",\r\n \"20.41.4.96/29\",\r\n \"20.41.65.128/29\",\r\n - \ \"20.41.192.112/29\",\r\n \"20.42.4.192/29\",\r\n \"20.42.129.176/29\",\r\n - \ \"20.42.224.112/29\",\r\n \"20.43.41.144/29\",\r\n \"20.43.65.136/29\",\r\n - \ \"20.43.130.88/29\",\r\n \"20.45.112.112/29\",\r\n \"20.45.192.112/29\",\r\n - \ \"20.150.160.112/29\",\r\n \"20.184.13.55/32\",\r\n \"20.184.14.129/32\",\r\n - \ \"20.189.106.120/29\",\r\n \"20.192.160.24/29\",\r\n \"20.192.225.16/29\",\r\n - \ \"40.65.107.78/32\",\r\n \"40.65.111.206/32\",\r\n \"40.67.48.112/29\",\r\n - \ \"40.74.30.96/29\",\r\n \"40.80.56.112/29\",\r\n \"40.80.168.112/29\",\r\n - \ \"40.80.188.16/29\",\r\n \"40.82.253.64/29\",\r\n \"40.85.133.119/32\",\r\n - \ \"40.85.133.178/32\",\r\n \"40.87.44.77/32\",\r\n \"40.87.45.222/32\",\r\n - \ \"40.89.16.112/29\",\r\n \"40.119.9.224/29\",\r\n \"51.104.25.144/29\",\r\n - \ \"51.105.80.112/29\",\r\n \"51.105.88.112/29\",\r\n \"51.107.48.112/29\",\r\n - \ \"51.107.144.112/29\",\r\n \"51.120.40.112/29\",\r\n \"51.120.224.112/29\",\r\n - \ \"51.137.161.128/29\",\r\n \"51.143.183.3/32\",\r\n \"51.143.183.52/32\",\r\n - \ \"51.143.192.112/29\",\r\n \"52.136.48.112/29\",\r\n \"52.140.104.112/29\",\r\n - \ \"52.150.139.64/29\",\r\n \"52.170.0.116/32\",\r\n \"52.170.1.228/32\",\r\n - \ \"52.170.249.197/32\",\r\n \"52.174.66.179/32\",\r\n \"52.174.66.180/32\",\r\n - \ \"52.225.176.98/32\",\r\n \"52.225.181.34/32\",\r\n \"52.225.183.206/32\",\r\n - \ \"52.228.81.128/29\",\r\n \"104.42.25.10/32\",\r\n \"104.42.29.8/32\",\r\n - \ \"168.63.46.233/32\",\r\n \"168.63.46.241/32\",\r\n \"191.233.8.24/29\",\r\n - \ \"191.235.225.136/29\",\r\n \"2603:1000:104:1::140/123\",\r\n - \ \"2603:1010:6:1::140/123\",\r\n \"2603:1020:5:1::140/123\",\r\n - \ \"2603:1020:206:1::140/123\",\r\n \"2603:1020:705:1::140/123\",\r\n - \ \"2603:1020:805:1::140/123\",\r\n \"2603:1020:a04:1::140/123\",\r\n - \ \"2603:1020:c04:1::140/123\",\r\n \"2603:1020:e04:1::140/123\",\r\n - \ \"2603:1020:1004::140/123\",\r\n \"2603:1030:10:1::140/123\",\r\n - \ \"2603:1030:104:1::140/123\",\r\n \"2603:1030:210:1::140/123\",\r\n - \ \"2603:1030:40b:1::140/123\",\r\n \"2603:1030:40c:1::140/123\",\r\n - \ \"2603:1030:504:1::140/123\",\r\n \"2603:1030:807:1::140/123\",\r\n - \ \"2603:1030:c06:1::140/123\",\r\n \"2603:1030:f05:1::140/123\",\r\n - \ \"2603:1040:5:1::140/123\",\r\n \"2603:1040:407:1::140/123\",\r\n - \ \"2603:1040:904:1::140/123\",\r\n \"2603:1040:a06:1::140/123\",\r\n - \ \"2603:1040:d04::140/123\",\r\n \"2603:1040:f05:1::140/123\",\r\n - \ \"2603:1050:6:1::140/123\",\r\n \"2603:1050:403::140/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.AustraliaCentral\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"20.37.224.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.CanadaEast\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"40.89.16.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.JapanWest\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.JapanWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"40.80.56.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.KoreaSouth\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"40.80.168.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.NorwayWest\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"51.120.224.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.SouthIndia\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"20.41.192.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.UKNorth\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.UKNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"51.105.80.112/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.WestUS2\",\r\n - \ \"id\": \"AzureAdvancedThreatProtection.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureAdvancedThreatProtection\",\r\n \"addressPrefixes\": [\r\n \"20.42.129.176/29\",\r\n - \ \"40.65.107.78/32\",\r\n \"40.65.111.206/32\",\r\n \"2603:1030:c06:1::140/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.CentralUS\",\r\n - \ \"id\": \"AzureAPIForFHIR.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n - \ \"addressPrefixes\": [\r\n \"52.182.141.14/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.FranceSouth\",\r\n - \ \"id\": \"AzureAPIForFHIR.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n - \ \"addressPrefixes\": [\r\n \"51.138.160.0/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.SoutheastAsia\",\r\n - \ \"id\": \"AzureAPIForFHIR.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.40.183/32\",\r\n \"40.78.238.58/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.UKNorth\",\r\n - \ \"id\": \"AzureAPIForFHIR.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": - [\r\n \"13.87.124.136/31\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureAPIForFHIR.UKSouth2\",\r\n \"id\": \"AzureAPIForFHIR.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": [\r\n \"13.87.58.136/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.WestEurope\",\r\n - \ \"id\": \"AzureAPIForFHIR.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.80.124.132/32\",\r\n \"52.178.17.0/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.WestIndia\",\r\n - \ \"id\": \"AzureAPIForFHIR.WestIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.128.170/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup\",\r\n \"id\": - \"AzureBackup\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.192/26\",\r\n - \ \"13.66.141.0/27\",\r\n \"13.67.12.0/24\",\r\n \"13.67.13.0/25\",\r\n - \ \"13.69.65.32/27\",\r\n \"13.69.65.128/25\",\r\n \"13.69.107.0/27\",\r\n - \ \"13.69.107.128/25\",\r\n \"13.69.228.128/25\",\r\n \"13.69.229.0/27\",\r\n - \ \"13.70.73.192/27\",\r\n \"13.70.74.0/26\",\r\n \"13.71.172.0/26\",\r\n - \ \"13.71.172.64/27\",\r\n \"13.71.195.64/26\",\r\n \"13.71.195.128/27\",\r\n - \ \"13.74.107.192/27\",\r\n \"13.74.108.0/25\",\r\n \"13.75.36.128/25\",\r\n - \ \"13.75.37.0/24\",\r\n \"13.77.52.32/27\",\r\n \"13.77.52.64/26\",\r\n - \ \"13.78.108.32/27\",\r\n \"13.78.108.64/26\",\r\n \"13.86.218.0/25\",\r\n - \ \"13.86.218.128/26\",\r\n \"13.87.57.0/26\",\r\n \"13.87.57.64/27\",\r\n - \ \"13.87.123.0/26\",\r\n \"13.87.123.64/27\",\r\n \"13.89.171.128/26\",\r\n - \ \"13.89.171.192/27\",\r\n \"20.36.107.32/27\",\r\n \"20.36.107.64/26\",\r\n - \ \"20.36.114.224/27\",\r\n \"20.36.115.0/26\",\r\n \"20.37.75.0/26\",\r\n - \ \"20.37.75.64/27\",\r\n \"20.38.147.0/27\",\r\n \"20.38.147.64/26\",\r\n - \ \"20.44.3.64/26\",\r\n \"20.44.3.128/27\",\r\n \"20.44.8.32/27\",\r\n - \ \"20.44.8.64/26\",\r\n \"20.44.16.128/27\",\r\n \"20.44.16.192/26\",\r\n - \ \"20.44.27.128/27\",\r\n \"20.45.123.0/26\",\r\n \"20.45.123.64/28\",\r\n - \ \"20.45.125.192/27\",\r\n \"20.49.82.192/26\",\r\n \"20.49.83.0/27\",\r\n - \ \"20.49.90.192/26\",\r\n \"20.49.91.0/27\",\r\n \"20.150.171.96/27\",\r\n - \ \"20.150.171.128/26\",\r\n \"20.150.179.80/28\",\r\n \"20.150.179.128/26\",\r\n - \ \"20.150.181.64/27\",\r\n \"20.150.187.80/28\",\r\n \"20.150.187.128/26\",\r\n - \ \"20.192.99.80/28\",\r\n \"20.192.99.128/26\",\r\n \"20.192.235.32/27\",\r\n - \ \"20.192.235.64/26\",\r\n \"20.193.203.0/26\",\r\n \"20.193.203.64/27\",\r\n - \ \"20.194.66.192/26\",\r\n \"20.194.67.0/27\",\r\n \"23.98.83.0/27\",\r\n - \ \"23.98.83.128/25\",\r\n \"23.98.84.0/24\",\r\n \"40.67.59.96/27\",\r\n - \ \"40.67.59.128/26\",\r\n \"40.69.107.32/27\",\r\n \"40.69.107.64/26\",\r\n - \ \"40.70.147.128/26\",\r\n \"40.70.147.192/27\",\r\n \"40.71.12.0/25\",\r\n - \ \"40.71.12.128/26\",\r\n \"40.74.98.64/26\",\r\n \"40.74.98.128/27\",\r\n - \ \"40.74.146.96/27\",\r\n \"40.74.146.128/26\",\r\n \"40.75.34.96/27\",\r\n - \ \"40.75.34.192/26\",\r\n \"40.78.195.32/27\",\r\n \"40.78.195.64/26\",\r\n - \ \"40.78.202.160/27\",\r\n \"40.78.202.192/26\",\r\n \"40.78.227.64/26\",\r\n - \ \"40.78.227.128/25\",\r\n \"40.78.234.192/27\",\r\n \"40.78.235.0/24\",\r\n - \ \"40.78.236.0/25\",\r\n \"40.78.243.32/27\",\r\n \"40.78.243.64/26\",\r\n - \ \"40.78.250.224/27\",\r\n \"40.78.251.0/26\",\r\n \"40.79.131.0/26\",\r\n - \ \"40.79.131.64/27\",\r\n \"40.79.155.64/26\",\r\n \"40.79.155.128/25\",\r\n - \ \"40.79.162.128/27\",\r\n \"40.79.162.192/26\",\r\n \"40.79.170.64/26\",\r\n - \ \"40.79.170.128/27\",\r\n \"40.79.171.32/27\",\r\n \"40.79.179.32/27\",\r\n - \ \"40.79.179.64/26\",\r\n \"40.79.187.32/27\",\r\n \"40.79.187.64/26\",\r\n - \ \"40.79.195.32/27\",\r\n \"40.79.195.64/26\",\r\n \"40.80.51.0/27\",\r\n - \ \"40.120.74.192/26\",\r\n \"40.120.75.0/27\",\r\n \"51.12.99.96/27\",\r\n - \ \"51.12.99.128/26\",\r\n \"51.12.203.96/27\",\r\n \"51.12.203.128/26\",\r\n - \ \"51.12.227.80/28\",\r\n \"51.12.227.128/26\",\r\n \"51.12.235.80/28\",\r\n - \ \"51.12.235.128/26\",\r\n \"51.105.67.32/27\",\r\n \"51.105.67.64/26\",\r\n - \ \"51.105.75.0/27\",\r\n \"51.105.75.64/26\",\r\n \"51.107.59.64/26\",\r\n - \ \"51.107.59.128/27\",\r\n \"51.107.155.64/26\",\r\n \"51.107.155.128/27\",\r\n - \ \"51.116.59.64/26\",\r\n \"51.116.59.128/27\",\r\n \"51.116.155.128/26\",\r\n - \ \"51.116.155.192/27\",\r\n \"51.116.156.144/28\",\r\n \"51.116.156.192/26\",\r\n - \ \"51.116.245.0/26\",\r\n \"51.116.245.64/27\",\r\n \"51.116.250.240/28\",\r\n - \ \"51.116.251.64/26\",\r\n \"51.116.253.0/27\",\r\n \"51.120.99.96/27\",\r\n - \ \"51.120.99.128/26\",\r\n \"51.120.107.80/28\",\r\n \"51.120.107.128/26\",\r\n - \ \"51.120.211.80/28\",\r\n \"51.120.211.128/26\",\r\n \"51.120.219.96/27\",\r\n - \ \"51.120.219.128/26\",\r\n \"51.140.148.64/26\",\r\n \"51.140.148.128/27\",\r\n - \ \"51.140.211.32/27\",\r\n \"51.140.211.64/26\",\r\n \"52.138.90.160/27\",\r\n - \ \"52.138.90.192/26\",\r\n \"52.138.226.192/27\",\r\n \"52.138.227.0/25\",\r\n - \ \"52.162.107.192/26\",\r\n \"52.162.110.0/27\",\r\n \"52.167.106.192/27\",\r\n - \ \"52.167.107.0/26\",\r\n \"52.182.139.64/27\",\r\n \"52.182.139.128/26\",\r\n - \ \"52.231.19.0/26\",\r\n \"52.231.19.64/27\",\r\n \"52.231.147.32/27\",\r\n - \ \"52.231.147.64/26\",\r\n \"52.236.187.0/27\",\r\n \"52.236.187.128/25\",\r\n - \ \"52.246.155.0/27\",\r\n \"52.246.155.64/26\",\r\n \"65.52.251.0/26\",\r\n - \ \"65.52.251.64/27\",\r\n \"102.133.27.64/26\",\r\n \"102.133.27.128/27\",\r\n - \ \"102.133.123.96/27\",\r\n \"102.133.155.64/26\",\r\n \"102.133.155.128/27\",\r\n - \ \"102.133.251.0/27\",\r\n \"104.211.82.0/26\",\r\n \"104.211.82.64/27\",\r\n - \ \"104.211.147.0/26\",\r\n \"104.211.147.64/27\",\r\n \"104.214.19.96/27\",\r\n - \ \"104.214.19.128/26\",\r\n \"191.233.50.224/27\",\r\n \"191.233.51.64/26\",\r\n - \ \"191.233.204.0/26\",\r\n \"191.233.204.64/27\",\r\n \"191.234.147.80/28\",\r\n - \ \"191.234.147.128/26\",\r\n \"191.234.149.160/27\",\r\n - \ \"191.234.155.80/28\",\r\n \"191.234.155.128/26\",\r\n - \ \"191.234.157.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.AustraliaCentral\",\r\n \"id\": \"AzureBackup.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.36.107.32/27\",\r\n - \ \"20.36.107.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.AustraliaCentral2\",\r\n \"id\": \"AzureBackup.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.224/27\",\r\n - \ \"20.36.115.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.AustraliaEast\",\r\n \"id\": \"AzureBackup.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.70.73.192/27\",\r\n - \ \"13.70.74.0/26\",\r\n \"40.79.162.128/27\",\r\n \"40.79.162.192/26\",\r\n - \ \"40.79.170.64/26\",\r\n \"40.79.170.128/27\",\r\n \"40.79.171.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureBackup.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.52.32/27\",\r\n \"13.77.52.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.BrazilSouth\",\r\n - \ \"id\": \"AzureBackup.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.204.0/26\",\r\n \"191.233.204.64/27\",\r\n - \ \"191.234.147.80/28\",\r\n \"191.234.147.128/26\",\r\n - \ \"191.234.149.160/27\",\r\n \"191.234.155.80/28\",\r\n - \ \"191.234.155.128/26\",\r\n \"191.234.157.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.CanadaCentral\",\r\n - \ \"id\": \"AzureBackup.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.172.0/26\",\r\n \"13.71.172.64/27\",\r\n - \ \"20.38.147.0/27\",\r\n \"20.38.147.64/26\",\r\n \"52.246.155.0/27\",\r\n - \ \"52.246.155.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.CanadaEast\",\r\n \"id\": \"AzureBackup.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"40.69.107.32/27\",\r\n - \ \"40.69.107.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.CentralIndia\",\r\n \"id\": \"AzureBackup.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.192.99.80/28\",\r\n - \ \"20.192.99.128/26\",\r\n \"40.80.51.0/27\",\r\n \"104.211.82.0/26\",\r\n - \ \"104.211.82.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.CentralUS\",\r\n \"id\": \"AzureBackup.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.128/26\",\r\n - \ \"13.89.171.192/27\",\r\n \"20.44.8.32/27\",\r\n \"20.44.8.64/26\",\r\n - \ \"52.182.139.64/27\",\r\n \"52.182.139.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.CentralUSEUAP\",\r\n - \ \"id\": \"AzureBackup.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.202.160/27\",\r\n \"40.78.202.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.EastAsia\",\r\n - \ \"id\": \"AzureBackup.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"13.75.36.128/25\",\r\n \"13.75.37.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.EastUS\",\r\n - \ \"id\": \"AzureBackup.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"40.71.12.0/25\",\r\n \"40.71.12.128/26\",\r\n \"40.78.227.64/26\",\r\n - \ \"40.78.227.128/25\",\r\n \"40.79.155.64/26\",\r\n \"40.79.155.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.EastUS2\",\r\n - \ \"id\": \"AzureBackup.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"20.44.16.128/27\",\r\n \"20.44.16.192/26\",\r\n - \ \"40.70.147.128/26\",\r\n \"40.70.147.192/27\",\r\n \"52.167.106.192/27\",\r\n - \ \"52.167.107.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.EastUS2EUAP\",\r\n \"id\": \"AzureBackup.EastUS2EUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.96/27\",\r\n - \ \"40.74.146.128/26\",\r\n \"40.75.34.96/27\",\r\n \"40.75.34.192/26\",\r\n - \ \"52.138.90.160/27\",\r\n \"52.138.90.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.FranceCentral\",\r\n - \ \"id\": \"AzureBackup.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.131.0/26\",\r\n \"40.79.131.64/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.FranceSouth\",\r\n - \ \"id\": \"AzureBackup.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.179.32/27\",\r\n \"40.79.179.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.GermanyNorth\",\r\n - \ \"id\": \"AzureBackup.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.59.64/26\",\r\n \"51.116.59.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.GermanyWestCentral\",\r\n - \ \"id\": \"AzureBackup.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.155.128/26\",\r\n \"51.116.155.192/27\",\r\n - \ \"51.116.156.144/28\",\r\n \"51.116.156.192/26\",\r\n \"51.116.245.0/26\",\r\n - \ \"51.116.245.64/27\",\r\n \"51.116.250.240/28\",\r\n \"51.116.251.64/26\",\r\n - \ \"51.116.253.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.JapanEast\",\r\n \"id\": \"AzureBackup.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.78.108.32/27\",\r\n - \ \"13.78.108.64/26\",\r\n \"40.79.187.32/27\",\r\n \"40.79.187.64/26\",\r\n - \ \"40.79.195.32/27\",\r\n \"40.79.195.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.JapanWest\",\r\n - \ \"id\": \"AzureBackup.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"40.74.98.64/26\",\r\n \"40.74.98.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.KoreaCentral\",\r\n - \ \"id\": \"AzureBackup.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.27.128/27\",\r\n \"20.194.66.192/26\",\r\n - \ \"20.194.67.0/27\",\r\n \"52.231.19.0/26\",\r\n \"52.231.19.64/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.KoreaSouth\",\r\n - \ \"id\": \"AzureBackup.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"52.231.147.32/27\",\r\n \"52.231.147.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.NorthCentralUS\",\r\n - \ \"id\": \"AzureBackup.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"52.162.107.192/26\",\r\n \"52.162.110.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.NorthEurope\",\r\n - \ \"id\": \"AzureBackup.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.228.128/25\",\r\n \"13.69.229.0/27\",\r\n - \ \"13.74.107.192/27\",\r\n \"13.74.108.0/25\",\r\n \"52.138.226.192/27\",\r\n - \ \"52.138.227.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.NorwayEast\",\r\n \"id\": \"AzureBackup.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.120.99.96/27\",\r\n - \ \"51.120.99.128/26\",\r\n \"51.120.107.80/28\",\r\n \"51.120.107.128/26\",\r\n - \ \"51.120.211.80/28\",\r\n \"51.120.211.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.NorwayWest\",\r\n - \ \"id\": \"AzureBackup.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"51.120.219.96/27\",\r\n \"51.120.219.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureBackup.SouthAfricaNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.123.96/27\",\r\n \"102.133.155.64/26\",\r\n - \ \"102.133.155.128/27\",\r\n \"102.133.251.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SouthAfricaWest\",\r\n - \ \"id\": \"AzureBackup.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.27.64/26\",\r\n \"102.133.27.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SouthCentralUS\",\r\n - \ \"id\": \"AzureBackup.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.123.0/26\",\r\n \"20.45.123.64/28\",\r\n - \ \"20.45.125.192/27\",\r\n \"20.49.90.192/26\",\r\n \"20.49.91.0/27\",\r\n - \ \"104.214.19.96/27\",\r\n \"104.214.19.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SoutheastAsia\",\r\n - \ \"id\": \"AzureBackup.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.12.0/24\",\r\n \"13.67.13.0/25\",\r\n - \ \"23.98.83.0/27\",\r\n \"23.98.83.128/25\",\r\n \"23.98.84.0/24\",\r\n - \ \"40.78.234.192/27\",\r\n \"40.78.235.0/24\",\r\n \"40.78.236.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SouthIndia\",\r\n - \ \"id\": \"AzureBackup.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"40.78.195.32/27\",\r\n \"40.78.195.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureBackup.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.59.64/26\",\r\n \"51.107.59.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SwitzerlandWest\",\r\n - \ \"id\": \"AzureBackup.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.155.64/26\",\r\n \"51.107.155.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UAECentral\",\r\n - \ \"id\": \"AzureBackup.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"20.37.75.0/26\",\r\n \"20.37.75.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UAENorth\",\r\n - \ \"id\": \"AzureBackup.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"40.120.74.192/26\",\r\n \"40.120.75.0/27\",\r\n - \ \"65.52.251.0/26\",\r\n \"65.52.251.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UKNorth\",\r\n - \ \"id\": \"AzureBackup.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"13.87.123.0/26\",\r\n \"13.87.123.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UKSouth\",\r\n - \ \"id\": \"AzureBackup.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"51.105.67.32/27\",\r\n \"51.105.67.64/26\",\r\n - \ \"51.105.75.0/27\",\r\n \"51.105.75.64/26\",\r\n \"51.140.148.64/26\",\r\n - \ \"51.140.148.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.UKSouth2\",\r\n \"id\": \"AzureBackup.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.87.57.0/26\",\r\n - \ \"13.87.57.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.UKWest\",\r\n \"id\": \"AzureBackup.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.140.211.32/27\",\r\n - \ \"51.140.211.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.WestCentralUS\",\r\n \"id\": \"AzureBackup.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.71.195.64/26\",\r\n - \ \"13.71.195.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBackup.WestEurope\",\r\n \"id\": \"AzureBackup.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.69.65.32/27\",\r\n - \ \"13.69.65.128/25\",\r\n \"13.69.107.0/27\",\r\n \"13.69.107.128/25\",\r\n - \ \"52.236.187.0/27\",\r\n \"52.236.187.128/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.WestIndia\",\r\n - \ \"id\": \"AzureBackup.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"104.211.147.0/26\",\r\n \"104.211.147.64/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.WestUS\",\r\n - \ \"id\": \"AzureBackup.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"13.86.218.0/25\",\r\n \"13.86.218.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.WestUS2\",\r\n - \ \"id\": \"AzureBackup.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.192/26\",\r\n \"13.66.141.0/27\",\r\n - \ \"40.78.243.32/27\",\r\n \"40.78.243.64/26\",\r\n \"40.78.250.224/27\",\r\n - \ \"40.78.251.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBotService\",\r\n \"id\": \"AzureBotService\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.66.142.64/30\",\r\n - \ \"13.67.10.88/30\",\r\n \"13.69.67.56/30\",\r\n \"13.69.227.252/30\",\r\n - \ \"13.70.74.112/30\",\r\n \"13.71.173.240/30\",\r\n \"13.71.196.160/30\",\r\n - \ \"13.73.248.0/30\",\r\n \"13.75.39.72/30\",\r\n \"13.77.53.80/30\",\r\n - \ \"13.78.108.172/30\",\r\n \"13.86.219.168/30\",\r\n \"13.87.58.40/30\",\r\n - \ \"13.87.124.40/30\",\r\n \"13.89.171.116/30\",\r\n \"20.36.108.112/30\",\r\n - \ \"20.36.115.240/30\",\r\n \"20.36.120.64/30\",\r\n \"20.37.64.64/30\",\r\n - \ \"20.37.76.104/30\",\r\n \"20.37.152.64/30\",\r\n \"20.37.192.64/30\",\r\n - \ \"20.37.224.64/30\",\r\n \"20.38.80.64/30\",\r\n \"20.38.128.72/30\",\r\n - \ \"20.38.136.64/30\",\r\n \"20.39.8.64/30\",\r\n \"20.41.0.64/30\",\r\n - \ \"20.41.64.64/30\",\r\n \"20.41.192.64/30\",\r\n \"20.42.0.64/30\",\r\n - \ \"20.42.128.64/30\",\r\n \"20.42.224.64/30\",\r\n \"20.43.40.64/30\",\r\n - \ \"20.43.64.64/30\",\r\n \"20.43.121.8/30\",\r\n \"20.43.128.64/30\",\r\n - \ \"20.44.4.72/30\",\r\n \"20.44.17.24/30\",\r\n \"20.44.27.208/30\",\r\n - \ \"20.45.112.64/30\",\r\n \"20.45.123.112/30\",\r\n \"20.45.192.64/30\",\r\n - \ \"20.150.160.120/30\",\r\n \"20.189.104.64/30\",\r\n \"20.192.160.16/30\",\r\n - \ \"20.192.224.64/26\",\r\n \"40.67.48.64/30\",\r\n \"40.67.58.4/30\",\r\n - \ \"40.69.108.56/30\",\r\n \"40.71.12.244/30\",\r\n \"40.74.24.64/30\",\r\n - \ \"40.74.147.168/30\",\r\n \"40.78.196.56/30\",\r\n \"40.78.202.132/30\",\r\n - \ \"40.79.132.56/30\",\r\n \"40.79.180.24/30\",\r\n \"40.80.56.64/30\",\r\n - \ \"40.80.168.64/30\",\r\n \"40.80.176.32/30\",\r\n \"40.80.184.64/30\",\r\n - \ \"40.82.248.64/30\",\r\n \"40.89.16.64/30\",\r\n \"51.12.40.64/26\",\r\n - \ \"51.12.192.64/26\",\r\n \"51.104.8.248/30\",\r\n \"51.104.24.64/30\",\r\n - \ \"51.105.80.64/30\",\r\n \"51.105.88.64/30\",\r\n \"51.107.48.64/30\",\r\n - \ \"51.107.58.4/30\",\r\n \"51.107.144.64/30\",\r\n \"51.107.154.4/30\",\r\n - \ \"51.116.48.64/30\",\r\n \"51.116.144.64/30\",\r\n \"51.120.40.64/30\",\r\n - \ \"51.120.98.12/30\",\r\n \"51.120.218.4/30\",\r\n \"51.120.224.64/30\",\r\n - \ \"51.137.160.64/30\",\r\n \"51.140.212.72/30\",\r\n \"51.143.192.64/30\",\r\n - \ \"52.136.48.64/30\",\r\n \"52.140.104.64/30\",\r\n \"52.150.136.64/30\",\r\n - \ \"52.162.111.16/30\",\r\n \"52.228.80.64/30\",\r\n \"52.231.148.88/30\",\r\n - \ \"65.52.252.104/30\",\r\n \"102.133.28.88/30\",\r\n \"102.133.56.64/30\",\r\n - \ \"102.133.124.8/30\",\r\n \"102.133.216.64/30\",\r\n \"191.233.8.16/30\",\r\n - \ \"191.233.205.96/30\",\r\n \"191.235.224.64/30\",\r\n \"2603:1000:104:1::20/123\",\r\n - \ \"2603:1010:6:1::20/123\",\r\n \"2603:1020:5:1::20/123\",\r\n - \ \"2603:1020:206:1::20/123\",\r\n \"2603:1020:705:1::20/123\",\r\n - \ \"2603:1020:805:1::20/123\",\r\n \"2603:1020:a04:1::20/123\",\r\n - \ \"2603:1020:c04:1::20/123\",\r\n \"2603:1020:e04:1::20/123\",\r\n - \ \"2603:1020:1004::20/123\",\r\n \"2603:1030:10:1::20/123\",\r\n - \ \"2603:1030:104:1::20/123\",\r\n \"2603:1030:210:1::20/123\",\r\n - \ \"2603:1030:40b:1::20/123\",\r\n \"2603:1030:40c:1::20/123\",\r\n - \ \"2603:1030:504:1::20/123\",\r\n \"2603:1030:807:1::20/123\",\r\n - \ \"2603:1030:c06:1::20/123\",\r\n \"2603:1030:f05:1::20/123\",\r\n - \ \"2603:1040:5:1::20/123\",\r\n \"2603:1040:407:1::20/123\",\r\n - \ \"2603:1040:904:1::20/123\",\r\n \"2603:1040:a06:1::20/123\",\r\n - \ \"2603:1040:d04::20/123\",\r\n \"2603:1040:f05:1::20/123\",\r\n - \ \"2603:1050:6:1::20/123\",\r\n \"2603:1050:403::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.AustraliaCentral\",\r\n - \ \"id\": \"AzureBotService.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.108.112/30\",\r\n \"20.37.224.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.AustraliaCentral2\",\r\n - \ \"id\": \"AzureBotService.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.115.240/30\",\r\n \"20.36.120.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.AustraliaEast\",\r\n - \ \"id\": \"AzureBotService.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.74.112/30\",\r\n \"20.37.192.64/30\",\r\n - \ \"2603:1010:6:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.AustraliaSoutheast\",\r\n \"id\": - \"AzureBotService.AustraliaSoutheast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiasoutheast\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"13.77.53.80/30\",\r\n \"20.42.224.64/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBotService.BrazilSouth\",\r\n - \ \"id\": \"AzureBotService.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.205.96/30\",\r\n \"191.235.224.64/30\",\r\n - \ \"2603:1050:6:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.CanadaCentral\",\r\n \"id\": - \"AzureBotService.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"13.71.173.240/30\",\r\n \"52.228.80.64/30\",\r\n - \ \"2603:1030:f05:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.CanadaEast\",\r\n \"id\": - \"AzureBotService.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"40.69.108.56/30\",\r\n \"40.89.16.64/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CentralIndia\",\r\n - \ \"id\": \"AzureBotService.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.121.8/30\",\r\n \"52.140.104.64/30\",\r\n - \ \"2603:1040:a06:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.CentralUS\",\r\n \"id\": \"AzureBotService.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.116/30\",\r\n - \ \"20.37.152.64/30\",\r\n \"2603:1030:10:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CentralUSEUAP\",\r\n - \ \"id\": \"AzureBotService.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.192.64/30\",\r\n \"40.78.202.132/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.EastAsia\",\r\n - \ \"id\": \"AzureBotService.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.39.72/30\",\r\n \"20.189.104.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.EastUS\",\r\n - \ \"id\": \"AzureBotService.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"20.42.0.64/30\",\r\n \"40.71.12.244/30\",\r\n \"2603:1030:210:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.EastUS2\",\r\n - \ \"id\": \"AzureBotService.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"20.41.0.64/30\",\r\n \"20.44.17.24/30\",\r\n \"2603:1030:40c:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.EastUS2EUAP\",\r\n - \ \"id\": \"AzureBotService.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.8.64/30\",\r\n \"40.74.147.168/30\",\r\n - \ \"2603:1030:40b:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.FranceCentral\",\r\n \"id\": - \"AzureBotService.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"20.43.40.64/30\",\r\n \"40.79.132.56/30\",\r\n \"2603:1020:805:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.FranceSouth\",\r\n - \ \"id\": \"AzureBotService.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.180.24/30\",\r\n \"51.105.88.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.GermanyNorth\",\r\n - \ \"id\": \"AzureBotService.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.48.64/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureBotService.GermanyWestCentral\",\r\n - \ \"id\": \"AzureBotService.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.144.64/30\",\r\n \"2603:1020:c04:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.JapanEast\",\r\n - \ \"id\": \"AzureBotService.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.108.172/30\",\r\n \"20.43.64.64/30\",\r\n - \ \"2603:1040:407:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.JapanWest\",\r\n \"id\": \"AzureBotService.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.80.56.64/30\",\r\n - \ \"40.80.176.32/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBotService.KoreaCentral\",\r\n \"id\": \"AzureBotService.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.41.64.64/30\",\r\n - \ \"20.44.27.208/30\",\r\n \"2603:1040:f05:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.KoreaSouth\",\r\n - \ \"id\": \"AzureBotService.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.168.64/30\",\r\n \"52.231.148.88/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.NorthCentralUS\",\r\n - \ \"id\": \"AzureBotService.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.184.64/30\",\r\n \"52.162.111.16/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.NorthEurope\",\r\n - \ \"id\": \"AzureBotService.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.227.252/30\",\r\n \"20.38.80.64/30\",\r\n - \ \"2603:1020:5:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.NorwayEast\",\r\n \"id\": - \"AzureBotService.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"51.120.40.64/30\",\r\n \"51.120.98.12/30\",\r\n - \ \"2603:1020:e04:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.NorwayWest\",\r\n \"id\": - \"AzureBotService.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"51.120.218.4/30\",\r\n \"51.120.224.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureBotService.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.124.8/30\",\r\n \"102.133.216.64/30\",\r\n - \ \"2603:1000:104:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.SouthAfricaWest\",\r\n \"id\": - \"AzureBotService.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"102.133.28.88/30\",\r\n \"102.133.56.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SouthCentralUS\",\r\n - \ \"id\": \"AzureBotService.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.248.0/30\",\r\n \"20.45.123.112/30\",\r\n - \ \"2603:1030:807:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.SoutheastAsia\",\r\n \"id\": - \"AzureBotService.SoutheastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"13.67.10.88/30\",\r\n \"20.43.128.64/30\",\r\n \"2603:1040:5:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SouthIndia\",\r\n - \ \"id\": \"AzureBotService.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.192.64/30\",\r\n \"40.78.196.56/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureBotService.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.64/30\",\r\n \"51.107.58.4/30\",\r\n - \ \"2603:1020:a04:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.SwitzerlandWest\",\r\n \"id\": - \"AzureBotService.SwitzerlandWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"51.107.144.64/30\",\r\n \"51.107.154.4/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.UAECentral\",\r\n - \ \"id\": \"AzureBotService.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.64/30\",\r\n \"20.37.76.104/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.UAENorth\",\r\n - \ \"id\": \"AzureBotService.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.64/30\",\r\n \"65.52.252.104/30\",\r\n - \ \"2603:1040:904:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.UKNorth\",\r\n \"id\": \"AzureBotService.UKNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.87.124.40/30\",\r\n - \ \"51.105.80.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBotService.UKSouth\",\r\n \"id\": \"AzureBotService.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.104.8.248/30\",\r\n - \ \"51.104.24.64/30\",\r\n \"2603:1020:705:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.UKSouth2\",\r\n - \ \"id\": \"AzureBotService.UKSouth2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.58.40/30\",\r\n \"51.143.192.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.UKWest\",\r\n - \ \"id\": \"AzureBotService.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": - [\r\n \"51.137.160.64/30\",\r\n \"51.140.212.72/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.WestCentralUS\",\r\n - \ \"id\": \"AzureBotService.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.196.160/30\",\r\n \"52.150.136.64/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.WestEurope\",\r\n - \ \"id\": \"AzureBotService.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.67.56/30\",\r\n \"40.74.24.64/30\",\r\n - \ \"2603:1020:206:1::20/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureBotService.WestIndia\",\r\n \"id\": \"AzureBotService.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.38.128.72/30\",\r\n - \ \"52.136.48.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBotService.WestUS\",\r\n \"id\": \"AzureBotService.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.86.219.168/30\",\r\n - \ \"40.82.248.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureBotService.WestUS2\",\r\n \"id\": \"AzureBotService.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.66.142.64/30\",\r\n - \ \"20.42.128.64/30\",\r\n \"2603:1030:c06:1::20/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch\",\r\n - \ \"id\": \"AzureCognitiveSearch\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"13.64.32.141/32\",\r\n \"13.83.22.45/32\",\r\n \"13.83.22.74/32\",\r\n - \ \"13.83.22.119/32\",\r\n \"13.86.5.51/32\",\r\n \"20.36.120.128/26\",\r\n - \ \"20.37.64.128/26\",\r\n \"20.37.156.128/26\",\r\n \"20.37.193.192/26\",\r\n - \ \"20.37.224.128/26\",\r\n \"20.38.84.0/26\",\r\n \"20.38.136.128/26\",\r\n - \ \"20.39.8.192/26\",\r\n \"20.40.123.36/32\",\r\n \"20.40.123.39/32\",\r\n - \ \"20.40.123.46/32\",\r\n \"20.40.123.72/32\",\r\n \"20.41.4.128/26\",\r\n - \ \"20.41.65.64/26\",\r\n \"20.41.193.64/26\",\r\n \"20.42.4.128/26\",\r\n - \ \"20.42.24.90/32\",\r\n \"20.42.29.212/32\",\r\n \"20.42.30.105/32\",\r\n - \ \"20.42.34.190/32\",\r\n \"20.42.35.204/32\",\r\n \"20.42.129.192/26\",\r\n - \ \"20.42.225.192/26\",\r\n \"20.43.41.64/26\",\r\n \"20.43.65.64/26\",\r\n - \ \"20.43.130.128/26\",\r\n \"20.44.74.182/32\",\r\n \"20.44.76.53/32\",\r\n - \ \"20.44.76.61/32\",\r\n \"20.44.76.86/32\",\r\n \"20.45.0.49/32\",\r\n - \ \"20.45.2.122/32\",\r\n \"20.45.112.128/26\",\r\n \"20.45.192.128/26\",\r\n - \ \"20.150.160.128/26\",\r\n \"20.185.110.199/32\",\r\n \"20.189.106.128/26\",\r\n - \ \"20.189.129.94/32\",\r\n \"20.192.161.0/26\",\r\n \"20.192.225.64/26\",\r\n - \ \"23.100.238.27/32\",\r\n \"23.100.238.34/31\",\r\n \"23.100.238.37/32\",\r\n - \ \"40.65.173.157/32\",\r\n \"40.65.175.212/32\",\r\n \"40.65.175.228/32\",\r\n - \ \"40.66.56.233/32\",\r\n \"40.67.48.128/26\",\r\n \"40.74.18.154/32\",\r\n - \ \"40.74.30.0/26\",\r\n \"40.80.57.64/26\",\r\n \"40.80.169.64/26\",\r\n - \ \"40.80.186.192/26\",\r\n \"40.80.216.231/32\",\r\n \"40.80.217.38/32\",\r\n - \ \"40.80.219.46/32\",\r\n \"40.81.9.100/32\",\r\n \"40.81.9.131/32\",\r\n - \ \"40.81.9.203/32\",\r\n \"40.81.9.209/32\",\r\n \"40.81.9.213/32\",\r\n - \ \"40.81.9.221/32\",\r\n \"40.81.10.36/32\",\r\n \"40.81.12.133/32\",\r\n - \ \"40.81.15.8/32\",\r\n \"40.81.15.39/32\",\r\n \"40.81.29.152/32\",\r\n - \ \"40.81.188.130/32\",\r\n \"40.81.191.58/32\",\r\n \"40.81.253.154/32\",\r\n - \ \"40.82.155.65/32\",\r\n \"40.82.253.0/26\",\r\n \"40.89.17.64/26\",\r\n - \ \"40.90.190.180/32\",\r\n \"40.90.240.17/32\",\r\n \"40.91.93.84/32\",\r\n - \ \"40.91.127.116/32\",\r\n \"40.91.127.241/32\",\r\n \"40.119.11.0/26\",\r\n - \ \"51.12.41.64/26\",\r\n \"51.12.193.64/26\",\r\n \"51.104.25.64/26\",\r\n - \ \"51.105.80.128/26\",\r\n \"51.105.88.128/26\",\r\n \"51.107.48.128/26\",\r\n - \ \"51.107.144.128/26\",\r\n \"51.116.48.96/28\",\r\n \"51.116.144.96/28\",\r\n - \ \"51.120.40.128/26\",\r\n \"51.120.224.128/26\",\r\n \"51.132.43.66/32\",\r\n - \ \"51.137.161.64/26\",\r\n \"51.143.104.54/32\",\r\n \"51.143.104.90/32\",\r\n - \ \"51.143.192.128/26\",\r\n \"51.145.124.157/32\",\r\n \"51.145.124.158/32\",\r\n - \ \"51.145.176.249/32\",\r\n \"51.145.177.212/32\",\r\n \"51.145.178.138/32\",\r\n - \ \"51.145.178.140/32\",\r\n \"52.136.48.128/26\",\r\n \"52.137.24.236/32\",\r\n - \ \"52.137.26.114/32\",\r\n \"52.137.26.155/32\",\r\n \"52.137.26.198/32\",\r\n - \ \"52.137.27.49/32\",\r\n \"52.137.56.115/32\",\r\n \"52.137.60.208/32\",\r\n - \ \"52.139.0.47/32\",\r\n \"52.139.0.49/32\",\r\n \"52.140.105.64/26\",\r\n - \ \"52.140.233.105/32\",\r\n \"52.150.139.0/26\",\r\n \"52.151.235.150/32\",\r\n - \ \"52.151.235.242/32\",\r\n \"52.151.235.244/32\",\r\n \"52.155.216.245/32\",\r\n - \ \"52.155.217.84/32\",\r\n \"52.155.221.242/32\",\r\n \"52.155.221.250/32\",\r\n - \ \"52.155.222.35/32\",\r\n \"52.155.222.56/32\",\r\n \"52.157.22.233/32\",\r\n - \ \"52.157.231.64/32\",\r\n \"52.158.28.181/32\",\r\n \"52.158.30.241/32\",\r\n - \ \"52.158.208.11/32\",\r\n \"52.184.80.221/32\",\r\n \"52.185.224.13/32\",\r\n - \ \"52.185.224.38/32\",\r\n \"52.188.217.235/32\",\r\n \"52.188.218.228/32\",\r\n - \ \"52.188.218.239/32\",\r\n \"52.228.81.64/26\",\r\n \"52.242.214.45/32\",\r\n - \ \"52.253.133.74/32\",\r\n \"52.253.229.120/32\",\r\n \"102.133.128.33/32\",\r\n - \ \"102.133.217.128/26\",\r\n \"104.45.64.0/32\",\r\n \"104.45.64.147/32\",\r\n - \ \"104.45.64.224/32\",\r\n \"104.45.65.30/32\",\r\n \"104.45.65.89/32\",\r\n - \ \"191.233.9.0/26\",\r\n \"191.233.26.156/32\",\r\n \"191.235.225.64/26\",\r\n - \ \"2603:1000:104:1::180/121\",\r\n \"2603:1010:6:1::180/121\",\r\n - \ \"2603:1020:5:1::180/121\",\r\n \"2603:1020:206:1::180/121\",\r\n - \ \"2603:1020:705:1::180/121\",\r\n \"2603:1020:805:1::180/121\",\r\n - \ \"2603:1020:a04:1::180/121\",\r\n \"2603:1020:c04:1::180/121\",\r\n - \ \"2603:1020:e04:1::180/121\",\r\n \"2603:1020:1004::180/121\",\r\n - \ \"2603:1030:10:1::180/121\",\r\n \"2603:1030:104:1::180/121\",\r\n - \ \"2603:1030:210:1::180/121\",\r\n \"2603:1030:40b:1::180/121\",\r\n - \ \"2603:1030:40c:1::180/121\",\r\n \"2603:1030:504:1::180/121\",\r\n - \ \"2603:1030:807:1::180/121\",\r\n \"2603:1030:c06:1::180/121\",\r\n - \ \"2603:1030:f05:1::180/121\",\r\n \"2603:1040:5:1::180/121\",\r\n - \ \"2603:1040:407:1::180/121\",\r\n \"2603:1040:904:1::180/121\",\r\n - \ \"2603:1040:a06:1::180/121\",\r\n \"2603:1040:d04::180/121\",\r\n - \ \"2603:1040:f05:1::180/121\",\r\n \"2603:1050:6:1::180/121\",\r\n - \ \"2603:1050:403::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.AustraliaCentral\",\r\n \"id\": - \"AzureCognitiveSearch.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.224.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.AustraliaCentral2\",\r\n - \ \"id\": \"AzureCognitiveSearch.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.120.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.AustraliaEast\",\r\n - \ \"id\": \"AzureCognitiveSearch.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.193.192/26\",\r\n \"20.40.123.36/32\",\r\n - \ \"20.40.123.39/32\",\r\n \"20.40.123.46/32\",\r\n \"20.40.123.72/32\",\r\n - \ \"2603:1010:6:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureCognitiveSearch.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.225.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.BrazilSouth\",\r\n - \ \"id\": \"AzureCognitiveSearch.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.26.156/32\",\r\n \"191.235.225.64/26\",\r\n - \ \"2603:1050:6:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.CanadaCentral\",\r\n \"id\": - \"AzureCognitiveSearch.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"52.139.0.47/32\",\r\n \"52.139.0.49/32\",\r\n \"52.228.81.64/26\",\r\n - \ \"2603:1030:f05:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.CanadaEast\",\r\n \"id\": - \"AzureCognitiveSearch.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"40.89.17.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCognitiveSearch.CentralIndia\",\r\n \"id\": \"AzureCognitiveSearch.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \"40.81.253.154/32\",\r\n - \ \"52.140.105.64/26\",\r\n \"2603:1040:a06:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CentralUS\",\r\n - \ \"id\": \"AzureCognitiveSearch.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.5.51/32\",\r\n \"20.37.156.128/26\",\r\n - \ \"52.158.208.11/32\",\r\n \"52.242.214.45/32\",\r\n \"2603:1030:10:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CentralUSEUAP\",\r\n - \ \"id\": \"AzureCognitiveSearch.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.192.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.EastAsia\",\r\n - \ \"id\": \"AzureCognitiveSearch.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.106.128/26\",\r\n \"40.81.29.152/32\",\r\n - \ \"52.184.80.221/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCognitiveSearch.EastUS\",\r\n \"id\": \"AzureCognitiveSearch.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \"20.42.4.128/26\",\r\n - \ \"20.42.24.90/32\",\r\n \"20.42.29.212/32\",\r\n \"20.42.30.105/32\",\r\n - \ \"20.42.34.190/32\",\r\n \"20.42.35.204/32\",\r\n \"20.185.110.199/32\",\r\n - \ \"40.90.240.17/32\",\r\n \"52.151.235.150/32\",\r\n \"52.151.235.242/32\",\r\n - \ \"52.151.235.244/32\",\r\n \"52.188.217.235/32\",\r\n \"52.188.218.228/32\",\r\n - \ \"52.188.218.239/32\",\r\n \"2603:1030:210:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.EastUS2\",\r\n - \ \"id\": \"AzureCognitiveSearch.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"20.41.4.128/26\",\r\n \"20.44.74.182/32\",\r\n \"20.44.76.53/32\",\r\n - \ \"20.44.76.61/32\",\r\n \"20.44.76.86/32\",\r\n \"2603:1030:40c:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.EastUS2EUAP\",\r\n - \ \"id\": \"AzureCognitiveSearch.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.8.192/26\",\r\n \"52.253.229.120/32\",\r\n - \ \"2603:1030:40b:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.FranceCentral\",\r\n \"id\": - \"AzureCognitiveSearch.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"20.43.41.64/26\",\r\n \"40.66.56.233/32\",\r\n \"2603:1020:805:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.FranceSouth\",\r\n - \ \"id\": \"AzureCognitiveSearch.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.88.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.GermanyNorth\",\r\n - \ \"id\": \"AzureCognitiveSearch.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.48.96/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.GermanyWestCentral\",\r\n - \ \"id\": \"AzureCognitiveSearch.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.144.96/28\",\r\n \"2603:1020:c04:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.JapanEast\",\r\n - \ \"id\": \"AzureCognitiveSearch.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.65.64/26\",\r\n \"52.140.233.105/32\",\r\n - \ \"2603:1040:407:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.JapanWest\",\r\n \"id\": - \"AzureCognitiveSearch.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"40.80.57.64/26\",\r\n \"40.81.188.130/32\",\r\n - \ \"40.81.191.58/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCognitiveSearch.KoreaCentral\",\r\n \"id\": \"AzureCognitiveSearch.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \"20.41.65.64/26\",\r\n - \ \"40.82.155.65/32\",\r\n \"2603:1040:f05:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.KoreaSouth\",\r\n - \ \"id\": \"AzureCognitiveSearch.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.169.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorthCentralUS\",\r\n - \ \"id\": \"AzureCognitiveSearch.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"23.100.238.27/32\",\r\n \"23.100.238.34/31\",\r\n - \ \"23.100.238.37/32\",\r\n \"40.80.186.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorthEurope\",\r\n - \ \"id\": \"AzureCognitiveSearch.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.84.0/26\",\r\n \"52.155.216.245/32\",\r\n - \ \"52.155.217.84/32\",\r\n \"52.155.221.242/32\",\r\n \"52.155.221.250/32\",\r\n - \ \"52.155.222.35/32\",\r\n \"52.155.222.56/32\",\r\n \"52.158.28.181/32\",\r\n - \ \"52.158.30.241/32\",\r\n \"2603:1020:5:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorwayEast\",\r\n - \ \"id\": \"AzureCognitiveSearch.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.40.128/26\",\r\n \"2603:1020:e04:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorwayWest\",\r\n - \ \"id\": \"AzureCognitiveSearch.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.224.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureCognitiveSearch.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.128.33/32\",\r\n \"102.133.217.128/26\",\r\n - \ \"2603:1000:104:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.SouthCentralUS\",\r\n \"id\": - \"AzureCognitiveSearch.SouthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"20.45.0.49/32\",\r\n \"20.45.2.122/32\",\r\n \"40.80.216.231/32\",\r\n - \ \"40.80.217.38/32\",\r\n \"40.80.219.46/32\",\r\n \"40.119.11.0/26\",\r\n - \ \"52.185.224.13/32\",\r\n \"52.185.224.38/32\",\r\n \"2603:1030:807:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.SoutheastAsia\",\r\n - \ \"id\": \"AzureCognitiveSearch.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.130.128/26\",\r\n \"40.65.173.157/32\",\r\n - \ \"40.65.175.212/32\",\r\n \"40.65.175.228/32\",\r\n \"40.90.190.180/32\",\r\n - \ \"2603:1040:5:1::180/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.SouthIndia\",\r\n \"id\": - \"AzureCognitiveSearch.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"20.41.193.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCognitiveSearch.SwitzerlandNorth\",\r\n \"id\": - \"AzureCognitiveSearch.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.128/26\",\r\n \"2603:1020:a04:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.SwitzerlandWest\",\r\n - \ \"id\": \"AzureCognitiveSearch.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.144.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UAECentral\",\r\n - \ \"id\": \"AzureCognitiveSearch.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UAENorth\",\r\n - \ \"id\": \"AzureCognitiveSearch.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.128/26\",\r\n \"2603:1040:904:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UKNorth\",\r\n - \ \"id\": \"AzureCognitiveSearch.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"51.105.80.128/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.UKSouth\",\r\n \"id\": - \"AzureCognitiveSearch.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"51.104.25.64/26\",\r\n \"51.132.43.66/32\",\r\n - \ \"51.145.124.157/32\",\r\n \"51.145.124.158/32\",\r\n \"2603:1020:705:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UKSouth2\",\r\n - \ \"id\": \"AzureCognitiveSearch.UKSouth2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"51.143.192.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UKWest\",\r\n - \ \"id\": \"AzureCognitiveSearch.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"51.137.161.64/26\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureCognitiveSearch.WestCentralUS\",\r\n \"id\": - \"AzureCognitiveSearch.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"52.150.139.0/26\",\r\n \"52.253.133.74/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestEurope\",\r\n - \ \"id\": \"AzureCognitiveSearch.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.18.154/32\",\r\n \"40.74.30.0/26\",\r\n - \ \"51.145.176.249/32\",\r\n \"51.145.177.212/32\",\r\n \"51.145.178.138/32\",\r\n - \ \"51.145.178.140/32\",\r\n \"52.137.24.236/32\",\r\n \"52.137.26.114/32\",\r\n - \ \"52.137.26.155/32\",\r\n \"52.137.26.198/32\",\r\n \"52.137.27.49/32\",\r\n - \ \"52.137.56.115/32\",\r\n \"52.137.60.208/32\",\r\n \"52.157.231.64/32\",\r\n - \ \"104.45.64.0/32\",\r\n \"104.45.64.147/32\",\r\n \"104.45.64.224/32\",\r\n - \ \"104.45.65.30/32\",\r\n \"104.45.65.89/32\",\r\n \"2603:1020:206:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestIndia\",\r\n - \ \"id\": \"AzureCognitiveSearch.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n - \ \"addressPrefixes\": [\r\n \"52.136.48.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestUS\",\r\n - \ \"id\": \"AzureCognitiveSearch.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"13.64.32.141/32\",\r\n \"13.83.22.45/32\",\r\n \"13.83.22.74/32\",\r\n - \ \"13.83.22.119/32\",\r\n \"20.189.129.94/32\",\r\n \"40.81.9.100/32\",\r\n - \ \"40.81.9.131/32\",\r\n \"40.81.9.203/32\",\r\n \"40.81.9.209/32\",\r\n - \ \"40.81.9.213/32\",\r\n \"40.81.9.221/32\",\r\n \"40.81.10.36/32\",\r\n - \ \"40.81.12.133/32\",\r\n \"40.81.15.8/32\",\r\n \"40.81.15.39/32\",\r\n - \ \"40.82.253.0/26\",\r\n \"52.157.22.233/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestUS2\",\r\n - \ \"id\": \"AzureCognitiveSearch.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": - [\r\n \"20.42.129.192/26\",\r\n \"40.91.93.84/32\",\r\n - \ \"40.91.127.116/32\",\r\n \"40.91.127.241/32\",\r\n \"51.143.104.54/32\",\r\n - \ \"51.143.104.90/32\",\r\n \"2603:1030:c06:1::180/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors\",\r\n - \ \"id\": \"AzureConnectors\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"13.65.86.57/32\",\r\n \"13.66.140.128/28\",\r\n - \ \"13.66.145.96/27\",\r\n \"13.66.210.166/32\",\r\n \"13.66.213.29/32\",\r\n - \ \"13.66.213.240/32\",\r\n \"13.66.214.51/32\",\r\n \"13.67.8.240/28\",\r\n - \ \"13.67.15.32/27\",\r\n \"13.69.64.208/28\",\r\n \"13.69.71.192/27\",\r\n - \ \"13.69.227.208/28\",\r\n \"13.69.231.192/27\",\r\n \"13.70.72.192/28\",\r\n - \ \"13.70.78.224/27\",\r\n \"13.70.82.210/32\",\r\n \"13.70.136.174/32\",\r\n - \ \"13.70.187.251/32\",\r\n \"13.70.189.7/32\",\r\n \"13.70.191.49/32\",\r\n - \ \"13.71.125.22/32\",\r\n \"13.71.127.26/32\",\r\n \"13.71.153.19/32\",\r\n - \ \"13.71.170.208/28\",\r\n \"13.71.175.160/27\",\r\n \"13.71.195.32/28\",\r\n - \ \"13.71.199.192/27\",\r\n \"13.72.243.10/32\",\r\n \"13.73.21.230/32\",\r\n - \ \"13.73.203.158/32\",\r\n \"13.73.205.35/32\",\r\n \"13.73.207.42/32\",\r\n - \ \"13.73.244.224/27\",\r\n \"13.75.36.64/28\",\r\n \"13.75.89.9/32\",\r\n - \ \"13.75.91.198/32\",\r\n \"13.75.92.124/32\",\r\n \"13.75.92.202/32\",\r\n - \ \"13.75.110.131/32\",\r\n \"13.76.231.68/32\",\r\n \"13.77.7.172/32\",\r\n - \ \"13.77.50.240/28\",\r\n \"13.77.55.160/27\",\r\n \"13.78.84.73/32\",\r\n - \ \"13.78.85.193/32\",\r\n \"13.78.85.200/32\",\r\n \"13.78.86.229/32\",\r\n - \ \"13.78.108.0/28\",\r\n \"13.78.132.82/32\",\r\n \"13.86.223.32/27\",\r\n - \ \"13.87.56.224/28\",\r\n \"13.87.122.224/28\",\r\n \"13.89.171.80/28\",\r\n - \ \"13.89.178.64/27\",\r\n \"13.93.148.62/32\",\r\n \"20.36.107.0/28\",\r\n - \ \"20.36.114.176/28\",\r\n \"20.36.117.160/27\",\r\n \"20.37.74.192/28\",\r\n - \ \"20.38.128.224/27\",\r\n \"20.43.123.0/27\",\r\n \"20.44.3.0/28\",\r\n - \ \"20.44.29.64/27\",\r\n \"20.53.0.0/27\",\r\n \"20.150.170.240/28\",\r\n - \ \"20.150.173.64/26\",\r\n \"20.192.32.64/26\",\r\n \"20.192.184.32/27\",\r\n - \ \"20.193.206.192/26\",\r\n \"23.99.116.181/32\",\r\n \"23.100.208.0/27\",\r\n - \ \"40.67.58.240/28\",\r\n \"40.67.60.224/27\",\r\n \"40.69.42.254/32\",\r\n - \ \"40.69.45.11/32\",\r\n \"40.69.45.93/32\",\r\n \"40.69.45.126/32\",\r\n - \ \"40.69.106.240/28\",\r\n \"40.69.111.0/27\",\r\n \"40.70.146.208/28\",\r\n - \ \"40.70.151.96/27\",\r\n \"40.71.11.80/28\",\r\n \"40.71.15.160/27\",\r\n - \ \"40.71.249.139/32\",\r\n \"40.71.249.205/32\",\r\n \"40.74.100.224/28\",\r\n - \ \"40.74.130.77/32\",\r\n \"40.74.146.64/28\",\r\n \"40.78.194.240/28\",\r\n - \ \"40.78.202.96/28\",\r\n \"40.79.130.208/28\",\r\n \"40.79.148.96/27\",\r\n - \ \"40.79.178.240/28\",\r\n \"40.79.180.224/27\",\r\n \"40.79.189.64/27\",\r\n - \ \"40.80.180.64/27\",\r\n \"40.89.135.2/32\",\r\n \"40.89.186.239/32\",\r\n - \ \"40.91.208.65/32\",\r\n \"40.112.195.87/32\",\r\n \"40.112.243.160/28\",\r\n - \ \"40.114.40.132/32\",\r\n \"40.115.50.13/32\",\r\n \"40.115.186.96/32\",\r\n - \ \"40.117.98.246/32\",\r\n \"40.117.100.191/32\",\r\n \"40.117.101.91/32\",\r\n - \ \"40.117.101.120/32\",\r\n \"40.120.8.0/27\",\r\n \"40.120.64.64/27\",\r\n - \ \"40.122.49.51/32\",\r\n \"40.126.251.213/32\",\r\n \"40.127.80.34/32\",\r\n - \ \"51.12.98.240/28\",\r\n \"51.12.202.240/28\",\r\n \"51.105.77.96/27\",\r\n - \ \"51.107.59.16/28\",\r\n \"51.107.60.224/27\",\r\n \"51.107.155.16/28\",\r\n - \ \"51.107.156.224/27\",\r\n \"51.116.59.16/28\",\r\n \"51.116.60.192/27\",\r\n - \ \"51.116.155.80/28\",\r\n \"51.116.158.96/27\",\r\n \"51.120.98.224/28\",\r\n - \ \"51.120.100.192/27\",\r\n \"51.120.218.240/28\",\r\n \"51.120.220.192/27\",\r\n - \ \"51.140.61.124/32\",\r\n \"51.140.74.150/32\",\r\n \"51.140.80.51/32\",\r\n - \ \"51.140.148.0/28\",\r\n \"51.140.211.0/28\",\r\n \"51.140.212.224/27\",\r\n - \ \"51.141.47.105/32\",\r\n \"51.141.52.185/32\",\r\n \"51.141.124.13/32\",\r\n - \ \"52.136.133.184/32\",\r\n \"52.136.142.154/32\",\r\n \"52.138.92.192/27\",\r\n - \ \"52.141.1.104/32\",\r\n \"52.141.36.214/32\",\r\n \"52.160.91.66/32\",\r\n - \ \"52.160.92.131/32\",\r\n \"52.160.93.247/32\",\r\n \"52.160.95.100/32\",\r\n - \ \"52.161.26.33/32\",\r\n \"52.161.26.191/32\",\r\n \"52.161.27.42/32\",\r\n - \ \"52.161.29.40/32\",\r\n \"52.161.101.204/32\",\r\n \"52.161.102.22/32\",\r\n - \ \"52.162.107.160/28\",\r\n \"52.162.111.192/27\",\r\n \"52.162.126.4/32\",\r\n - \ \"52.162.242.161/32\",\r\n \"52.163.89.40/32\",\r\n \"52.163.89.65/32\",\r\n - \ \"52.163.91.227/32\",\r\n \"52.163.95.29/32\",\r\n \"52.166.78.89/32\",\r\n - \ \"52.166.241.149/32\",\r\n \"52.166.243.169/32\",\r\n \"52.166.244.232/32\",\r\n - \ \"52.166.245.173/32\",\r\n \"52.169.28.181/32\",\r\n \"52.171.130.92/32\",\r\n - \ \"52.172.51.70/32\",\r\n \"52.172.54.172/32\",\r\n \"52.172.55.84/32\",\r\n - \ \"52.172.55.107/32\",\r\n \"52.172.155.245/32\",\r\n \"52.172.158.2/32\",\r\n - \ \"52.172.158.185/32\",\r\n \"52.172.159.100/32\",\r\n \"52.172.211.12/32\",\r\n - \ \"52.172.212.129/32\",\r\n \"52.173.241.27/32\",\r\n \"52.173.245.164/32\",\r\n - \ \"52.174.88.118/32\",\r\n \"52.175.23.169/32\",\r\n \"52.178.150.68/32\",\r\n - \ \"52.183.78.157/32\",\r\n \"52.187.68.19/32\",\r\n \"52.187.115.69/32\",\r\n - \ \"52.191.164.250/32\",\r\n \"52.225.129.144/32\",\r\n \"52.228.33.76/32\",\r\n - \ \"52.228.34.13/32\",\r\n \"52.228.42.205/32\",\r\n \"52.229.120.52/32\",\r\n - \ \"52.229.120.178/32\",\r\n \"52.229.123.56/32\",\r\n \"52.229.123.98/32\",\r\n - \ \"52.229.126.28/32\",\r\n \"52.229.126.118/32\",\r\n \"52.229.126.202/32\",\r\n - \ \"52.231.18.208/28\",\r\n \"52.231.147.0/28\",\r\n \"52.231.148.224/27\",\r\n - \ \"52.231.163.10/32\",\r\n \"52.231.201.173/32\",\r\n \"52.232.130.205/32\",\r\n - \ \"52.232.188.154/32\",\r\n \"52.233.29.254/32\",\r\n \"52.233.30.148/32\",\r\n - \ \"52.233.30.199/32\",\r\n \"52.233.30.222/32\",\r\n \"52.233.31.197/32\",\r\n - \ \"52.237.24.126/32\",\r\n \"52.237.32.212/32\",\r\n \"52.237.214.72/32\",\r\n - \ \"52.242.30.112/32\",\r\n \"52.242.35.152/32\",\r\n \"52.255.48.202/32\",\r\n - \ \"65.52.218.230/32\",\r\n \"65.52.250.208/28\",\r\n \"94.245.91.93/32\",\r\n - \ \"102.37.64.0/27\",\r\n \"102.133.27.0/28\",\r\n \"102.133.72.85/32\",\r\n - \ \"102.133.155.0/28\",\r\n \"102.133.168.167/32\",\r\n \"102.133.253.0/27\",\r\n - \ \"104.40.51.248/32\",\r\n \"104.41.59.51/32\",\r\n \"104.42.122.49/32\",\r\n - \ \"104.43.232.28/32\",\r\n \"104.43.232.242/32\",\r\n \"104.43.234.211/32\",\r\n - \ \"104.43.235.249/32\",\r\n \"104.45.93.9/32\",\r\n \"104.208.233.100/32\",\r\n - \ \"104.209.247.23/32\",\r\n \"104.211.81.192/28\",\r\n \"104.211.98.164/32\",\r\n - \ \"104.211.146.224/28\",\r\n \"104.211.161.203/32\",\r\n - \ \"104.211.189.124/32\",\r\n \"104.211.189.218/32\",\r\n - \ \"104.211.227.225/32\",\r\n \"104.214.19.48/28\",\r\n \"104.214.70.191/32\",\r\n - \ \"104.214.137.186/32\",\r\n \"104.214.138.174/32\",\r\n - \ \"104.214.139.29/32\",\r\n \"104.214.140.23/32\",\r\n \"104.214.164.0/27\",\r\n - \ \"104.215.27.24/32\",\r\n \"104.215.61.248/32\",\r\n \"168.61.140.0/27\",\r\n - \ \"191.232.38.129/32\",\r\n \"191.232.191.157/32\",\r\n - \ \"191.233.51.0/26\",\r\n \"191.233.203.192/28\",\r\n \"191.233.207.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.AustraliaCentral\",\r\n - \ \"id\": \"AzureConnectors.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.107.0/28\",\r\n \"20.53.0.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.AustraliaCentral2\",\r\n - \ \"id\": \"AzureConnectors.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.114.176/28\",\r\n \"20.36.117.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.AustraliaEast\",\r\n - \ \"id\": \"AzureConnectors.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.72.192/28\",\r\n \"13.70.78.224/27\",\r\n - \ \"13.70.82.210/32\",\r\n \"13.72.243.10/32\",\r\n \"13.73.203.158/32\",\r\n - \ \"13.73.205.35/32\",\r\n \"13.73.207.42/32\",\r\n \"40.126.251.213/32\",\r\n - \ \"52.237.214.72/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.AustraliaSoutheast\",\r\n \"id\": \"AzureConnectors.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.70.136.174/32\",\r\n - \ \"13.70.187.251/32\",\r\n \"13.70.189.7/32\",\r\n \"13.70.191.49/32\",\r\n - \ \"13.77.7.172/32\",\r\n \"13.77.50.240/28\",\r\n \"13.77.55.160/27\",\r\n - \ \"40.127.80.34/32\",\r\n \"52.255.48.202/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.BrazilSouth\",\r\n - \ \"id\": \"AzureConnectors.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"104.41.59.51/32\",\r\n \"191.232.38.129/32\",\r\n - \ \"191.232.191.157/32\",\r\n \"191.233.203.192/28\",\r\n - \ \"191.233.207.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.CanadaCentral\",\r\n \"id\": \"AzureConnectors.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.208/28\",\r\n - \ \"13.71.175.160/27\",\r\n \"52.228.33.76/32\",\r\n \"52.228.34.13/32\",\r\n - \ \"52.228.42.205/32\",\r\n \"52.233.29.254/32\",\r\n \"52.233.30.148/32\",\r\n - \ \"52.233.30.199/32\",\r\n \"52.233.30.222/32\",\r\n \"52.233.31.197/32\",\r\n - \ \"52.237.24.126/32\",\r\n \"52.237.32.212/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CanadaEast\",\r\n - \ \"id\": \"AzureConnectors.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.106.240/28\",\r\n \"40.69.111.0/27\",\r\n - \ \"52.229.120.52/32\",\r\n \"52.229.120.178/32\",\r\n \"52.229.123.56/32\",\r\n - \ \"52.229.123.98/32\",\r\n \"52.229.126.28/32\",\r\n \"52.229.126.118/32\",\r\n - \ \"52.229.126.202/32\",\r\n \"52.232.130.205/32\",\r\n \"52.242.30.112/32\",\r\n - \ \"52.242.35.152/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.CentralIndia\",\r\n \"id\": \"AzureConnectors.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"20.43.123.0/27\",\r\n - \ \"52.172.155.245/32\",\r\n \"52.172.158.2/32\",\r\n \"52.172.158.185/32\",\r\n - \ \"52.172.159.100/32\",\r\n \"52.172.211.12/32\",\r\n \"52.172.212.129/32\",\r\n - \ \"104.211.81.192/28\",\r\n \"104.211.98.164/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CentralUS\",\r\n - \ \"id\": \"AzureConnectors.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.171.80/28\",\r\n \"13.89.178.64/27\",\r\n - \ \"40.122.49.51/32\",\r\n \"52.173.241.27/32\",\r\n \"52.173.245.164/32\",\r\n - \ \"104.43.232.28/32\",\r\n \"104.43.232.242/32\",\r\n \"104.43.234.211/32\",\r\n - \ \"104.43.235.249/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.CentralUSEUAP\",\r\n \"id\": \"AzureConnectors.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.96/28\",\r\n - \ \"168.61.140.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.EastAsia\",\r\n \"id\": \"AzureConnectors.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.75.36.64/28\",\r\n - \ \"13.75.89.9/32\",\r\n \"13.75.91.198/32\",\r\n \"13.75.92.124/32\",\r\n - \ \"13.75.92.202/32\",\r\n \"13.75.110.131/32\",\r\n \"23.99.116.181/32\",\r\n - \ \"52.175.23.169/32\",\r\n \"104.214.164.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.EastUS\",\r\n - \ \"id\": \"AzureConnectors.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"40.71.11.80/28\",\r\n \"40.71.15.160/27\",\r\n \"40.71.249.139/32\",\r\n - \ \"40.71.249.205/32\",\r\n \"40.114.40.132/32\",\r\n \"40.117.98.246/32\",\r\n - \ \"40.117.100.191/32\",\r\n \"40.117.101.91/32\",\r\n \"40.117.101.120/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.EastUS2\",\r\n - \ \"id\": \"AzureConnectors.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"40.70.146.208/28\",\r\n \"40.70.151.96/27\",\r\n - \ \"52.225.129.144/32\",\r\n \"52.232.188.154/32\",\r\n \"104.208.233.100/32\",\r\n - \ \"104.209.247.23/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.EastUS2EUAP\",\r\n \"id\": \"AzureConnectors.EastUS2EUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.64/28\",\r\n - \ \"52.138.92.192/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.FranceCentral\",\r\n \"id\": \"AzureConnectors.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.79.130.208/28\",\r\n - \ \"40.79.148.96/27\",\r\n \"40.89.135.2/32\",\r\n \"40.89.186.239/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.FranceSouth\",\r\n - \ \"id\": \"AzureConnectors.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.178.240/28\",\r\n \"40.79.180.224/27\",\r\n - \ \"52.136.133.184/32\",\r\n \"52.136.142.154/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.GermanyNorth\",\r\n - \ \"id\": \"AzureConnectors.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.59.16/28\",\r\n \"51.116.60.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.GermanyWestCentral\",\r\n - \ \"id\": \"AzureConnectors.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.155.80/28\",\r\n \"51.116.158.96/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.JapanEast\",\r\n - \ \"id\": \"AzureConnectors.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.153.19/32\",\r\n \"13.73.21.230/32\",\r\n - \ \"13.78.84.73/32\",\r\n \"13.78.85.193/32\",\r\n \"13.78.85.200/32\",\r\n - \ \"13.78.86.229/32\",\r\n \"13.78.108.0/28\",\r\n \"40.79.189.64/27\",\r\n - \ \"40.115.186.96/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.JapanWest\",\r\n \"id\": \"AzureConnectors.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.74.100.224/28\",\r\n - \ \"40.74.130.77/32\",\r\n \"40.80.180.64/27\",\r\n \"104.214.137.186/32\",\r\n - \ \"104.214.138.174/32\",\r\n \"104.214.139.29/32\",\r\n - \ \"104.214.140.23/32\",\r\n \"104.215.27.24/32\",\r\n \"104.215.61.248/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.KoreaCentral\",\r\n - \ \"id\": \"AzureConnectors.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.29.64/27\",\r\n \"52.141.1.104/32\",\r\n - \ \"52.141.36.214/32\",\r\n \"52.231.18.208/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.KoreaSouth\",\r\n - \ \"id\": \"AzureConnectors.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.147.0/28\",\r\n \"52.231.148.224/27\",\r\n - \ \"52.231.163.10/32\",\r\n \"52.231.201.173/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorthCentralUS\",\r\n - \ \"id\": \"AzureConnectors.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"52.162.107.160/28\",\r\n \"52.162.111.192/27\",\r\n - \ \"52.162.126.4/32\",\r\n \"52.162.242.161/32\",\r\n \"65.52.218.230/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorthEurope\",\r\n - \ \"id\": \"AzureConnectors.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.227.208/28\",\r\n \"13.69.231.192/27\",\r\n - \ \"40.69.42.254/32\",\r\n \"40.69.45.11/32\",\r\n \"40.69.45.93/32\",\r\n - \ \"40.69.45.126/32\",\r\n \"52.169.28.181/32\",\r\n \"52.178.150.68/32\",\r\n - \ \"94.245.91.93/32\",\r\n \"104.45.93.9/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorwayEast\",\r\n - \ \"id\": \"AzureConnectors.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"51.120.98.224/28\",\r\n \"51.120.100.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorwayWest\",\r\n - \ \"id\": \"AzureConnectors.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"51.120.218.240/28\",\r\n \"51.120.220.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureConnectors.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.155.0/28\",\r\n \"102.133.168.167/32\",\r\n - \ \"102.133.253.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.SouthAfricaWest\",\r\n \"id\": \"AzureConnectors.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"102.37.64.0/27\",\r\n - \ \"102.133.27.0/28\",\r\n \"102.133.72.85/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SouthCentralUS\",\r\n - \ \"id\": \"AzureConnectors.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.86.57/32\",\r\n \"13.73.244.224/27\",\r\n - \ \"52.171.130.92/32\",\r\n \"104.214.19.48/28\",\r\n \"104.214.70.191/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SoutheastAsia\",\r\n - \ \"id\": \"AzureConnectors.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.8.240/28\",\r\n \"13.67.15.32/27\",\r\n - \ \"13.76.231.68/32\",\r\n \"52.163.89.40/32\",\r\n \"52.163.89.65/32\",\r\n - \ \"52.163.91.227/32\",\r\n \"52.163.95.29/32\",\r\n \"52.187.68.19/32\",\r\n - \ \"52.187.115.69/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.SouthIndia\",\r\n \"id\": \"AzureConnectors.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.71.125.22/32\",\r\n - \ \"13.71.127.26/32\",\r\n \"20.192.184.32/27\",\r\n \"40.78.194.240/28\",\r\n - \ \"52.172.51.70/32\",\r\n \"52.172.54.172/32\",\r\n \"52.172.55.84/32\",\r\n - \ \"52.172.55.107/32\",\r\n \"104.211.227.225/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureConnectors.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.59.16/28\",\r\n \"51.107.60.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SwitzerlandWest\",\r\n - \ \"id\": \"AzureConnectors.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.155.16/28\",\r\n \"51.107.156.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UAECentral\",\r\n - \ \"id\": \"AzureConnectors.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.74.192/28\",\r\n \"40.120.8.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UAENorth\",\r\n - \ \"id\": \"AzureConnectors.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"40.120.64.64/27\",\r\n \"65.52.250.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKNorth\",\r\n - \ \"id\": \"AzureConnectors.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"13.87.122.224/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureConnectors.UKSouth\",\r\n \"id\": \"AzureConnectors.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.105.77.96/27\",\r\n - \ \"51.140.61.124/32\",\r\n \"51.140.74.150/32\",\r\n \"51.140.80.51/32\",\r\n - \ \"51.140.148.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.UKSouth2\",\r\n \"id\": \"AzureConnectors.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.56.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKWest\",\r\n - \ \"id\": \"AzureConnectors.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"51.140.211.0/28\",\r\n \"51.140.212.224/27\",\r\n - \ \"51.141.47.105/32\",\r\n \"51.141.52.185/32\",\r\n \"51.141.124.13/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestCentralUS\",\r\n - \ \"id\": \"AzureConnectors.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.195.32/28\",\r\n \"13.71.199.192/27\",\r\n - \ \"13.78.132.82/32\",\r\n \"52.161.26.33/32\",\r\n \"52.161.26.191/32\",\r\n - \ \"52.161.27.42/32\",\r\n \"52.161.29.40/32\",\r\n \"52.161.101.204/32\",\r\n - \ \"52.161.102.22/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.WestEurope\",\r\n \"id\": \"AzureConnectors.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.208/28\",\r\n - \ \"13.69.71.192/27\",\r\n \"40.91.208.65/32\",\r\n \"40.115.50.13/32\",\r\n - \ \"52.166.78.89/32\",\r\n \"52.166.241.149/32\",\r\n \"52.166.243.169/32\",\r\n - \ \"52.166.244.232/32\",\r\n \"52.166.245.173/32\",\r\n \"52.174.88.118/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestIndia\",\r\n - \ \"id\": \"AzureConnectors.WestIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.128.224/27\",\r\n \"104.211.146.224/28\",\r\n - \ \"104.211.161.203/32\",\r\n \"104.211.189.124/32\",\r\n - \ \"104.211.189.218/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureConnectors.WestUS\",\r\n \"id\": \"AzureConnectors.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.86.223.32/27\",\r\n - \ \"13.93.148.62/32\",\r\n \"40.112.195.87/32\",\r\n \"40.112.243.160/28\",\r\n - \ \"52.160.91.66/32\",\r\n \"52.160.92.131/32\",\r\n \"52.160.93.247/32\",\r\n - \ \"52.160.95.100/32\",\r\n \"104.40.51.248/32\",\r\n \"104.42.122.49/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestUS2\",\r\n - \ \"id\": \"AzureConnectors.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.128/28\",\r\n \"13.66.145.96/27\",\r\n - \ \"13.66.210.166/32\",\r\n \"13.66.213.29/32\",\r\n \"13.66.213.240/32\",\r\n - \ \"13.66.214.51/32\",\r\n \"52.183.78.157/32\",\r\n \"52.191.164.250/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry\",\r\n - \ \"id\": \"AzureContainerRegistry\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.72/29\",\r\n \"13.67.8.120/29\",\r\n \"13.67.14.0/24\",\r\n - \ \"13.69.64.88/29\",\r\n \"13.69.106.80/29\",\r\n \"13.69.110.0/24\",\r\n - \ \"13.69.227.88/29\",\r\n \"13.70.72.136/29\",\r\n \"13.70.78.0/25\",\r\n - \ \"13.71.170.56/29\",\r\n \"13.71.194.224/29\",\r\n \"13.74.107.80/29\",\r\n - \ \"13.74.110.0/24\",\r\n \"13.75.36.0/29\",\r\n \"13.77.50.80/29\",\r\n - \ \"13.78.106.200/29\",\r\n \"13.78.111.0/25\",\r\n \"13.87.56.96/29\",\r\n - \ \"13.87.122.96/29\",\r\n \"13.89.170.216/29\",\r\n \"13.89.175.0/25\",\r\n - \ \"20.37.74.72/29\",\r\n \"20.38.146.144/29\",\r\n \"20.38.149.0/25\",\r\n - \ \"20.43.121.128/26\",\r\n \"20.44.2.24/29\",\r\n \"20.44.26.144/29\",\r\n - \ \"20.45.122.144/29\",\r\n \"20.45.125.0/25\",\r\n \"20.49.82.16/29\",\r\n - \ \"20.49.90.16/29\",\r\n \"20.150.170.24/29\",\r\n \"20.150.173.128/26\",\r\n - \ \"20.150.178.144/29\",\r\n \"20.150.186.144/29\",\r\n \"20.189.169.0/24\",\r\n - \ \"20.192.32.0/26\",\r\n \"20.192.98.144/29\",\r\n \"20.192.234.24/29\",\r\n - \ \"20.193.202.16/29\",\r\n \"20.193.206.64/26\",\r\n \"20.194.66.16/29\",\r\n - \ \"23.98.82.112/29\",\r\n \"40.67.58.24/29\",\r\n \"40.67.121.0/25\",\r\n - \ \"40.69.106.80/29\",\r\n \"40.69.110.0/25\",\r\n \"40.70.146.88/29\",\r\n - \ \"40.70.150.0/24\",\r\n \"40.71.10.216/29\",\r\n \"40.74.100.160/29\",\r\n - \ \"40.74.146.48/29\",\r\n \"40.74.149.128/25\",\r\n \"40.75.34.32/29\",\r\n - \ \"40.78.194.80/29\",\r\n \"40.78.196.192/26\",\r\n \"40.78.202.72/29\",\r\n - \ \"40.78.226.208/29\",\r\n \"40.78.231.0/24\",\r\n \"40.78.234.48/29\",\r\n - \ \"40.78.242.160/29\",\r\n \"40.78.246.0/24\",\r\n \"40.78.250.96/29\",\r\n - \ \"40.79.130.56/29\",\r\n \"40.79.132.192/26\",\r\n \"40.79.138.32/29\",\r\n - \ \"40.79.146.32/29\",\r\n \"40.79.154.104/29\",\r\n \"40.79.162.32/29\",\r\n - \ \"40.79.170.0/29\",\r\n \"40.79.178.80/29\",\r\n \"40.79.186.8/29\",\r\n - \ \"40.79.194.96/29\",\r\n \"40.80.50.144/29\",\r\n \"40.80.51.192/26\",\r\n - \ \"40.80.176.128/25\",\r\n \"40.112.242.160/29\",\r\n \"40.120.8.64/26\",\r\n - \ \"40.120.74.16/29\",\r\n \"51.12.98.24/29\",\r\n \"51.12.100.192/26\",\r\n - \ \"51.12.101.0/26\",\r\n \"51.12.202.24/29\",\r\n \"51.12.226.144/29\",\r\n - \ \"51.12.234.144/29\",\r\n \"51.104.9.128/25\",\r\n \"51.105.66.144/29\",\r\n - \ \"51.105.74.144/29\",\r\n \"51.107.56.192/26\",\r\n \"51.107.58.24/29\",\r\n - \ \"51.107.152.192/26\",\r\n \"51.107.154.24/29\",\r\n \"51.107.192.0/26\",\r\n - \ \"51.116.58.24/29\",\r\n \"51.116.154.88/29\",\r\n \"51.116.158.128/25\",\r\n - \ \"51.116.242.144/29\",\r\n \"51.116.250.144/29\",\r\n \"51.120.98.160/29\",\r\n - \ \"51.120.106.144/29\",\r\n \"51.120.210.144/29\",\r\n \"51.120.218.24/29\",\r\n - \ \"51.140.146.200/29\",\r\n \"51.140.210.192/29\",\r\n \"51.140.215.0/25\",\r\n - \ \"52.138.90.32/29\",\r\n \"52.138.226.80/29\",\r\n \"52.162.104.192/26\",\r\n - \ \"52.162.106.160/29\",\r\n \"52.167.106.80/29\",\r\n \"52.182.138.208/29\",\r\n - \ \"52.231.18.56/29\",\r\n \"52.231.20.128/26\",\r\n \"52.231.146.192/29\",\r\n - \ \"52.236.186.80/29\",\r\n \"52.246.154.144/29\",\r\n \"65.52.248.192/26\",\r\n - \ \"65.52.250.16/29\",\r\n \"102.133.26.24/29\",\r\n \"102.133.122.144/29\",\r\n - \ \"102.133.154.24/29\",\r\n \"102.133.156.192/26\",\r\n - \ \"102.133.250.144/29\",\r\n \"104.46.161.128/25\",\r\n - \ \"104.208.16.80/29\",\r\n \"104.208.144.80/29\",\r\n \"104.211.81.136/29\",\r\n - \ \"104.211.146.80/29\",\r\n \"104.214.18.184/29\",\r\n \"104.214.161.128/25\",\r\n - \ \"191.233.50.16/29\",\r\n \"191.233.54.64/26\",\r\n \"191.233.54.128/26\",\r\n - \ \"191.233.203.136/29\",\r\n \"191.233.205.192/26\",\r\n - \ \"191.234.146.144/29\",\r\n \"191.234.154.144/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.AustraliaEast\",\r\n - \ \"id\": \"AzureContainerRegistry.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.72.136/29\",\r\n \"13.70.78.0/25\",\r\n - \ \"40.79.162.32/29\",\r\n \"40.79.170.0/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureContainerRegistry.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.50.80/29\",\r\n \"104.46.161.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.BrazilSouth\",\r\n - \ \"id\": \"AzureContainerRegistry.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.203.136/29\",\r\n \"191.233.205.192/26\",\r\n - \ \"191.234.146.144/29\",\r\n \"191.234.154.144/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CanadaCentral\",\r\n - \ \"id\": \"AzureContainerRegistry.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.170.56/29\",\r\n \"20.38.146.144/29\",\r\n - \ \"20.38.149.0/25\",\r\n \"52.246.154.144/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CanadaEast\",\r\n - \ \"id\": \"AzureContainerRegistry.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.106.80/29\",\r\n \"40.69.110.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CentralIndia\",\r\n - \ \"id\": \"AzureContainerRegistry.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.121.128/26\",\r\n \"20.192.98.144/29\",\r\n - \ \"40.80.50.144/29\",\r\n \"40.80.51.192/26\",\r\n \"104.211.81.136/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CentralUS\",\r\n - \ \"id\": \"AzureContainerRegistry.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.170.216/29\",\r\n \"13.89.175.0/25\",\r\n - \ \"52.182.138.208/29\",\r\n \"104.208.16.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CentralUSEUAP\",\r\n - \ \"id\": \"AzureContainerRegistry.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.202.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastAsia\",\r\n - \ \"id\": \"AzureContainerRegistry.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.36.0/29\",\r\n \"104.214.161.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS\",\r\n - \ \"id\": \"AzureContainerRegistry.EastUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.71.10.216/29\",\r\n \"40.78.226.208/29\",\r\n - \ \"40.78.231.0/24\",\r\n \"40.79.154.104/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS2\",\r\n - \ \"id\": \"AzureContainerRegistry.EastUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.70.146.88/29\",\r\n \"40.70.150.0/24\",\r\n - \ \"52.167.106.80/29\",\r\n \"104.208.144.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS2EUAP\",\r\n - \ \"id\": \"AzureContainerRegistry.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.146.48/29\",\r\n \"40.74.149.128/25\",\r\n - \ \"40.75.34.32/29\",\r\n \"52.138.90.32/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.FranceCentral\",\r\n - \ \"id\": \"AzureContainerRegistry.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.130.56/29\",\r\n \"40.79.132.192/26\",\r\n - \ \"40.79.138.32/29\",\r\n \"40.79.146.32/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.FranceSouth\",\r\n - \ \"id\": \"AzureContainerRegistry.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.178.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.GermanyNorth\",\r\n - \ \"id\": \"AzureContainerRegistry.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.58.24/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.GermanyWestCentral\",\r\n - \ \"id\": \"AzureContainerRegistry.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.154.88/29\",\r\n \"51.116.158.128/26\",\r\n - \ \"51.116.158.192/26\",\r\n \"51.116.242.144/29\",\r\n \"51.116.250.144/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.JapanEast\",\r\n - \ \"id\": \"AzureContainerRegistry.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.106.200/29\",\r\n \"13.78.111.0/25\",\r\n - \ \"40.79.186.8/29\",\r\n \"40.79.194.96/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.JapanWest\",\r\n - \ \"id\": \"AzureContainerRegistry.JapanWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.100.160/29\",\r\n \"40.80.176.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.KoreaCentral\",\r\n - \ \"id\": \"AzureContainerRegistry.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.26.144/29\",\r\n \"20.194.66.16/29\",\r\n - \ \"52.231.18.56/29\",\r\n \"52.231.20.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.KoreaSouth\",\r\n - \ \"id\": \"AzureContainerRegistry.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.146.192/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.NorthCentralUS\",\r\n - \ \"id\": \"AzureContainerRegistry.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"52.162.104.192/26\",\r\n \"52.162.106.160/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.NorthEurope\",\r\n - \ \"id\": \"AzureContainerRegistry.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.227.88/29\",\r\n \"13.74.107.80/29\",\r\n - \ \"13.74.110.0/24\",\r\n \"52.138.226.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.NorwayEast\",\r\n - \ \"id\": \"AzureContainerRegistry.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.98.160/29\",\r\n \"51.120.106.144/29\",\r\n - \ \"51.120.210.144/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.NorwayWest\",\r\n \"id\": \"AzureContainerRegistry.NorwayWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.24/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureContainerRegistry.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.122.144/29\",\r\n \"102.133.154.24/29\",\r\n - \ \"102.133.156.192/26\",\r\n \"102.133.250.144/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthAfricaWest\",\r\n - \ \"id\": \"AzureContainerRegistry.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.26.24/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthCentralUS\",\r\n - \ \"id\": \"AzureContainerRegistry.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.122.144/29\",\r\n \"20.45.125.0/25\",\r\n - \ \"20.49.90.16/29\",\r\n \"104.214.18.184/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SoutheastAsia\",\r\n - \ \"id\": \"AzureContainerRegistry.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.8.120/29\",\r\n \"13.67.14.0/25\",\r\n - \ \"13.67.14.128/25\",\r\n \"23.98.82.112/29\",\r\n \"40.78.234.48/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthIndia\",\r\n - \ \"id\": \"AzureContainerRegistry.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.194.80/29\",\r\n \"40.78.196.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureContainerRegistry.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.56.192/26\",\r\n \"51.107.58.24/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SwitzerlandWest\",\r\n - \ \"id\": \"AzureContainerRegistry.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.152.192/26\",\r\n \"51.107.154.24/29\",\r\n - \ \"51.107.192.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.UAECentral\",\r\n \"id\": \"AzureContainerRegistry.UAECentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.72/29\",\r\n - \ \"40.120.8.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.UAENorth\",\r\n \"id\": \"AzureContainerRegistry.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.16/29\",\r\n - \ \"65.52.248.192/26\",\r\n \"65.52.250.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UKNorth\",\r\n - \ \"id\": \"AzureContainerRegistry.UKNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\": - [\r\n \"13.87.122.96/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.UKSouth\",\r\n \"id\": \"AzureContainerRegistry.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"51.104.9.128/25\",\r\n - \ \"51.105.66.144/29\",\r\n \"51.105.74.144/29\",\r\n \"51.140.146.200/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UKSouth2\",\r\n - \ \"id\": \"AzureContainerRegistry.UKSouth2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\": - [\r\n \"13.87.56.96/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.UKWest\",\r\n \"id\": \"AzureContainerRegistry.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"51.140.210.192/29\",\r\n - \ \"51.140.215.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureContainerRegistry.WestCentralUS\",\r\n \"id\": - \"AzureContainerRegistry.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\": - [\r\n \"13.71.194.224/29\",\r\n \"40.67.121.0/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestEurope\",\r\n - \ \"id\": \"AzureContainerRegistry.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.64.88/29\",\r\n \"13.69.106.80/29\",\r\n - \ \"13.69.110.0/24\",\r\n \"52.236.186.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestIndia\",\r\n - \ \"id\": \"AzureContainerRegistry.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"104.211.146.80/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestUS\",\r\n - \ \"id\": \"AzureContainerRegistry.WestUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.169.0/24\",\r\n \"40.112.242.160/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestUS2\",\r\n - \ \"id\": \"AzureContainerRegistry.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.140.72/29\",\r\n \"40.78.242.160/29\",\r\n - \ \"40.78.246.0/24\",\r\n \"40.78.250.96/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB\",\r\n \"id\": - \"AzureCosmosDB\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"13.64.69.151/32\",\r\n \"13.64.113.68/32\",\r\n - \ \"13.64.114.48/32\",\r\n \"13.64.194.140/32\",\r\n \"13.65.145.92/32\",\r\n - \ \"13.66.26.107/32\",\r\n \"13.66.138.0/26\",\r\n \"13.67.8.0/26\",\r\n - \ \"13.68.28.135/32\",\r\n \"13.69.66.0/25\",\r\n \"13.69.66.128/29\",\r\n - \ \"13.69.112.0/25\",\r\n \"13.69.226.0/25\",\r\n \"13.70.74.136/29\",\r\n - \ \"13.71.115.125/32\",\r\n \"13.71.124.81/32\",\r\n \"13.71.170.0/28\",\r\n - \ \"13.71.194.0/26\",\r\n \"13.72.255.150/32\",\r\n \"13.73.100.183/32\",\r\n - \ \"13.74.106.0/25\",\r\n \"13.75.34.0/26\",\r\n \"13.75.134.84/32\",\r\n - \ \"13.76.161.130/32\",\r\n \"13.77.50.0/28\",\r\n \"13.78.51.35/32\",\r\n - \ \"13.78.106.0/26\",\r\n \"13.78.188.25/32\",\r\n \"13.79.34.236/32\",\r\n - \ \"13.81.51.99/32\",\r\n \"13.82.53.191/32\",\r\n \"13.84.150.178/32\",\r\n - \ \"13.84.157.70/32\",\r\n \"13.85.16.188/32\",\r\n \"13.87.56.0/27\",\r\n - \ \"13.87.122.0/27\",\r\n \"13.88.30.39/32\",\r\n \"13.88.253.180/32\",\r\n - \ \"13.89.41.245/32\",\r\n \"13.89.170.0/25\",\r\n \"13.89.190.186/32\",\r\n - \ \"13.89.224.229/32\",\r\n \"13.90.199.155/32\",\r\n \"13.91.246.52/32\",\r\n - \ \"13.93.153.80/32\",\r\n \"13.93.156.125/32\",\r\n \"13.93.207.66/32\",\r\n - \ \"13.94.201.5/32\",\r\n \"13.95.234.68/32\",\r\n \"20.36.26.132/32\",\r\n - \ \"20.36.42.8/32\",\r\n \"20.36.75.163/32\",\r\n \"20.36.106.0/26\",\r\n - \ \"20.36.114.0/28\",\r\n \"20.37.75.128/26\",\r\n \"20.38.146.0/26\",\r\n - \ \"20.44.2.64/26\",\r\n \"20.44.10.0/26\",\r\n \"20.44.26.0/26\",\r\n - \ \"20.45.122.0/26\",\r\n \"20.49.82.64/26\",\r\n \"20.49.90.64/26\",\r\n - \ \"20.150.170.64/26\",\r\n \"20.150.178.0/26\",\r\n \"20.150.186.0/26\",\r\n - \ \"20.192.98.0/26\",\r\n \"20.192.234.64/26\",\r\n \"20.193.202.64/26\",\r\n - \ \"20.194.66.64/26\",\r\n \"23.96.180.213/32\",\r\n \"23.96.219.207/32\",\r\n - \ \"23.96.242.234/32\",\r\n \"23.98.82.0/26\",\r\n \"23.102.191.13/32\",\r\n - \ \"23.102.239.134/32\",\r\n \"40.65.106.154/32\",\r\n \"40.65.114.105/32\",\r\n - \ \"40.67.58.64/26\",\r\n \"40.68.44.85/32\",\r\n \"40.69.106.0/28\",\r\n - \ \"40.70.0.140/32\",\r\n \"40.70.220.202/32\",\r\n \"40.71.10.0/25\",\r\n - \ \"40.71.17.19/32\",\r\n \"40.71.203.37/32\",\r\n \"40.71.204.115/32\",\r\n - \ \"40.71.216.114/32\",\r\n \"40.74.98.0/26\",\r\n \"40.74.143.235/32\",\r\n - \ \"40.74.147.192/26\",\r\n \"40.75.32.32/29\",\r\n \"40.75.34.128/26\",\r\n - \ \"40.77.63.179/32\",\r\n \"40.78.194.0/28\",\r\n \"40.78.203.32/27\",\r\n - \ \"40.78.226.0/25\",\r\n \"40.78.236.192/26\",\r\n \"40.78.243.192/26\",\r\n - \ \"40.78.250.0/26\",\r\n \"40.79.39.162/32\",\r\n \"40.79.59.92/32\",\r\n - \ \"40.79.67.136/32\",\r\n \"40.79.130.0/28\",\r\n \"40.79.138.48/28\",\r\n - \ \"40.79.146.48/28\",\r\n \"40.79.154.128/26\",\r\n \"40.79.163.72/29\",\r\n - \ \"40.79.163.192/26\",\r\n \"40.79.170.48/28\",\r\n \"40.79.178.0/28\",\r\n - \ \"40.79.186.16/28\",\r\n \"40.79.194.128/26\",\r\n \"40.80.50.0/26\",\r\n - \ \"40.83.137.191/32\",\r\n \"40.85.178.211/32\",\r\n \"40.86.229.245/32\",\r\n - \ \"40.89.67.208/32\",\r\n \"40.89.132.238/32\",\r\n \"40.112.140.12/32\",\r\n - \ \"40.112.241.0/24\",\r\n \"40.112.249.60/32\",\r\n \"40.113.90.91/32\",\r\n - \ \"40.114.240.253/32\",\r\n \"40.115.241.37/32\",\r\n \"40.118.245.44/32\",\r\n - \ \"40.118.245.251/32\",\r\n \"40.120.74.64/26\",\r\n \"40.122.132.89/32\",\r\n - \ \"40.122.174.140/32\",\r\n \"40.126.244.209/32\",\r\n \"51.12.98.64/26\",\r\n - \ \"51.12.202.64/26\",\r\n \"51.12.226.0/26\",\r\n \"51.12.234.0/26\",\r\n - \ \"51.105.66.0/26\",\r\n \"51.105.74.0/26\",\r\n \"51.107.58.64/26\",\r\n - \ \"51.107.154.64/26\",\r\n \"51.116.58.64/26\",\r\n \"51.116.154.128/26\",\r\n - \ \"51.116.242.0/26\",\r\n \"51.116.250.0/26\",\r\n \"51.120.98.64/26\",\r\n - \ \"51.120.106.0/26\",\r\n \"51.120.210.0/26\",\r\n \"51.120.218.64/26\",\r\n - \ \"51.140.52.73/32\",\r\n \"51.140.70.75/32\",\r\n \"51.140.75.146/32\",\r\n - \ \"51.140.83.56/32\",\r\n \"51.140.99.233/32\",\r\n \"51.140.146.0/27\",\r\n - \ \"51.140.210.0/27\",\r\n \"51.141.11.34/32\",\r\n \"51.141.25.77/32\",\r\n - \ \"51.141.53.76/32\",\r\n \"51.141.55.229/32\",\r\n \"51.143.189.37/32\",\r\n - \ \"51.144.177.166/32\",\r\n \"51.144.182.233/32\",\r\n \"52.136.134.25/32\",\r\n - \ \"52.136.134.250/32\",\r\n \"52.136.136.70/32\",\r\n \"52.138.66.90/32\",\r\n - \ \"52.138.70.62/32\",\r\n \"52.138.92.0/26\",\r\n \"52.138.141.112/32\",\r\n - \ \"52.138.197.33/32\",\r\n \"52.138.201.47/32\",\r\n \"52.138.205.97/32\",\r\n - \ \"52.138.206.153/32\",\r\n \"52.138.227.192/26\",\r\n \"52.143.136.41/32\",\r\n - \ \"52.151.16.118/32\",\r\n \"52.156.170.104/32\",\r\n \"52.158.234.203/32\",\r\n - \ \"52.161.13.67/32\",\r\n \"52.161.15.197/32\",\r\n \"52.161.22.131/32\",\r\n - \ \"52.161.100.126/32\",\r\n \"52.162.106.0/26\",\r\n \"52.162.252.26/32\",\r\n - \ \"52.163.63.20/32\",\r\n \"52.163.249.82/32\",\r\n \"52.164.250.188/32\",\r\n - \ \"52.165.42.204/32\",\r\n \"52.165.46.249/32\",\r\n \"52.165.129.184/32\",\r\n - \ \"52.165.229.112/32\",\r\n \"52.165.229.184/32\",\r\n \"52.167.107.128/26\",\r\n - \ \"52.168.28.222/32\",\r\n \"52.169.122.37/32\",\r\n \"52.169.219.183/32\",\r\n - \ \"52.170.204.83/32\",\r\n \"52.172.55.127/32\",\r\n \"52.172.206.130/32\",\r\n - \ \"52.173.148.217/32\",\r\n \"52.173.196.170/32\",\r\n \"52.173.240.244/32\",\r\n - \ \"52.174.253.239/32\",\r\n \"52.175.25.211/32\",\r\n \"52.175.39.232/32\",\r\n - \ \"52.176.0.136/32\",\r\n \"52.176.7.71/32\",\r\n \"52.176.101.49/32\",\r\n - \ \"52.176.155.127/32\",\r\n \"52.177.172.74/32\",\r\n \"52.177.206.153/32\",\r\n - \ \"52.178.108.222/32\",\r\n \"52.179.141.33/32\",\r\n \"52.179.143.233/32\",\r\n - \ \"52.179.200.0/25\",\r\n \"52.180.160.251/32\",\r\n \"52.180.161.1/32\",\r\n - \ \"52.180.177.137/32\",\r\n \"52.182.138.0/25\",\r\n \"52.183.42.252/32\",\r\n - \ \"52.183.66.36/32\",\r\n \"52.183.92.223/32\",\r\n \"52.183.119.101/32\",\r\n - \ \"52.184.152.241/32\",\r\n \"52.186.69.224/32\",\r\n \"52.187.11.8/32\",\r\n - \ \"52.187.12.93/32\",\r\n \"52.191.197.220/32\",\r\n \"52.226.18.140/32\",\r\n - \ \"52.226.21.178/32\",\r\n \"52.230.15.63/32\",\r\n \"52.230.23.170/32\",\r\n - \ \"52.230.70.94/32\",\r\n \"52.230.87.21/32\",\r\n \"52.231.18.0/28\",\r\n - \ \"52.231.25.123/32\",\r\n \"52.231.39.143/32\",\r\n \"52.231.56.0/28\",\r\n - \ \"52.231.146.0/27\",\r\n \"52.231.206.234/32\",\r\n \"52.231.207.31/32\",\r\n - \ \"52.232.59.220/32\",\r\n \"52.233.41.60/32\",\r\n \"52.233.128.86/32\",\r\n - \ \"52.235.40.247/32\",\r\n \"52.235.46.28/32\",\r\n \"52.236.189.0/26\",\r\n - \ \"52.237.20.252/32\",\r\n \"52.246.154.0/26\",\r\n \"52.255.52.19/32\",\r\n - \ \"52.255.58.221/32\",\r\n \"65.52.210.9/32\",\r\n \"65.52.251.128/26\",\r\n - \ \"102.133.26.64/26\",\r\n \"102.133.122.0/26\",\r\n \"102.133.154.64/26\",\r\n - \ \"102.133.250.0/26\",\r\n \"104.41.52.61/32\",\r\n \"104.41.54.69/32\",\r\n - \ \"104.41.177.93/32\",\r\n \"104.45.16.183/32\",\r\n \"104.45.131.193/32\",\r\n - \ \"104.45.144.73/32\",\r\n \"104.208.231.0/25\",\r\n \"104.210.89.99/32\",\r\n - \ \"104.210.217.251/32\",\r\n \"104.211.84.0/28\",\r\n \"104.211.102.50/32\",\r\n - \ \"104.211.146.0/28\",\r\n \"104.211.162.94/32\",\r\n \"104.211.184.117/32\",\r\n - \ \"104.211.188.174/32\",\r\n \"104.211.227.84/32\",\r\n - \ \"104.214.18.0/25\",\r\n \"104.214.23.192/27\",\r\n \"104.214.26.177/32\",\r\n - \ \"104.215.1.53/32\",\r\n \"104.215.21.39/32\",\r\n \"104.215.55.227/32\",\r\n - \ \"137.117.9.157/32\",\r\n \"157.55.170.133/32\",\r\n \"191.232.51.175/32\",\r\n - \ \"191.232.53.203/32\",\r\n \"191.233.50.64/26\",\r\n \"191.233.204.128/27\",\r\n - \ \"191.234.146.0/26\",\r\n \"191.234.154.0/26\",\r\n \"191.234.179.157/32\",\r\n - \ \"191.239.179.124/32\",\r\n \"207.46.150.252/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.AustraliaCentral\",\r\n - \ \"id\": \"AzureCosmosDB.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.42.8/32\",\r\n \"20.36.106.0/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.AustraliaCentral2\",\r\n - \ \"id\": \"AzureCosmosDB.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.75.163/32\",\r\n \"20.36.114.0/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.AustraliaEast\",\r\n - \ \"id\": \"AzureCosmosDB.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.74.136/29\",\r\n \"13.72.255.150/32\",\r\n - \ \"13.75.134.84/32\",\r\n \"40.79.163.72/29\",\r\n \"40.79.163.192/26\",\r\n - \ \"40.79.170.48/28\",\r\n \"40.126.244.209/32\",\r\n \"52.156.170.104/32\",\r\n - \ \"104.210.89.99/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.AustraliaSoutheast\",\r\n \"id\": \"AzureCosmosDB.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.73.100.183/32\",\r\n - \ \"13.77.50.0/28\",\r\n \"52.255.52.19/32\",\r\n \"52.255.58.221/32\",\r\n - \ \"191.239.179.124/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.BrazilSouth\",\r\n \"id\": \"AzureCosmosDB.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"104.41.52.61/32\",\r\n - \ \"104.41.54.69/32\",\r\n \"191.232.51.175/32\",\r\n \"191.232.53.203/32\",\r\n - \ \"191.233.204.128/27\",\r\n \"191.234.146.0/26\",\r\n \"191.234.154.0/26\",\r\n - \ \"191.234.179.157/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.CanadaCentral\",\r\n \"id\": \"AzureCosmosDB.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.0/28\",\r\n - \ \"13.88.253.180/32\",\r\n \"20.38.146.0/26\",\r\n \"52.233.41.60/32\",\r\n - \ \"52.237.20.252/32\",\r\n \"52.246.154.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.CanadaEast\",\r\n - \ \"id\": \"AzureCosmosDB.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.106.0/28\",\r\n \"40.86.229.245/32\",\r\n - \ \"52.235.40.247/32\",\r\n \"52.235.46.28/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.CentralIndia\",\r\n - \ \"id\": \"AzureCosmosDB.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"20.192.98.0/26\",\r\n \"40.80.50.0/26\",\r\n - \ \"52.172.206.130/32\",\r\n \"104.211.84.0/28\",\r\n \"104.211.102.50/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.CentralUS\",\r\n - \ \"id\": \"AzureCosmosDB.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.41.245/32\",\r\n \"13.89.170.0/25\",\r\n - \ \"13.89.190.186/32\",\r\n \"13.89.224.229/32\",\r\n \"20.44.10.0/26\",\r\n - \ \"40.77.63.179/32\",\r\n \"40.122.132.89/32\",\r\n \"40.122.174.140/32\",\r\n - \ \"52.165.42.204/32\",\r\n \"52.165.46.249/32\",\r\n \"52.165.129.184/32\",\r\n - \ \"52.165.229.112/32\",\r\n \"52.165.229.184/32\",\r\n \"52.173.148.217/32\",\r\n - \ \"52.173.196.170/32\",\r\n \"52.173.240.244/32\",\r\n \"52.176.0.136/32\",\r\n - \ \"52.176.7.71/32\",\r\n \"52.176.101.49/32\",\r\n \"52.176.155.127/32\",\r\n - \ \"52.182.138.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.CentralUSEUAP\",\r\n \"id\": \"AzureCosmosDB.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"40.78.203.32/27\",\r\n - \ \"52.180.160.251/32\",\r\n \"52.180.161.1/32\",\r\n \"52.180.177.137/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.EastAsia\",\r\n - \ \"id\": \"AzureCosmosDB.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"13.75.34.0/26\",\r\n \"23.102.239.134/32\",\r\n - \ \"52.175.25.211/32\",\r\n \"52.175.39.232/32\",\r\n \"207.46.150.252/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.EastUS\",\r\n - \ \"id\": \"AzureCosmosDB.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"13.82.53.191/32\",\r\n \"13.90.199.155/32\",\r\n - \ \"40.71.10.0/25\",\r\n \"40.71.17.19/32\",\r\n \"40.71.203.37/32\",\r\n - \ \"40.71.204.115/32\",\r\n \"40.71.216.114/32\",\r\n \"40.78.226.0/25\",\r\n - \ \"40.79.154.128/26\",\r\n \"40.85.178.211/32\",\r\n \"52.168.28.222/32\",\r\n - \ \"52.170.204.83/32\",\r\n \"52.186.69.224/32\",\r\n \"52.191.197.220/32\",\r\n - \ \"52.226.18.140/32\",\r\n \"52.226.21.178/32\",\r\n \"104.45.131.193/32\",\r\n - \ \"104.45.144.73/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.EastUS2\",\r\n \"id\": \"AzureCosmosDB.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.68.28.135/32\",\r\n - \ \"40.70.0.140/32\",\r\n \"40.70.220.202/32\",\r\n \"40.79.39.162/32\",\r\n - \ \"40.79.59.92/32\",\r\n \"40.79.67.136/32\",\r\n \"52.167.107.128/26\",\r\n - \ \"52.177.172.74/32\",\r\n \"52.177.206.153/32\",\r\n \"52.179.141.33/32\",\r\n - \ \"52.179.143.233/32\",\r\n \"52.179.200.0/25\",\r\n \"52.184.152.241/32\",\r\n - \ \"104.208.231.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.EastUS2EUAP\",\r\n \"id\": \"AzureCosmosDB.EastUS2EUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"40.74.147.192/26\",\r\n - \ \"40.75.32.32/29\",\r\n \"40.75.34.128/26\",\r\n \"40.89.67.208/32\",\r\n - \ \"52.138.66.90/32\",\r\n \"52.138.70.62/32\",\r\n \"52.138.92.0/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.FranceCentral\",\r\n - \ \"id\": \"AzureCosmosDB.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.130.0/28\",\r\n \"40.79.138.48/28\",\r\n - \ \"40.79.146.48/28\",\r\n \"40.89.132.238/32\",\r\n \"52.143.136.41/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.FranceSouth\",\r\n - \ \"id\": \"AzureCosmosDB.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.178.0/28\",\r\n \"52.136.134.25/32\",\r\n - \ \"52.136.134.250/32\",\r\n \"52.136.136.70/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.GermanyNorth\",\r\n - \ \"id\": \"AzureCosmosDB.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.58.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.GermanyWestCentral\",\r\n - \ \"id\": \"AzureCosmosDB.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.154.128/26\",\r\n \"51.116.242.0/26\",\r\n - \ \"51.116.250.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.JapanEast\",\r\n \"id\": \"AzureCosmosDB.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.78.51.35/32\",\r\n - \ \"13.78.106.0/26\",\r\n \"40.79.186.16/28\",\r\n \"40.79.194.128/26\",\r\n - \ \"40.115.241.37/32\",\r\n \"104.41.177.93/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.JapanWest\",\r\n - \ \"id\": \"AzureCosmosDB.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.98.0/26\",\r\n \"40.74.143.235/32\",\r\n - \ \"104.215.1.53/32\",\r\n \"104.215.21.39/32\",\r\n \"104.215.55.227/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.KoreaCentral\",\r\n - \ \"id\": \"AzureCosmosDB.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.26.0/26\",\r\n \"20.194.66.64/26\",\r\n - \ \"52.231.18.0/28\",\r\n \"52.231.25.123/32\",\r\n \"52.231.39.143/32\",\r\n - \ \"52.231.56.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.KoreaSouth\",\r\n \"id\": \"AzureCosmosDB.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"52.231.146.0/27\",\r\n - \ \"52.231.206.234/32\",\r\n \"52.231.207.31/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorthCentralUS\",\r\n - \ \"id\": \"AzureCosmosDB.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"23.96.180.213/32\",\r\n \"23.96.219.207/32\",\r\n - \ \"23.96.242.234/32\",\r\n \"52.162.106.0/26\",\r\n \"52.162.252.26/32\",\r\n - \ \"65.52.210.9/32\",\r\n \"157.55.170.133/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorthEurope\",\r\n - \ \"id\": \"AzureCosmosDB.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.226.0/25\",\r\n \"13.74.106.0/25\",\r\n - \ \"13.79.34.236/32\",\r\n \"40.113.90.91/32\",\r\n \"52.138.141.112/32\",\r\n - \ \"52.138.197.33/32\",\r\n \"52.138.201.47/32\",\r\n \"52.138.205.97/32\",\r\n - \ \"52.138.206.153/32\",\r\n \"52.138.227.192/26\",\r\n \"52.164.250.188/32\",\r\n - \ \"52.169.122.37/32\",\r\n \"52.169.219.183/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorwayEast\",\r\n - \ \"id\": \"AzureCosmosDB.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"51.120.98.64/26\",\r\n \"51.120.106.0/26\",\r\n - \ \"51.120.210.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.NorwayWest\",\r\n \"id\": \"AzureCosmosDB.NorwayWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureCosmosDB.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.122.0/26\",\r\n \"102.133.154.64/26\",\r\n - \ \"102.133.250.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.SouthAfricaWest\",\r\n \"id\": \"AzureCosmosDB.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthCentralUS\",\r\n - \ \"id\": \"AzureCosmosDB.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.145.92/32\",\r\n \"13.66.26.107/32\",\r\n - \ \"13.84.150.178/32\",\r\n \"13.84.157.70/32\",\r\n \"13.85.16.188/32\",\r\n - \ \"20.45.122.0/26\",\r\n \"20.49.90.64/26\",\r\n \"23.102.191.13/32\",\r\n - \ \"104.210.217.251/32\",\r\n \"104.214.18.0/25\",\r\n \"104.214.23.192/27\",\r\n - \ \"104.214.26.177/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.SoutheastAsia\",\r\n \"id\": \"AzureCosmosDB.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.0/26\",\r\n - \ \"13.76.161.130/32\",\r\n \"23.98.82.0/26\",\r\n \"40.78.236.192/26\",\r\n - \ \"52.163.63.20/32\",\r\n \"52.163.249.82/32\",\r\n \"52.187.11.8/32\",\r\n - \ \"52.187.12.93/32\",\r\n \"52.230.15.63/32\",\r\n \"52.230.23.170/32\",\r\n - \ \"52.230.70.94/32\",\r\n \"52.230.87.21/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthIndia\",\r\n - \ \"id\": \"AzureCosmosDB.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.115.125/32\",\r\n \"13.71.124.81/32\",\r\n - \ \"40.78.194.0/28\",\r\n \"52.172.55.127/32\",\r\n \"104.211.227.84/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureCosmosDB.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.58.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SwitzerlandWest\",\r\n - \ \"id\": \"AzureCosmosDB.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.154.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UAECentral\",\r\n - \ \"id\": \"AzureCosmosDB.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.75.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UAENorth\",\r\n - \ \"id\": \"AzureCosmosDB.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"40.120.74.64/26\",\r\n \"65.52.251.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKNorth\",\r\n - \ \"id\": \"AzureCosmosDB.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.87.122.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKSouth\",\r\n - \ \"id\": \"AzureCosmosDB.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"51.105.66.0/26\",\r\n \"51.105.74.0/26\",\r\n \"51.140.52.73/32\",\r\n - \ \"51.140.70.75/32\",\r\n \"51.140.75.146/32\",\r\n \"51.140.83.56/32\",\r\n - \ \"51.140.99.233/32\",\r\n \"51.140.146.0/27\",\r\n \"51.143.189.37/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKSouth2\",\r\n - \ \"id\": \"AzureCosmosDB.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.87.56.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKWest\",\r\n - \ \"id\": \"AzureCosmosDB.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"51.140.210.0/27\",\r\n \"51.141.11.34/32\",\r\n - \ \"51.141.25.77/32\",\r\n \"51.141.53.76/32\",\r\n \"51.141.55.229/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestCentralUS\",\r\n - \ \"id\": \"AzureCosmosDB.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.0/26\",\r\n \"13.78.188.25/32\",\r\n - \ \"52.161.13.67/32\",\r\n \"52.161.15.197/32\",\r\n \"52.161.22.131/32\",\r\n - \ \"52.161.100.126/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureCosmosDB.WestEurope\",\r\n \"id\": \"AzureCosmosDB.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.69.66.0/25\",\r\n - \ \"13.69.66.128/29\",\r\n \"13.69.112.0/25\",\r\n \"13.81.51.99/32\",\r\n - \ \"13.94.201.5/32\",\r\n \"13.95.234.68/32\",\r\n \"40.68.44.85/32\",\r\n - \ \"40.114.240.253/32\",\r\n \"51.144.177.166/32\",\r\n \"51.144.182.233/32\",\r\n - \ \"52.174.253.239/32\",\r\n \"52.178.108.222/32\",\r\n \"52.232.59.220/32\",\r\n - \ \"52.233.128.86/32\",\r\n \"52.236.189.0/26\",\r\n \"104.45.16.183/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestIndia\",\r\n - \ \"id\": \"AzureCosmosDB.WestIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n - \ \"addressPrefixes\": [\r\n \"104.211.146.0/28\",\r\n \"104.211.162.94/32\",\r\n - \ \"104.211.184.117/32\",\r\n \"104.211.188.174/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestUS\",\r\n - \ \"id\": \"AzureCosmosDB.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"13.64.69.151/32\",\r\n \"13.64.113.68/32\",\r\n - \ \"13.64.114.48/32\",\r\n \"13.64.194.140/32\",\r\n \"13.88.30.39/32\",\r\n - \ \"13.91.246.52/32\",\r\n \"13.93.153.80/32\",\r\n \"13.93.156.125/32\",\r\n - \ \"13.93.207.66/32\",\r\n \"40.83.137.191/32\",\r\n \"40.112.140.12/32\",\r\n - \ \"40.112.241.0/24\",\r\n \"40.112.249.60/32\",\r\n \"40.118.245.44/32\",\r\n - \ \"40.118.245.251/32\",\r\n \"137.117.9.157/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestUS2\",\r\n - \ \"id\": \"AzureCosmosDB.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.0/26\",\r\n \"20.36.26.132/32\",\r\n \"40.65.106.154/32\",\r\n - \ \"40.65.114.105/32\",\r\n \"40.78.243.192/26\",\r\n \"40.78.250.0/26\",\r\n - \ \"52.151.16.118/32\",\r\n \"52.158.234.203/32\",\r\n \"52.183.42.252/32\",\r\n - \ \"52.183.66.36/32\",\r\n \"52.183.92.223/32\",\r\n \"52.183.119.101/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDatabricks\",\r\n - \ \"id\": \"AzureDatabricks\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureDatabricks\",\r\n \"addressPrefixes\": - [\r\n \"13.70.105.50/32\",\r\n \"13.70.107.141/32\",\r\n - \ \"13.71.184.74/32\",\r\n \"13.71.187.166/32\",\r\n \"13.75.218.172/32\",\r\n - \ \"13.78.18.152/32\",\r\n \"13.78.19.235/32\",\r\n \"20.36.120.68/30\",\r\n - \ \"20.37.64.68/30\",\r\n \"20.37.156.208/28\",\r\n \"20.37.195.16/29\",\r\n - \ \"20.37.224.68/30\",\r\n \"20.38.84.80/28\",\r\n \"20.38.136.120/29\",\r\n - \ \"20.39.8.68/30\",\r\n \"20.41.4.112/28\",\r\n \"20.41.65.136/29\",\r\n - \ \"20.41.192.68/30\",\r\n \"20.42.4.208/28\",\r\n \"20.42.129.160/28\",\r\n - \ \"20.42.224.68/30\",\r\n \"20.43.41.152/29\",\r\n \"20.43.65.144/29\",\r\n - \ \"20.43.130.96/28\",\r\n \"20.45.112.68/30\",\r\n \"20.45.192.68/30\",\r\n - \ \"20.150.160.104/30\",\r\n \"20.150.160.208/29\",\r\n \"20.189.106.192/28\",\r\n - \ \"20.192.160.32/29\",\r\n \"20.192.225.24/29\",\r\n \"23.100.0.135/32\",\r\n - \ \"23.101.147.147/32\",\r\n \"23.101.152.95/32\",\r\n \"40.67.48.68/30\",\r\n - \ \"40.70.58.221/32\",\r\n \"40.74.30.80/28\",\r\n \"40.80.56.68/30\",\r\n - \ \"40.80.168.68/30\",\r\n \"40.80.188.0/28\",\r\n \"40.82.248.112/28\",\r\n - \ \"40.83.176.199/32\",\r\n \"40.83.178.242/32\",\r\n \"40.85.223.25/32\",\r\n - \ \"40.89.16.68/30\",\r\n \"40.89.168.225/32\",\r\n \"40.89.170.184/32\",\r\n - \ \"40.89.171.101/32\",\r\n \"40.118.174.12/32\",\r\n \"40.119.9.208/28\",\r\n - \ \"40.123.212.253/32\",\r\n \"40.123.218.63/32\",\r\n \"40.123.219.125/32\",\r\n - \ \"40.127.5.82/32\",\r\n \"40.127.5.124/32\",\r\n \"51.12.41.16/30\",\r\n - \ \"51.12.193.16/30\",\r\n \"51.104.25.136/30\",\r\n \"51.105.80.68/30\",\r\n - \ \"51.105.88.68/30\",\r\n \"51.107.48.120/30\",\r\n \"51.107.144.68/30\",\r\n - \ \"51.120.40.120/30\",\r\n \"51.120.224.68/30\",\r\n \"51.137.160.120/29\",\r\n - \ \"51.140.200.46/32\",\r\n \"51.140.203.27/32\",\r\n \"51.140.204.4/32\",\r\n - \ \"51.143.192.68/30\",\r\n \"52.136.48.68/30\",\r\n \"52.140.104.120/29\",\r\n - \ \"52.141.6.71/32\",\r\n \"52.141.6.181/32\",\r\n \"52.141.22.164/32\",\r\n - \ \"52.150.136.68/30\",\r\n \"52.187.0.85/32\",\r\n \"52.187.3.203/32\",\r\n - \ \"52.187.145.107/32\",\r\n \"52.228.81.136/29\",\r\n \"52.232.19.246/32\",\r\n - \ \"52.246.160.72/32\",\r\n \"102.133.56.68/30\",\r\n \"102.133.216.96/29\",\r\n - \ \"102.133.224.24/32\",\r\n \"104.41.54.118/32\",\r\n \"104.45.7.191/32\",\r\n - \ \"104.211.89.81/32\",\r\n \"104.211.101.14/32\",\r\n \"104.211.103.82/32\",\r\n - \ \"191.232.53.223/32\",\r\n \"191.233.8.32/29\",\r\n \"191.234.160.82/32\",\r\n - \ \"191.235.225.144/29\",\r\n \"2603:1000:104:1::160/123\",\r\n - \ \"2603:1010:6:1::160/123\",\r\n \"2603:1020:5:1::160/123\",\r\n - \ \"2603:1020:206:1::160/123\",\r\n \"2603:1020:705:1::160/123\",\r\n - \ \"2603:1020:805:1::160/123\",\r\n \"2603:1020:a04:1::160/123\",\r\n - \ \"2603:1020:c04:1::160/123\",\r\n \"2603:1020:e04:1::160/123\",\r\n - \ \"2603:1020:1004::160/123\",\r\n \"2603:1030:10:1::160/123\",\r\n - \ \"2603:1030:104:1::160/123\",\r\n \"2603:1030:210:1::160/123\",\r\n - \ \"2603:1030:40b:1::160/123\",\r\n \"2603:1030:40c:1::160/123\",\r\n - \ \"2603:1030:504:1::160/123\",\r\n \"2603:1030:807:1::160/123\",\r\n - \ \"2603:1030:c06:1::160/123\",\r\n \"2603:1030:f05:1::160/123\",\r\n - \ \"2603:1040:5:1::160/123\",\r\n \"2603:1040:407:1::160/123\",\r\n - \ \"2603:1040:904:1::160/123\",\r\n \"2603:1040:a06:1::160/123\",\r\n - \ \"2603:1040:d04::160/123\",\r\n \"2603:1040:f05:1::160/123\",\r\n - \ \"2603:1050:6:1::160/123\",\r\n \"2603:1050:403::160/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement\",\r\n - \ \"id\": \"AzureDataExplorerManagement\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.38.225/32\",\r\n \"13.66.141.160/28\",\r\n - \ \"13.69.106.240/28\",\r\n \"13.69.229.176/28\",\r\n \"13.70.73.112/28\",\r\n - \ \"13.71.173.64/28\",\r\n \"13.71.196.64/28\",\r\n \"13.73.240.96/28\",\r\n - \ \"13.75.39.0/28\",\r\n \"13.77.52.240/28\",\r\n \"13.86.36.42/32\",\r\n - \ \"13.86.219.64/28\",\r\n \"13.87.57.224/28\",\r\n \"13.87.123.224/28\",\r\n - \ \"13.89.174.80/28\",\r\n \"20.36.242.104/32\",\r\n \"20.37.24.1/32\",\r\n - \ \"20.39.97.38/32\",\r\n \"20.39.99.177/32\",\r\n \"20.40.114.21/32\",\r\n - \ \"20.40.161.39/32\",\r\n \"20.43.89.90/32\",\r\n \"20.43.120.96/28\",\r\n - \ \"20.44.16.96/28\",\r\n \"20.44.27.96/28\",\r\n \"20.45.3.60/32\",\r\n - \ \"20.46.146.7/32\",\r\n \"20.150.171.192/28\",\r\n \"20.185.100.27/32\",\r\n - \ \"20.189.74.103/32\",\r\n \"20.192.235.128/28\",\r\n \"20.193.203.96/28\",\r\n - \ \"23.98.82.240/28\",\r\n \"40.66.57.57/32\",\r\n \"40.66.57.91/32\",\r\n - \ \"40.67.188.68/32\",\r\n \"40.69.107.240/28\",\r\n \"40.71.13.176/28\",\r\n - \ \"40.74.101.208/28\",\r\n \"40.74.147.80/28\",\r\n \"40.78.195.240/28\",\r\n - \ \"40.78.203.176/28\",\r\n \"40.79.131.224/28\",\r\n \"40.79.179.208/28\",\r\n - \ \"40.79.187.16/28\",\r\n \"40.80.234.9/32\",\r\n \"40.80.250.168/32\",\r\n - \ \"40.80.255.12/32\",\r\n \"40.81.28.50/32\",\r\n \"40.81.43.47/32\",\r\n - \ \"40.81.56.122/32\",\r\n \"40.81.72.110/32\",\r\n \"40.81.88.112/32\",\r\n - \ \"40.81.89.242/32\",\r\n \"40.81.122.39/32\",\r\n \"40.81.154.254/32\",\r\n - \ \"40.81.184.86/32\",\r\n \"40.81.220.38/32\",\r\n \"40.81.248.53/32\",\r\n - \ \"40.81.249.251/32\",\r\n \"40.82.154.174/32\",\r\n \"40.82.156.149/32\",\r\n - \ \"40.82.188.208/32\",\r\n \"40.82.217.84/32\",\r\n \"40.82.236.24/32\",\r\n - \ \"40.89.56.69/32\",\r\n \"40.90.219.23/32\",\r\n \"40.91.74.95/32\",\r\n - \ \"40.119.3.195/32\",\r\n \"40.119.203.252/32\",\r\n \"51.12.99.192/28\",\r\n - \ \"51.12.203.192/28\",\r\n \"51.104.8.112/28\",\r\n \"51.107.59.160/28\",\r\n - \ \"51.107.98.201/32\",\r\n \"51.107.155.160/28\",\r\n \"51.116.59.160/28\",\r\n - \ \"51.116.98.150/32\",\r\n \"51.116.155.224/28\",\r\n \"51.120.99.80/28\",\r\n - \ \"51.120.219.192/28\",\r\n \"51.140.212.0/28\",\r\n \"51.145.176.215/32\",\r\n - \ \"52.142.91.221/32\",\r\n \"52.159.55.120/32\",\r\n \"52.162.110.176/28\",\r\n - \ \"52.224.146.56/32\",\r\n \"52.231.148.16/28\",\r\n \"52.232.230.201/32\",\r\n - \ \"52.253.159.186/32\",\r\n \"52.253.225.186/32\",\r\n \"52.253.226.110/32\",\r\n - \ \"102.133.0.192/32\",\r\n \"102.133.28.112/28\",\r\n \"102.133.130.206/32\",\r\n - \ \"102.133.156.16/28\",\r\n \"104.211.147.224/28\",\r\n - \ \"191.233.25.183/32\",\r\n \"191.233.50.208/28\",\r\n \"191.233.205.0/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.AustraliaCentral\",\r\n - \ \"id\": \"AzureDataExplorerManagement.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.24.1/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.AustraliaCentral2\",\r\n - \ \"id\": \"AzureDataExplorerManagement.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.97.38/32\",\r\n \"20.39.99.177/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.AustraliaEast\",\r\n - \ \"id\": \"AzureDataExplorerManagement.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.73.112/28\",\r\n \"40.82.217.84/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureDataExplorerManagement.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.52.240/28\",\r\n \"20.40.161.39/32\",\r\n - \ \"40.81.56.122/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.BrazilSouth\",\r\n \"id\": - \"AzureDataExplorerManagement.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.40.114.21/32\",\r\n \"191.233.25.183/32\",\r\n - \ \"191.233.205.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.CanadaCentral\",\r\n \"id\": - \"AzureDataExplorerManagement.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.173.64/28\",\r\n \"40.82.188.208/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.CanadaEast\",\r\n - \ \"id\": \"AzureDataExplorerManagement.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.107.240/28\",\r\n \"40.80.250.168/32\",\r\n - \ \"40.80.255.12/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.CentralIndia\",\r\n \"id\": - \"AzureDataExplorerManagement.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.120.96/28\",\r\n \"40.81.248.53/32\",\r\n - \ \"40.81.249.251/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.CentralUS\",\r\n \"id\": - \"AzureDataExplorerManagement.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.36.42/32\",\r\n \"13.89.174.80/28\",\r\n - \ \"40.67.188.68/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.CentralUSEUAP\",\r\n \"id\": - \"AzureDataExplorerManagement.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.203.176/28\",\r\n \"40.89.56.69/32\",\r\n - \ \"52.253.159.186/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.EastAsia\",\r\n \"id\": - \"AzureDataExplorerManagement.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureDataExplorerManagement\",\r\n \"addressPrefixes\": [\r\n \"13.75.39.0/28\",\r\n - \ \"20.189.74.103/32\",\r\n \"40.81.28.50/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.EastUS\",\r\n - \ \"id\": \"AzureDataExplorerManagement.EastUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.185.100.27/32\",\r\n \"40.71.13.176/28\",\r\n - \ \"52.224.146.56/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.EastUS2EUAP\",\r\n \"id\": - \"AzureDataExplorerManagement.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.147.80/28\",\r\n \"52.253.225.186/32\",\r\n - \ \"52.253.226.110/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.FranceCentral\",\r\n \"id\": - \"AzureDataExplorerManagement.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.66.57.57/32\",\r\n \"40.66.57.91/32\",\r\n - \ \"40.79.131.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.FranceSouth\",\r\n \"id\": - \"AzureDataExplorerManagement.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.179.208/28\",\r\n \"40.82.236.24/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.GermanyNorth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.59.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.GermanyWestCentral\",\r\n - \ \"id\": \"AzureDataExplorerManagement.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.98.150/32\",\r\n \"51.116.155.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.JapanEast\",\r\n - \ \"id\": \"AzureDataExplorerManagement.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.89.90/32\",\r\n \"40.79.187.16/28\",\r\n - \ \"40.81.220.38/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.JapanWest\",\r\n \"id\": - \"AzureDataExplorerManagement.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.101.208/28\",\r\n \"40.81.184.86/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.KoreaCentral\",\r\n - \ \"id\": \"AzureDataExplorerManagement.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.27.96/28\",\r\n \"40.82.154.174/32\",\r\n - \ \"40.82.156.149/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.KoreaSouth\",\r\n \"id\": - \"AzureDataExplorerManagement.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.234.9/32\",\r\n \"52.231.148.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.NorthCentralUS\",\r\n - \ \"id\": \"AzureDataExplorerManagement.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.81.43.47/32\",\r\n \"52.162.110.176/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.NorthEurope\",\r\n - \ \"id\": \"AzureDataExplorerManagement.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.229.176/28\",\r\n \"52.142.91.221/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.NorwayEast\",\r\n - \ \"id\": \"AzureDataExplorerManagement.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.99.80/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.NorwayWest\",\r\n - \ \"id\": \"AzureDataExplorerManagement.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.219.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.130.206/32\",\r\n \"102.133.156.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthAfricaWest\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.0.192/32\",\r\n \"102.133.28.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthCentralUS\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.240.96/28\",\r\n \"20.45.3.60/32\",\r\n - \ \"40.119.3.195/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.SoutheastAsia\",\r\n \"id\": - \"AzureDataExplorerManagement.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"23.98.82.240/28\",\r\n \"40.119.203.252/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthIndia\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.195.240/28\",\r\n \"40.81.72.110/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.59.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SwitzerlandWest\",\r\n - \ \"id\": \"AzureDataExplorerManagement.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.98.201/32\",\r\n \"51.107.155.160/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UAENorth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.46.146.7/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKNorth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.UKNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.123.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKSouth\",\r\n - \ \"id\": \"AzureDataExplorerManagement.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.81.154.254/32\",\r\n \"51.104.8.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKSouth2\",\r\n - \ \"id\": \"AzureDataExplorerManagement.UKSouth2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.57.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKWest\",\r\n - \ \"id\": \"AzureDataExplorerManagement.UKWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.81.122.39/32\",\r\n \"51.140.212.0/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.WestCentralUS\",\r\n - \ \"id\": \"AzureDataExplorerManagement.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.196.64/28\",\r\n \"52.159.55.120/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.WestEurope\",\r\n - \ \"id\": \"AzureDataExplorerManagement.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.106.240/28\",\r\n \"51.145.176.215/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.WestIndia\",\r\n - \ \"id\": \"AzureDataExplorerManagement.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.81.88.112/32\",\r\n \"40.81.89.242/32\",\r\n - \ \"104.211.147.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataExplorerManagement.WestUS\",\r\n \"id\": \"AzureDataExplorerManagement.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.38.225/32\",\r\n \"13.86.219.64/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.WestUS2\",\r\n - \ \"id\": \"AzureDataExplorerManagement.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataExplorerManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.141.160/28\",\r\n \"40.90.219.23/32\",\r\n - \ \"40.91.74.95/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataLake\",\r\n \"id\": \"AzureDataLake\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": - [\r\n \"40.90.138.133/32\",\r\n \"40.90.138.136/32\",\r\n - \ \"40.90.141.128/29\",\r\n \"40.90.141.167/32\",\r\n \"40.90.144.0/27\",\r\n - \ \"40.90.145.192/26\",\r\n \"65.52.108.31/32\",\r\n \"65.52.108.38/32\",\r\n - \ \"104.44.88.66/31\",\r\n \"104.44.88.106/31\",\r\n \"104.44.88.112/31\",\r\n - \ \"104.44.88.176/31\",\r\n \"104.44.88.184/29\",\r\n \"104.44.89.39/32\",\r\n - \ \"104.44.89.42/32\",\r\n \"104.44.90.128/27\",\r\n \"104.44.90.194/31\",\r\n - \ \"104.44.91.64/27\",\r\n \"104.44.91.160/27\",\r\n \"104.44.93.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureDataLake.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": - [\r\n \"40.90.138.133/32\",\r\n \"40.90.138.136/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.CentralUS\",\r\n - \ \"id\": \"AzureDataLake.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": - [\r\n \"40.90.144.0/27\",\r\n \"104.44.88.176/31\",\r\n - \ \"104.44.88.184/29\",\r\n \"104.44.91.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.EastUS2\",\r\n - \ \"id\": \"AzureDataLake.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureDataLake\",\r\n \"addressPrefixes\": [\r\n \"65.52.108.31/32\",\r\n - \ \"65.52.108.38/32\",\r\n \"104.44.88.106/31\",\r\n \"104.44.88.112/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.NorthEurope\",\r\n - \ \"id\": \"AzureDataLake.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": - [\r\n \"40.90.141.128/29\",\r\n \"40.90.145.224/27\",\r\n - \ \"104.44.88.66/31\",\r\n \"104.44.91.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.SoutheastAsia\",\r\n - \ \"id\": \"AzureDataLake.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": - [\r\n \"104.44.89.39/32\",\r\n \"104.44.89.42/32\",\r\n - \ \"104.44.90.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDataLake.WestEurope\",\r\n \"id\": \"AzureDataLake.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataLake\",\r\n - \ \"addressPrefixes\": [\r\n \"40.90.141.167/32\",\r\n \"40.90.145.192/27\",\r\n - \ \"104.44.90.194/31\",\r\n \"104.44.93.192/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces\",\r\n \"id\": - \"AzureDevSpaces\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"13.69.71.144/28\",\r\n \"13.70.78.176/28\",\r\n - \ \"13.71.175.112/28\",\r\n \"13.71.199.96/28\",\r\n \"13.73.244.128/28\",\r\n - \ \"13.74.111.128/28\",\r\n \"13.78.111.144/28\",\r\n \"13.86.221.224/28\",\r\n - \ \"20.37.157.64/28\",\r\n \"20.37.195.80/28\",\r\n \"20.38.85.128/28\",\r\n - \ \"20.39.11.64/28\",\r\n \"20.41.5.128/28\",\r\n \"20.42.6.32/27\",\r\n - \ \"20.42.6.128/28\",\r\n \"20.42.64.64/26\",\r\n \"20.42.131.192/27\",\r\n - \ \"20.42.230.64/28\",\r\n \"20.43.65.208/28\",\r\n \"20.43.130.240/28\",\r\n - \ \"20.189.108.32/28\",\r\n \"40.69.110.176/28\",\r\n \"40.70.151.80/28\",\r\n - \ \"40.74.30.144/28\",\r\n \"40.75.35.224/28\",\r\n \"40.78.239.0/28\",\r\n - \ \"40.78.251.224/27\",\r\n \"40.82.253.112/28\",\r\n \"40.89.17.192/28\",\r\n - \ \"40.119.9.240/28\",\r\n \"51.104.25.208/28\",\r\n \"51.105.77.64/28\",\r\n - \ \"52.150.139.144/28\",\r\n \"52.182.141.128/28\",\r\n \"52.228.81.224/28\",\r\n - \ \"104.214.161.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDevSpaces.AustraliaEast\",\r\n \"id\": \"AzureDevSpaces.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"13.70.78.176/28\",\r\n - \ \"20.37.195.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureDevSpaces.AustraliaSoutheast\",\r\n \"id\": \"AzureDevSpaces.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.42.230.64/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.CanadaCentral\",\r\n - \ \"id\": \"AzureDevSpaces.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.175.112/28\",\r\n \"52.228.81.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.CanadaEast\",\r\n - \ \"id\": \"AzureDevSpaces.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.110.176/28\",\r\n \"40.89.17.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.CentralUS\",\r\n - \ \"id\": \"AzureDevSpaces.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.157.64/28\",\r\n \"52.182.141.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastAsia\",\r\n - \ \"id\": \"AzureDevSpaces.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.108.32/28\",\r\n \"104.214.161.48/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastUS\",\r\n - \ \"id\": \"AzureDevSpaces.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"20.42.6.32/27\",\r\n \"20.42.6.128/28\",\r\n \"20.42.64.64/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastUS2\",\r\n - \ \"id\": \"AzureDevSpaces.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"20.41.5.128/28\",\r\n \"40.70.151.80/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastUS2EUAP\",\r\n - \ \"id\": \"AzureDevSpaces.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.11.64/28\",\r\n \"40.75.35.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.JapanEast\",\r\n - \ \"id\": \"AzureDevSpaces.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.111.144/28\",\r\n \"20.43.65.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.NorthEurope\",\r\n - \ \"id\": \"AzureDevSpaces.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.74.111.128/28\",\r\n \"20.38.85.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.SouthCentralUS\",\r\n - \ \"id\": \"AzureDevSpaces.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.244.128/28\",\r\n \"40.119.9.240/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.SoutheastAsia\",\r\n - \ \"id\": \"AzureDevSpaces.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.130.240/28\",\r\n \"40.78.239.0/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.UKSouth\",\r\n - \ \"id\": \"AzureDevSpaces.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"51.104.25.208/28\",\r\n \"51.105.77.64/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestCentralUS\",\r\n - \ \"id\": \"AzureDevSpaces.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.199.96/28\",\r\n \"52.150.139.144/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestEurope\",\r\n - \ \"id\": \"AzureDevSpaces.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.71.144/28\",\r\n \"40.74.30.144/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestUS\",\r\n - \ \"id\": \"AzureDevSpaces.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"13.86.221.224/28\",\r\n \"40.82.253.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestUS2\",\r\n - \ \"id\": \"AzureDevSpaces.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": - [\r\n \"20.42.131.192/27\",\r\n \"40.78.251.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid\",\r\n - \ \"id\": \"AzureEventGrid\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"13.71.56.240/28\",\r\n \"13.71.57.0/28\",\r\n \"13.73.248.128/25\",\r\n - \ \"13.86.56.32/27\",\r\n \"13.86.56.160/27\",\r\n \"13.88.73.16/28\",\r\n - \ \"13.88.73.32/27\",\r\n \"13.88.135.208/28\",\r\n \"13.91.193.0/28\",\r\n - \ \"20.36.121.0/25\",\r\n \"20.37.55.32/27\",\r\n \"20.37.65.0/25\",\r\n - \ \"20.37.82.224/27\",\r\n \"20.37.157.128/25\",\r\n \"20.37.196.0/25\",\r\n - \ \"20.37.225.0/25\",\r\n \"20.38.87.0/25\",\r\n \"20.38.137.0/25\",\r\n - \ \"20.39.11.128/25\",\r\n \"20.39.20.16/28\",\r\n \"20.39.80.112/28\",\r\n - \ \"20.39.80.128/28\",\r\n \"20.39.99.64/28\",\r\n \"20.39.99.240/28\",\r\n - \ \"20.40.152.128/27\",\r\n \"20.40.175.48/28\",\r\n \"20.40.175.64/28\",\r\n - \ \"20.41.66.0/25\",\r\n \"20.41.136.240/28\",\r\n \"20.41.195.0/25\",\r\n - \ \"20.42.7.0/25\",\r\n \"20.42.228.0/25\",\r\n \"20.43.42.128/25\",\r\n - \ \"20.43.66.128/25\",\r\n \"20.43.131.128/25\",\r\n \"20.43.165.144/28\",\r\n - \ \"20.43.172.128/27\",\r\n \"20.44.39.176/28\",\r\n \"20.44.39.192/28\",\r\n - \ \"20.44.168.64/28\",\r\n \"20.44.205.112/28\",\r\n \"20.45.113.0/25\",\r\n - \ \"20.45.195.0/25\",\r\n \"20.46.152.112/28\",\r\n \"20.46.152.128/28\",\r\n - \ \"20.49.96.0/25\",\r\n \"20.150.164.0/25\",\r\n \"20.189.108.128/25\",\r\n - \ \"20.189.115.80/28\",\r\n \"20.189.123.80/28\",\r\n \"20.189.125.32/27\",\r\n - \ \"20.191.59.128/28\",\r\n \"20.191.59.176/28\",\r\n \"20.192.164.0/25\",\r\n - \ \"20.192.228.0/25\",\r\n \"20.193.34.0/28\",\r\n \"20.193.34.32/28\",\r\n - \ \"40.64.128.0/25\",\r\n \"40.67.49.0/25\",\r\n \"40.74.31.128/25\",\r\n - \ \"40.74.106.96/27\",\r\n \"40.80.58.0/25\",\r\n \"40.80.170.0/25\",\r\n - \ \"40.80.190.0/25\",\r\n \"40.80.236.192/27\",\r\n \"40.81.93.240/28\",\r\n - \ \"40.81.95.128/28\",\r\n \"40.82.254.128/25\",\r\n \"40.89.18.0/25\",\r\n - \ \"40.89.240.144/28\",\r\n \"40.114.160.176/28\",\r\n \"40.114.160.192/28\",\r\n - \ \"40.114.169.0/28\",\r\n \"40.127.155.192/28\",\r\n \"40.127.251.144/28\",\r\n - \ \"51.104.27.128/25\",\r\n \"51.105.81.0/25\",\r\n \"51.105.89.0/25\",\r\n - \ \"51.107.4.128/27\",\r\n \"51.107.49.0/25\",\r\n \"51.107.99.32/27\",\r\n - \ \"51.107.145.0/25\",\r\n \"51.116.3.32/27\",\r\n \"51.116.100.208/28\",\r\n - \ \"51.116.100.224/28\",\r\n \"51.120.4.0/27\",\r\n \"51.120.41.0/25\",\r\n - \ \"51.120.131.64/27\",\r\n \"51.120.225.0/25\",\r\n \"51.132.161.160/28\",\r\n - \ \"51.132.170.64/28\",\r\n \"51.137.16.224/28\",\r\n \"51.137.142.32/28\",\r\n - \ \"51.137.162.0/25\",\r\n \"51.143.193.0/25\",\r\n \"52.136.49.0/25\",\r\n - \ \"52.139.9.80/28\",\r\n \"52.139.11.16/28\",\r\n \"52.139.85.16/28\",\r\n - \ \"52.139.85.32/28\",\r\n \"52.140.106.0/25\",\r\n \"52.142.152.144/28\",\r\n - \ \"52.149.23.160/27\",\r\n \"52.149.48.80/28\",\r\n \"52.149.48.96/27\",\r\n - \ \"52.149.248.0/28\",\r\n \"52.149.248.64/27\",\r\n \"52.149.248.96/28\",\r\n - \ \"52.150.140.0/25\",\r\n \"52.154.57.48/28\",\r\n \"52.154.57.80/28\",\r\n - \ \"52.154.68.16/28\",\r\n \"52.154.68.32/28\",\r\n \"52.156.103.192/28\",\r\n - \ \"52.159.49.144/28\",\r\n \"52.159.51.160/28\",\r\n \"52.159.53.64/28\",\r\n - \ \"52.159.53.112/28\",\r\n \"52.160.136.16/28\",\r\n \"52.160.136.32/28\",\r\n - \ \"52.161.186.128/28\",\r\n \"52.161.186.208/28\",\r\n \"52.167.21.160/27\",\r\n - \ \"52.167.21.208/28\",\r\n \"52.167.21.224/28\",\r\n \"52.170.171.192/28\",\r\n - \ \"52.170.171.240/28\",\r\n \"52.177.38.160/27\",\r\n \"52.185.176.112/28\",\r\n - \ \"52.185.212.176/28\",\r\n \"52.185.212.192/28\",\r\n \"52.186.36.16/28\",\r\n - \ \"52.228.83.0/25\",\r\n \"52.231.112.192/28\",\r\n \"52.231.112.224/28\",\r\n - \ \"52.250.28.176/28\",\r\n \"52.250.32.160/28\",\r\n \"52.252.213.192/28\",\r\n - \ \"52.255.80.16/28\",\r\n \"52.255.82.160/28\",\r\n \"102.133.0.240/28\",\r\n - \ \"102.133.1.0/28\",\r\n \"102.133.57.0/25\",\r\n \"102.133.135.16/28\",\r\n - \ \"102.133.135.32/28\",\r\n \"191.233.9.128/25\",\r\n \"191.235.126.0/28\",\r\n - \ \"191.235.126.144/28\",\r\n \"191.235.227.0/25\",\r\n \"2603:1000:104:1::380/121\",\r\n - \ \"2603:1010:6:1::380/121\",\r\n \"2603:1020:5:1::380/121\",\r\n - \ \"2603:1020:206:1::380/121\",\r\n \"2603:1020:705:1::380/121\",\r\n - \ \"2603:1020:805:1::380/121\",\r\n \"2603:1020:a04:1::380/121\",\r\n - \ \"2603:1020:c04:1::380/121\",\r\n \"2603:1020:e04:1::380/121\",\r\n - \ \"2603:1020:1004::380/121\",\r\n \"2603:1030:10:1::380/121\",\r\n - \ \"2603:1030:104:1::380/121\",\r\n \"2603:1030:210:1::380/121\",\r\n - \ \"2603:1030:40b:1::380/121\",\r\n \"2603:1030:40c:1::380/121\",\r\n - \ \"2603:1030:504:1::380/121\",\r\n \"2603:1030:807:1::380/121\",\r\n - \ \"2603:1030:c06:1::380/121\",\r\n \"2603:1030:f05:1::380/121\",\r\n - \ \"2603:1040:5:1::380/121\",\r\n \"2603:1040:407:1::380/121\",\r\n - \ \"2603:1040:904:1::380/121\",\r\n \"2603:1040:a06:1::380/121\",\r\n - \ \"2603:1040:d04::380/121\",\r\n \"2603:1040:f05:1::380/121\",\r\n - \ \"2603:1050:6:1::380/121\",\r\n \"2603:1050:403::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.AustraliaCentral\",\r\n - \ \"id\": \"AzureEventGrid.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.55.32/27\",\r\n \"20.37.225.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.AustraliaCentral2\",\r\n - \ \"id\": \"AzureEventGrid.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.121.0/25\",\r\n \"20.39.99.64/28\",\r\n - \ \"20.39.99.240/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.AustraliaEast\",\r\n \"id\": \"AzureEventGrid.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.37.196.0/25\",\r\n - \ \"20.193.34.0/28\",\r\n \"20.193.34.32/28\",\r\n \"2603:1010:6:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureEventGrid.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.40.175.48/28\",\r\n \"20.40.175.64/28\",\r\n - \ \"20.42.228.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.BrazilSouth\",\r\n \"id\": \"AzureEventGrid.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"191.235.126.0/28\",\r\n - \ \"191.235.126.144/28\",\r\n \"191.235.227.0/25\",\r\n \"2603:1050:6:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CanadaCentral\",\r\n - \ \"id\": \"AzureEventGrid.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"52.139.9.80/28\",\r\n \"52.139.11.16/28\",\r\n - \ \"52.228.83.0/25\",\r\n \"2603:1030:f05:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CanadaEast\",\r\n - \ \"id\": \"AzureEventGrid.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"40.89.18.0/25\",\r\n \"52.139.85.16/28\",\r\n - \ \"52.139.85.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.CentralIndia\",\r\n \"id\": \"AzureEventGrid.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"13.71.56.240/28\",\r\n - \ \"13.71.57.0/28\",\r\n \"52.140.106.0/25\",\r\n \"2603:1040:a06:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CentralUS\",\r\n - \ \"id\": \"AzureEventGrid.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.56.32/27\",\r\n \"13.86.56.160/27\",\r\n - \ \"20.37.157.128/25\",\r\n \"40.89.240.144/28\",\r\n \"52.154.57.48/28\",\r\n - \ \"52.154.57.80/28\",\r\n \"2603:1030:10:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CentralUSEUAP\",\r\n - \ \"id\": \"AzureEventGrid.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.195.0/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.EastAsia\",\r\n - \ \"id\": \"AzureEventGrid.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.108.128/25\",\r\n \"20.189.115.80/28\",\r\n - \ \"20.189.123.80/28\",\r\n \"20.189.125.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.EastUS\",\r\n - \ \"id\": \"AzureEventGrid.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"20.42.7.0/25\",\r\n \"52.149.248.0/28\",\r\n \"52.149.248.64/27\",\r\n - \ \"52.149.248.96/28\",\r\n \"52.154.68.16/28\",\r\n \"52.154.68.32/28\",\r\n - \ \"52.170.171.192/28\",\r\n \"52.170.171.240/28\",\r\n \"52.186.36.16/28\",\r\n - \ \"2603:1030:210:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.EastUS2\",\r\n \"id\": \"AzureEventGrid.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.49.96.0/25\",\r\n - \ \"52.167.21.160/27\",\r\n \"52.167.21.208/28\",\r\n \"52.167.21.224/28\",\r\n - \ \"52.177.38.160/27\",\r\n \"2603:1030:40c:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.EastUS2EUAP\",\r\n - \ \"id\": \"AzureEventGrid.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.11.128/25\",\r\n \"20.39.20.16/28\",\r\n - \ \"2603:1030:40b:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.FranceCentral\",\r\n \"id\": - \"AzureEventGrid.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"20.40.152.128/27\",\r\n \"20.43.42.128/25\",\r\n - \ \"2603:1020:805:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.FranceSouth\",\r\n \"id\": - \"AzureEventGrid.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"20.39.80.112/28\",\r\n \"20.39.80.128/28\",\r\n - \ \"51.105.89.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.GermanyNorth\",\r\n \"id\": \"AzureEventGrid.GermanyNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanyn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.116.3.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.GermanyWestCentral\",\r\n - \ \"id\": \"AzureEventGrid.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.100.208/28\",\r\n \"51.116.100.224/28\",\r\n - \ \"2603:1020:c04:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.JapanEast\",\r\n \"id\": \"AzureEventGrid.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.43.66.128/25\",\r\n - \ \"20.44.168.64/28\",\r\n \"52.185.176.112/28\",\r\n \"2603:1040:407:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.JapanWest\",\r\n - \ \"id\": \"AzureEventGrid.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.106.96/27\",\r\n \"40.80.58.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.KoreaCentral\",\r\n - \ \"id\": \"AzureEventGrid.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.66.0/25\",\r\n \"52.231.112.192/28\",\r\n - \ \"52.231.112.224/28\",\r\n \"2603:1040:f05:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.KoreaSouth\",\r\n - \ \"id\": \"AzureEventGrid.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.170.0/25\",\r\n \"40.80.236.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.NorthCentralUS\",\r\n - \ \"id\": \"AzureEventGrid.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.136.240/28\",\r\n \"40.80.190.0/25\",\r\n - \ \"52.252.213.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.NorthEurope\",\r\n \"id\": \"AzureEventGrid.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.38.87.0/25\",\r\n - \ \"20.191.59.128/28\",\r\n \"20.191.59.176/28\",\r\n \"40.127.155.192/28\",\r\n - \ \"40.127.251.144/28\",\r\n \"2603:1020:5:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.NorwayEast\",\r\n - \ \"id\": \"AzureEventGrid.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"51.120.4.0/27\",\r\n \"51.120.41.0/25\",\r\n \"2603:1020:e04:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.NorwayWest\",\r\n - \ \"id\": \"AzureEventGrid.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"51.120.131.64/27\",\r\n \"51.120.225.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureEventGrid.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.135.16/28\",\r\n \"102.133.135.32/28\",\r\n - \ \"2603:1000:104:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.SouthAfricaWest\",\r\n \"id\": - \"AzureEventGrid.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"102.133.0.240/28\",\r\n \"102.133.1.0/28\",\r\n - \ \"102.133.57.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.SouthCentralUS\",\r\n \"id\": \"AzureEventGrid.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"13.73.248.128/25\",\r\n - \ \"52.185.212.176/28\",\r\n \"52.185.212.192/28\",\r\n \"52.255.80.16/28\",\r\n - \ \"52.255.82.160/28\",\r\n \"2603:1030:807:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SoutheastAsia\",\r\n - \ \"id\": \"AzureEventGrid.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.131.128/25\",\r\n \"20.43.165.144/28\",\r\n - \ \"20.43.172.128/27\",\r\n \"20.44.205.112/28\",\r\n \"2603:1040:5:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SouthIndia\",\r\n - \ \"id\": \"AzureEventGrid.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.195.0/25\",\r\n \"20.44.39.176/28\",\r\n - \ \"20.44.39.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.SwitzerlandNorth\",\r\n \"id\": \"AzureEventGrid.SwitzerlandNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.107.4.128/27\",\r\n - \ \"51.107.49.0/25\",\r\n \"2603:1020:a04:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SwitzerlandWest\",\r\n - \ \"id\": \"AzureEventGrid.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.99.32/27\",\r\n \"51.107.145.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UAECentral\",\r\n - \ \"id\": \"AzureEventGrid.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.65.0/25\",\r\n \"20.37.82.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UAENorth\",\r\n - \ \"id\": \"AzureEventGrid.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.137.0/25\",\r\n \"20.46.152.112/28\",\r\n - \ \"20.46.152.128/28\",\r\n \"2603:1040:904:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKNorth\",\r\n - \ \"id\": \"AzureEventGrid.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"51.105.81.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.UKSouth\",\r\n \"id\": \"AzureEventGrid.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.104.27.128/25\",\r\n - \ \"51.132.161.160/28\",\r\n \"51.132.170.64/28\",\r\n \"2603:1020:705:1::380/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKSouth2\",\r\n - \ \"id\": \"AzureEventGrid.UKSouth2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"51.143.193.0/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKWest\",\r\n - \ \"id\": \"AzureEventGrid.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"51.137.142.32/28\",\r\n \"51.137.162.0/25\",\r\n - \ \"52.142.152.144/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.WestCentralUS\",\r\n \"id\": \"AzureEventGrid.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"52.150.140.0/25\",\r\n - \ \"52.159.49.144/28\",\r\n \"52.159.51.160/28\",\r\n \"52.159.53.64/28\",\r\n - \ \"52.159.53.112/28\",\r\n \"52.161.186.128/28\",\r\n \"52.161.186.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestEurope\",\r\n - \ \"id\": \"AzureEventGrid.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.31.128/25\",\r\n \"40.114.160.176/28\",\r\n - \ \"40.114.160.192/28\",\r\n \"40.114.169.0/28\",\r\n \"51.137.16.224/28\",\r\n - \ \"2603:1020:206:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureEventGrid.WestIndia\",\r\n \"id\": \"AzureEventGrid.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"40.81.93.240/28\",\r\n - \ \"40.81.95.128/28\",\r\n \"52.136.49.0/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestUS\",\r\n - \ \"id\": \"AzureEventGrid.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": - [\r\n \"13.88.73.16/28\",\r\n \"13.88.73.32/27\",\r\n \"13.88.135.208/28\",\r\n - \ \"13.91.193.0/28\",\r\n \"40.82.254.128/25\",\r\n \"52.160.136.16/28\",\r\n - \ \"52.160.136.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureEventGrid.WestUS2\",\r\n \"id\": \"AzureEventGrid.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"40.64.128.0/25\",\r\n - \ \"52.149.23.160/27\",\r\n \"52.149.48.80/28\",\r\n \"52.149.48.96/27\",\r\n - \ \"52.156.103.192/28\",\r\n \"52.250.28.176/28\",\r\n \"52.250.32.160/28\",\r\n - \ \"2603:1030:c06:1::380/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureFrontDoor.Backend\",\r\n \"id\": \"AzureFrontDoor.Backend\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"\",\r\n \"addressPrefixes\": [\r\n \"13.73.248.16/29\",\r\n - \ \"20.36.120.104/29\",\r\n \"20.37.64.104/29\",\r\n \"20.37.156.120/29\",\r\n - \ \"20.37.195.0/29\",\r\n \"20.37.224.104/29\",\r\n \"20.38.84.72/29\",\r\n - \ \"20.38.136.104/29\",\r\n \"20.39.11.8/29\",\r\n \"20.41.4.88/29\",\r\n - \ \"20.41.64.120/29\",\r\n \"20.41.192.104/29\",\r\n \"20.42.4.120/29\",\r\n - \ \"20.42.129.152/29\",\r\n \"20.42.224.104/29\",\r\n \"20.43.41.136/29\",\r\n - \ \"20.43.65.128/29\",\r\n \"20.43.130.80/29\",\r\n \"20.45.112.104/29\",\r\n - \ \"20.45.192.104/29\",\r\n \"20.150.160.96/29\",\r\n \"20.189.106.112/29\",\r\n - \ \"20.192.161.104/29\",\r\n \"20.192.225.48/29\",\r\n \"40.67.48.104/29\",\r\n - \ \"40.74.30.72/29\",\r\n \"40.80.56.104/29\",\r\n \"40.80.168.104/29\",\r\n - \ \"40.80.184.120/29\",\r\n \"40.82.248.248/29\",\r\n \"40.89.16.104/29\",\r\n - \ \"51.12.41.8/29\",\r\n \"51.12.193.8/29\",\r\n \"51.104.25.128/29\",\r\n - \ \"51.105.80.104/29\",\r\n \"51.105.88.104/29\",\r\n \"51.107.48.104/29\",\r\n - \ \"51.107.144.104/29\",\r\n \"51.120.40.104/29\",\r\n \"51.120.224.104/29\",\r\n - \ \"51.137.160.112/29\",\r\n \"51.143.192.104/29\",\r\n \"52.136.48.104/29\",\r\n - \ \"52.140.104.104/29\",\r\n \"52.150.136.120/29\",\r\n \"52.228.80.120/29\",\r\n - \ \"102.133.56.88/29\",\r\n \"102.133.216.88/29\",\r\n \"147.243.0.0/16\",\r\n - \ \"191.233.9.120/29\",\r\n \"191.235.225.128/29\",\r\n \"2603:1000:104::e0/123\",\r\n - \ \"2603:1000:104::300/123\",\r\n \"2603:1000:104:1::5c0/123\",\r\n - \ \"2603:1000:104:1::7e0/123\",\r\n \"2603:1010:6:1::5c0/123\",\r\n - \ \"2603:1010:6:1::7e0/123\",\r\n \"2603:1020:5:1::5c0/123\",\r\n - \ \"2603:1020:5:1::7e0/123\",\r\n \"2603:1020:206:1::5c0/123\",\r\n - \ \"2603:1020:206:1::7e0/123\",\r\n \"2603:1020:705:1::5c0/123\",\r\n - \ \"2603:1020:705:1::7e0/123\",\r\n \"2603:1020:805:1::5c0/123\",\r\n - \ \"2603:1020:805:1::7e0/123\",\r\n \"2603:1020:a04:1::5c0/123\",\r\n - \ \"2603:1020:a04:1::7e0/123\",\r\n \"2603:1020:c04:1::5c0/123\",\r\n - \ \"2603:1020:c04:1::7e0/123\",\r\n \"2603:1020:e04:1::5c0/123\",\r\n - \ \"2603:1020:e04:1::7e0/123\",\r\n \"2603:1020:1004::5c0/123\",\r\n - \ \"2603:1020:1004::7e0/123\",\r\n \"2603:1030:10:1::5c0/123\",\r\n - \ \"2603:1030:10:1::7e0/123\",\r\n \"2603:1030:104:1::5c0/123\",\r\n - \ \"2603:1030:104:1::7e0/123\",\r\n \"2603:1030:210:1::5c0/123\",\r\n - \ \"2603:1030:210:1::7e0/123\",\r\n \"2603:1030:40b:1::5c0/123\",\r\n - \ \"2603:1030:40c:1::5c0/123\",\r\n \"2603:1030:40c:1::7e0/123\",\r\n - \ \"2603:1030:504:1::5c0/123\",\r\n \"2603:1030:504:1::7e0/123\",\r\n - \ \"2603:1030:807:1::5c0/123\",\r\n \"2603:1030:807:1::7e0/123\",\r\n - \ \"2603:1030:c06:1::5c0/123\",\r\n \"2603:1030:f05:1::5c0/123\",\r\n - \ \"2603:1030:f05:1::7e0/123\",\r\n \"2603:1040:5::e0/123\",\r\n - \ \"2603:1040:5:1::5c0/123\",\r\n \"2603:1040:5:1::7e0/123\",\r\n - \ \"2603:1040:407:1::5c0/123\",\r\n \"2603:1040:407:1::7e0/123\",\r\n - \ \"2603:1040:904:1::5c0/123\",\r\n \"2603:1040:904:1::7e0/123\",\r\n - \ \"2603:1040:a06::e0/123\",\r\n \"2603:1040:a06:1::5c0/123\",\r\n - \ \"2603:1040:a06:1::7e0/123\",\r\n \"2603:1040:d04::5c0/123\",\r\n - \ \"2603:1040:d04::7e0/123\",\r\n \"2603:1040:f05:1::5c0/123\",\r\n - \ \"2603:1040:f05:1::7e0/123\",\r\n \"2603:1050:6:1::5c0/123\",\r\n - \ \"2603:1050:6:1::7e0/123\",\r\n \"2603:1050:403::5c0/123\",\r\n - \ \"2a01:111:2050::/44\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureFrontDoor.FirstParty\",\r\n \"id\": \"AzureFrontDoor.FirstParty\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureFrontDoor\",\r\n \"addressPrefixes\": [\r\n \"13.107.3.0/24\",\r\n - \ \"13.107.4.0/22\",\r\n \"13.107.9.0/24\",\r\n \"13.107.12.0/23\",\r\n - \ \"13.107.15.0/24\",\r\n \"13.107.16.0/24\",\r\n \"13.107.18.0/23\",\r\n - \ \"13.107.21.0/24\",\r\n \"13.107.22.0/24\",\r\n \"13.107.37.0/24\",\r\n - \ \"13.107.38.0/23\",\r\n \"13.107.40.0/24\",\r\n \"13.107.42.0/23\",\r\n - \ \"13.107.48.0/24\",\r\n \"13.107.50.0/24\",\r\n \"13.107.52.0/24\",\r\n - \ \"13.107.54.0/24\",\r\n \"13.107.56.0/24\",\r\n \"13.107.64.0/18\",\r\n - \ \"13.107.128.0/19\",\r\n \"13.107.245.0/24\",\r\n \"13.107.254.0/23\",\r\n - \ \"131.253.3.0/24\",\r\n \"131.253.21.0/24\",\r\n \"131.253.33.0/24\",\r\n - \ \"150.171.32.0/19\",\r\n \"202.89.233.96/28\",\r\n \"204.79.197.0/24\",\r\n - \ \"2620:1ec:4::/46\",\r\n \"2620:1ec:a::/47\",\r\n \"2620:1ec:c::/47\",\r\n - \ \"2620:1ec:12::/47\",\r\n \"2620:1ec:21::/48\",\r\n \"2620:1ec:22::/48\",\r\n - \ \"2620:1ec:26::/63\",\r\n \"2620:1ec:26:2::/64\",\r\n \"2620:1ec:28::/48\",\r\n - \ \"2620:1ec:34::/48\",\r\n \"2620:1ec:39::/48\",\r\n \"2620:1ec:3e::/47\",\r\n - \ \"2620:1ec:42::/47\",\r\n \"2620:1ec:44::/47\",\r\n \"2620:1ec:8f0::/44\",\r\n - \ \"2620:1ec:900::/44\",\r\n \"2620:1ec:a92::/48\",\r\n \"2620:1ec:c11::/48\",\r\n - \ \"2a01:111:2003::/48\",\r\n \"2a01:111:202c::/46\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureFrontDoor.Frontend\",\r\n - \ \"id\": \"AzureFrontDoor.Frontend\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"\",\r\n \"addressPrefixes\": - [\r\n \"13.73.248.8/29\",\r\n \"13.107.208.0/24\",\r\n \"13.107.219.0/24\",\r\n - \ \"13.107.246.0/24\",\r\n \"13.107.253.0/24\",\r\n \"20.36.120.96/29\",\r\n - \ \"20.37.64.96/29\",\r\n \"20.37.156.112/29\",\r\n \"20.37.192.88/29\",\r\n - \ \"20.37.224.96/29\",\r\n \"20.38.84.64/29\",\r\n \"20.38.136.96/29\",\r\n - \ \"20.39.11.0/29\",\r\n \"20.41.4.80/29\",\r\n \"20.41.64.112/29\",\r\n - \ \"20.41.192.96/29\",\r\n \"20.42.4.112/29\",\r\n \"20.42.129.144/29\",\r\n - \ \"20.42.224.96/29\",\r\n \"20.43.41.128/29\",\r\n \"20.43.64.88/29\",\r\n - \ \"20.43.128.104/29\",\r\n \"20.45.112.96/29\",\r\n \"20.45.192.96/29\",\r\n - \ \"20.150.160.72/29\",\r\n \"20.189.106.72/29\",\r\n \"20.192.161.96/29\",\r\n - \ \"20.192.225.40/29\",\r\n \"40.67.48.96/29\",\r\n \"40.74.30.64/29\",\r\n - \ \"40.80.56.96/29\",\r\n \"40.80.168.96/29\",\r\n \"40.80.184.112/29\",\r\n - \ \"40.82.248.72/29\",\r\n \"40.89.16.96/29\",\r\n \"51.12.41.0/29\",\r\n - \ \"51.12.193.0/29\",\r\n \"51.104.24.88/29\",\r\n \"51.105.80.96/29\",\r\n - \ \"51.105.88.96/29\",\r\n \"51.107.48.96/29\",\r\n \"51.107.144.96/29\",\r\n - \ \"51.120.40.96/29\",\r\n \"51.120.224.96/29\",\r\n \"51.137.160.88/29\",\r\n - \ \"51.143.192.96/29\",\r\n \"52.136.48.96/29\",\r\n \"52.140.104.96/29\",\r\n - \ \"52.150.136.112/29\",\r\n \"52.228.80.112/29\",\r\n \"102.133.56.80/29\",\r\n - \ \"102.133.216.80/29\",\r\n \"191.233.9.112/29\",\r\n \"191.235.224.88/29\",\r\n - \ \"2603:1000:104::c0/123\",\r\n \"2603:1000:104::160/123\",\r\n - \ \"2603:1000:104:1::5a0/123\",\r\n \"2603:1000:104:1::7c0/123\",\r\n - \ \"2603:1010:6:1::5a0/123\",\r\n \"2603:1010:6:1::7c0/123\",\r\n - \ \"2603:1020:5:1::5a0/123\",\r\n \"2603:1020:5:1::7c0/123\",\r\n - \ \"2603:1020:206:1::5a0/123\",\r\n \"2603:1020:206:1::7c0/123\",\r\n - \ \"2603:1020:705:1::5a0/123\",\r\n \"2603:1020:705:1::7c0/123\",\r\n - \ \"2603:1020:805:1::5a0/123\",\r\n \"2603:1020:805:1::7c0/123\",\r\n - \ \"2603:1020:a04:1::5a0/123\",\r\n \"2603:1020:a04:1::7c0/123\",\r\n - \ \"2603:1020:c04:1::5a0/123\",\r\n \"2603:1020:c04:1::7c0/123\",\r\n - \ \"2603:1020:e04:1::5a0/123\",\r\n \"2603:1020:e04:1::7c0/123\",\r\n - \ \"2603:1020:1004::5a0/123\",\r\n \"2603:1020:1004::7c0/123\",\r\n - \ \"2603:1030:10:1::5a0/123\",\r\n \"2603:1030:10:1::7c0/123\",\r\n - \ \"2603:1030:104:1::5a0/123\",\r\n \"2603:1030:104:1::7c0/123\",\r\n - \ \"2603:1030:210:1::5a0/123\",\r\n \"2603:1030:210:1::7c0/123\",\r\n - \ \"2603:1030:40b:1::5a0/123\",\r\n \"2603:1030:40c:1::5a0/123\",\r\n - \ \"2603:1030:40c:1::7c0/123\",\r\n \"2603:1030:504:1::5a0/123\",\r\n - \ \"2603:1030:504:1::7c0/123\",\r\n \"2603:1030:807:1::5a0/123\",\r\n - \ \"2603:1030:807:1::7c0/123\",\r\n \"2603:1030:c06:1::5a0/123\",\r\n - \ \"2603:1030:f05:1::5a0/123\",\r\n \"2603:1030:f05:1::7c0/123\",\r\n - \ \"2603:1040:5::c0/123\",\r\n \"2603:1040:5:1::5a0/123\",\r\n - \ \"2603:1040:5:1::7c0/123\",\r\n \"2603:1040:407:1::5a0/123\",\r\n - \ \"2603:1040:407:1::7c0/123\",\r\n \"2603:1040:904:1::5a0/123\",\r\n - \ \"2603:1040:904:1::7c0/123\",\r\n \"2603:1040:a06::c0/123\",\r\n - \ \"2603:1040:a06:1::5a0/123\",\r\n \"2603:1040:a06:1::7c0/123\",\r\n - \ \"2603:1040:d04::5a0/123\",\r\n \"2603:1040:d04::7c0/123\",\r\n - \ \"2603:1040:f05:1::5a0/123\",\r\n \"2603:1040:f05:1::7c0/123\",\r\n - \ \"2603:1050:6:1::5a0/123\",\r\n \"2603:1050:6:1::7c0/123\",\r\n - \ \"2603:1050:403::5a0/123\",\r\n \"2620:1ec:29::/48\",\r\n - \ \"2620:1ec:40::/47\",\r\n \"2620:1ec:bdf::/48\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureInformationProtection\",\r\n - \ \"id\": \"AzureInformationProtection\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureInformationProtection\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.153.57/32\",\r\n \"13.66.245.220/32\",\r\n - \ \"13.66.251.171/32\",\r\n \"13.67.114.221/32\",\r\n \"13.68.179.152/32\",\r\n - \ \"13.76.139.8/32\",\r\n \"13.76.244.119/32\",\r\n \"13.77.166.40/32\",\r\n - \ \"13.77.203.47/32\",\r\n \"13.78.130.67/32\",\r\n \"13.78.130.185/32\",\r\n - \ \"13.78.178.191/32\",\r\n \"13.79.189.239/32\",\r\n \"13.79.189.241/32\",\r\n - \ \"13.82.198.231/32\",\r\n \"13.83.91.144/32\",\r\n \"13.92.58.123/32\",\r\n - \ \"13.92.61.93/32\",\r\n \"13.93.72.133/32\",\r\n \"13.93.75.214/32\",\r\n - \ \"13.94.98.184/32\",\r\n \"13.94.116.226/32\",\r\n \"23.97.70.206/32\",\r\n - \ \"23.99.106.184/32\",\r\n \"23.99.114.156/32\",\r\n \"23.99.251.107/32\",\r\n - \ \"23.101.112.34/32\",\r\n \"23.101.147.227/32\",\r\n \"23.101.163.169/32\",\r\n - \ \"40.69.191.65/32\",\r\n \"40.70.16.196/32\",\r\n \"40.76.94.49/32\",\r\n - \ \"40.83.177.47/32\",\r\n \"40.83.223.214/32\",\r\n \"40.87.2.166/32\",\r\n - \ \"40.87.67.213/32\",\r\n \"40.87.94.91/32\",\r\n \"40.114.2.72/32\",\r\n - \ \"40.117.180.9/32\",\r\n \"40.121.48.207/32\",\r\n \"40.121.49.153/32\",\r\n - \ \"40.121.90.82/32\",\r\n \"40.127.160.102/32\",\r\n \"40.127.175.173/32\",\r\n - \ \"51.136.18.12/32\",\r\n \"51.141.184.35/32\",\r\n \"51.143.32.47/32\",\r\n - \ \"51.143.88.135/32\",\r\n \"51.144.167.90/32\",\r\n \"51.145.146.97/32\",\r\n - \ \"52.162.33.18/32\",\r\n \"52.162.37.146/32\",\r\n \"52.162.88.200/32\",\r\n - \ \"52.162.95.132/32\",\r\n \"52.162.208.48/32\",\r\n \"52.163.61.51/32\",\r\n - \ \"52.163.85.21/32\",\r\n \"52.163.85.129/32\",\r\n \"52.163.87.92/32\",\r\n - \ \"52.163.89.155/32\",\r\n \"52.163.89.160/32\",\r\n \"52.165.189.139/32\",\r\n - \ \"52.167.1.118/32\",\r\n \"52.167.225.247/32\",\r\n \"52.167.226.2/32\",\r\n - \ \"52.167.227.104/32\",\r\n \"52.167.227.154/32\",\r\n \"52.173.21.111/32\",\r\n - \ \"52.173.89.54/32\",\r\n \"52.173.89.66/32\",\r\n \"52.173.93.137/32\",\r\n - \ \"52.176.44.178/32\",\r\n \"52.178.145.186/32\",\r\n \"52.178.147.96/32\",\r\n - \ \"52.179.136.129/32\",\r\n \"52.184.34.233/32\",\r\n \"52.184.35.49/32\",\r\n - \ \"52.232.110.114/32\",\r\n \"52.232.113.160/32\",\r\n \"52.232.118.97/32\",\r\n - \ \"52.232.119.81/32\",\r\n \"52.237.141.83/32\",\r\n \"52.237.141.229/32\",\r\n - \ \"52.250.56.125/32\",\r\n \"65.52.36.85/32\",\r\n \"65.52.55.108/32\",\r\n - \ \"65.52.176.250/32\",\r\n \"65.52.177.192/32\",\r\n \"65.52.184.44/32\",\r\n - \ \"65.52.184.218/32\",\r\n \"65.52.236.123/32\",\r\n \"70.37.163.131/32\",\r\n - \ \"94.245.88.160/32\",\r\n \"104.40.16.135/32\",\r\n \"104.40.30.29/32\",\r\n - \ \"104.41.143.145/32\",\r\n \"137.116.91.123/32\",\r\n \"137.117.47.75/32\",\r\n - \ \"138.91.121.248/32\",\r\n \"138.91.122.178/32\",\r\n \"157.55.177.248/32\",\r\n - \ \"157.55.185.205/32\",\r\n \"157.56.8.93/32\",\r\n \"157.56.8.135/32\",\r\n - \ \"157.56.9.127/32\",\r\n \"168.61.46.212/32\",\r\n \"168.62.5.167/32\",\r\n - \ \"168.62.8.139/32\",\r\n \"168.62.25.173/32\",\r\n \"168.62.25.179/32\",\r\n - \ \"168.62.48.148/32\",\r\n \"168.62.49.18/32\",\r\n \"168.62.52.244/32\",\r\n - \ \"168.62.53.73/32\",\r\n \"168.62.53.132/32\",\r\n \"168.62.54.75/32\",\r\n - \ \"168.62.54.211/32\",\r\n \"168.62.54.212/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureInformationProtection.NorthCentralUS\",\r\n - \ \"id\": \"AzureInformationProtection.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureInformationProtection\",\r\n - \ \"addressPrefixes\": [\r\n \"23.101.163.169/32\",\r\n \"52.162.33.18/32\",\r\n - \ \"52.162.37.146/32\",\r\n \"52.162.88.200/32\",\r\n \"52.162.95.132/32\",\r\n - \ \"52.162.208.48/32\",\r\n \"52.237.141.83/32\",\r\n \"52.237.141.229/32\",\r\n - \ \"65.52.55.108/32\",\r\n \"65.52.236.123/32\",\r\n \"157.56.8.93/32\",\r\n - \ \"157.56.8.135/32\",\r\n \"157.56.9.127/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureInformationProtection.WestEurope\",\r\n - \ \"id\": \"AzureInformationProtection.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureInformationProtection\",\r\n - \ \"addressPrefixes\": [\r\n \"13.93.72.133/32\",\r\n \"13.93.75.214/32\",\r\n - \ \"51.136.18.12/32\",\r\n \"51.144.167.90/32\",\r\n \"51.145.146.97/32\",\r\n - \ \"52.232.110.114/32\",\r\n \"52.232.113.160/32\",\r\n \"52.232.118.97/32\",\r\n - \ \"52.232.119.81/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureInformationProtection.WestUS2\",\r\n \"id\": \"AzureInformationProtection.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureInformationProtection\",\r\n \"addressPrefixes\": [\r\n \"13.66.153.57/32\",\r\n - \ \"13.66.245.220/32\",\r\n \"13.66.251.171/32\",\r\n \"13.77.166.40/32\",\r\n - \ \"51.141.184.35/32\",\r\n \"51.143.32.47/32\",\r\n \"51.143.88.135/32\",\r\n - \ \"52.250.56.125/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub\",\r\n \"id\": \"AzureIoTHub\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.142.96/27\",\r\n \"13.67.10.224/27\",\r\n - \ \"13.67.234.22/32\",\r\n \"13.69.71.0/25\",\r\n \"13.69.109.0/25\",\r\n - \ \"13.69.192.43/32\",\r\n \"13.69.230.64/27\",\r\n \"13.70.74.192/27\",\r\n - \ \"13.70.182.204/32\",\r\n \"13.70.182.210/32\",\r\n \"13.71.84.34/32\",\r\n - \ \"13.71.113.127/32\",\r\n \"13.71.150.19/32\",\r\n \"13.71.175.32/27\",\r\n - \ \"13.71.196.224/27\",\r\n \"13.73.115.51/32\",\r\n \"13.73.244.0/27\",\r\n - \ \"13.73.252.128/25\",\r\n \"13.74.108.192/27\",\r\n \"13.75.39.160/27\",\r\n - \ \"13.76.83.155/32\",\r\n \"13.76.217.46/32\",\r\n \"13.77.53.128/27\",\r\n - \ \"13.78.109.160/27\",\r\n \"13.78.129.154/32\",\r\n \"13.78.130.69/32\",\r\n - \ \"13.79.172.43/32\",\r\n \"13.82.93.138/32\",\r\n \"13.84.189.6/32\",\r\n - \ \"13.85.68.113/32\",\r\n \"13.86.221.0/25\",\r\n \"13.87.58.96/27\",\r\n - \ \"13.87.124.96/27\",\r\n \"13.89.174.160/27\",\r\n \"13.89.231.149/32\",\r\n - \ \"13.94.40.72/32\",\r\n \"13.95.15.251/32\",\r\n \"20.36.108.160/27\",\r\n - \ \"20.36.117.64/27\",\r\n \"20.36.123.32/27\",\r\n \"20.36.123.128/25\",\r\n - \ \"20.37.67.128/25\",\r\n \"20.37.68.0/27\",\r\n \"20.37.76.160/27\",\r\n - \ \"20.37.198.160/27\",\r\n \"20.37.199.0/25\",\r\n \"20.37.227.64/27\",\r\n - \ \"20.37.227.128/25\",\r\n \"20.38.128.128/27\",\r\n \"20.38.139.128/25\",\r\n - \ \"20.38.140.0/27\",\r\n \"20.38.147.192/27\",\r\n \"20.39.14.32/27\",\r\n - \ \"20.39.14.128/25\",\r\n \"20.40.206.192/27\",\r\n \"20.40.207.0/25\",\r\n - \ \"20.41.68.96/27\",\r\n \"20.41.68.128/25\",\r\n \"20.41.197.64/27\",\r\n - \ \"20.41.197.128/25\",\r\n \"20.42.230.160/27\",\r\n \"20.42.231.0/25\",\r\n - \ \"20.43.44.160/27\",\r\n \"20.43.45.0/25\",\r\n \"20.43.70.160/27\",\r\n - \ \"20.43.71.0/25\",\r\n \"20.43.121.64/27\",\r\n \"20.44.4.128/27\",\r\n - \ \"20.44.8.224/27\",\r\n \"20.44.17.96/27\",\r\n \"20.44.29.0/27\",\r\n - \ \"20.45.114.224/27\",\r\n \"20.45.115.0/25\",\r\n \"20.45.123.128/27\",\r\n - \ \"20.45.198.32/27\",\r\n \"20.45.198.128/25\",\r\n \"20.49.83.128/27\",\r\n - \ \"20.49.91.128/27\",\r\n \"20.49.99.96/27\",\r\n \"20.49.99.128/25\",\r\n - \ \"20.49.109.128/25\",\r\n \"20.49.110.0/26\",\r\n \"20.49.110.128/25\",\r\n - \ \"20.49.113.32/27\",\r\n \"20.49.113.128/25\",\r\n \"20.49.120.96/27\",\r\n - \ \"20.49.120.128/25\",\r\n \"20.49.121.0/25\",\r\n \"20.50.65.128/25\",\r\n - \ \"20.50.68.0/27\",\r\n \"20.150.165.192/27\",\r\n \"20.150.166.0/25\",\r\n - \ \"20.150.172.192/27\",\r\n \"20.150.179.224/27\",\r\n \"20.150.187.224/27\",\r\n - \ \"20.187.195.0/25\",\r\n \"20.188.0.51/32\",\r\n \"20.188.3.145/32\",\r\n - \ \"20.188.39.126/32\",\r\n \"20.189.109.192/27\",\r\n \"20.192.99.224/27\",\r\n - \ \"20.192.165.224/27\",\r\n \"20.192.166.0/25\",\r\n \"20.192.230.32/27\",\r\n - \ \"20.192.230.128/25\",\r\n \"20.192.238.0/27\",\r\n \"20.193.206.0/27\",\r\n - \ \"20.194.67.96/27\",\r\n \"23.96.222.45/32\",\r\n \"23.96.223.89/32\",\r\n - \ \"23.98.86.0/27\",\r\n \"23.98.104.192/27\",\r\n \"23.98.106.0/25\",\r\n - \ \"23.99.109.81/32\",\r\n \"23.100.4.253/32\",\r\n \"23.100.8.130/32\",\r\n - \ \"23.100.105.192/32\",\r\n \"23.101.29.228/32\",\r\n \"23.102.235.31/32\",\r\n - \ \"40.64.132.160/27\",\r\n \"40.64.134.0/25\",\r\n \"40.67.51.0/25\",\r\n - \ \"40.67.51.128/27\",\r\n \"40.67.60.128/27\",\r\n \"40.69.108.128/27\",\r\n - \ \"40.70.148.128/27\",\r\n \"40.71.14.128/25\",\r\n \"40.74.66.139/32\",\r\n - \ \"40.74.125.44/32\",\r\n \"40.74.149.0/27\",\r\n \"40.75.35.96/27\",\r\n - \ \"40.76.71.185/32\",\r\n \"40.77.23.107/32\",\r\n \"40.78.22.17/32\",\r\n - \ \"40.78.196.96/27\",\r\n \"40.78.204.64/27\",\r\n \"40.78.229.128/25\",\r\n - \ \"40.78.238.0/27\",\r\n \"40.78.245.32/27\",\r\n \"40.78.251.160/27\",\r\n - \ \"40.79.114.144/32\",\r\n \"40.79.132.128/27\",\r\n \"40.79.139.32/27\",\r\n - \ \"40.79.148.0/27\",\r\n \"40.79.156.128/25\",\r\n \"40.79.163.32/27\",\r\n - \ \"40.79.171.128/27\",\r\n \"40.79.180.96/27\",\r\n \"40.79.187.224/27\",\r\n - \ \"40.79.195.192/27\",\r\n \"40.80.51.128/27\",\r\n \"40.80.62.64/27\",\r\n - \ \"40.80.62.128/25\",\r\n \"40.80.172.64/27\",\r\n \"40.80.172.128/25\",\r\n - \ \"40.80.176.64/27\",\r\n \"40.83.177.42/32\",\r\n \"40.84.53.157/32\",\r\n - \ \"40.87.138.172/32\",\r\n \"40.87.143.97/32\",\r\n \"40.89.20.192/27\",\r\n - \ \"40.89.21.0/25\",\r\n \"40.112.221.188/32\",\r\n \"40.112.223.235/32\",\r\n - \ \"40.113.153.50/32\",\r\n \"40.113.176.160/27\",\r\n \"40.113.176.192/27\",\r\n - \ \"40.113.177.0/24\",\r\n \"40.114.53.146/32\",\r\n \"40.118.27.192/32\",\r\n - \ \"40.119.11.224/27\",\r\n \"40.120.75.160/27\",\r\n \"40.127.132.17/32\",\r\n - \ \"51.12.42.32/27\",\r\n \"51.12.42.128/25\",\r\n \"51.12.100.64/27\",\r\n - \ \"51.12.194.32/27\",\r\n \"51.12.194.128/25\",\r\n \"51.12.204.64/27\",\r\n - \ \"51.12.227.224/27\",\r\n \"51.12.235.224/27\",\r\n \"51.104.30.0/25\",\r\n - \ \"51.104.30.128/27\",\r\n \"51.105.69.0/27\",\r\n \"51.105.75.192/27\",\r\n - \ \"51.105.91.128/25\",\r\n \"51.105.92.0/27\",\r\n \"51.107.51.64/27\",\r\n - \ \"51.107.51.128/25\",\r\n \"51.107.60.96/27\",\r\n \"51.107.147.64/27\",\r\n - \ \"51.107.147.128/25\",\r\n \"51.107.156.96/27\",\r\n \"51.116.49.224/27\",\r\n - \ \"51.116.50.0/25\",\r\n \"51.116.60.96/27\",\r\n \"51.116.145.192/27\",\r\n - \ \"51.116.146.0/25\",\r\n \"51.116.158.0/27\",\r\n \"51.116.243.160/27\",\r\n - \ \"51.116.251.128/27\",\r\n \"51.120.43.128/25\",\r\n \"51.120.44.0/27\",\r\n - \ \"51.120.100.96/27\",\r\n \"51.120.107.224/27\",\r\n \"51.120.211.224/27\",\r\n - \ \"51.120.227.128/25\",\r\n \"51.120.228.0/27\",\r\n \"51.137.164.160/27\",\r\n - \ \"51.137.165.0/25\",\r\n \"51.140.84.251/32\",\r\n \"51.140.126.10/32\",\r\n - \ \"51.140.149.32/27\",\r\n \"51.140.212.160/27\",\r\n \"51.140.226.207/32\",\r\n - \ \"51.140.240.234/32\",\r\n \"51.141.49.253/32\",\r\n \"51.144.118.31/32\",\r\n - \ \"52.136.51.128/25\",\r\n \"52.136.52.0/27\",\r\n \"52.136.132.236/32\",\r\n - \ \"52.138.92.96/27\",\r\n \"52.138.229.0/27\",\r\n \"52.140.108.160/27\",\r\n - \ \"52.140.109.0/25\",\r\n \"52.147.10.141/32\",\r\n \"52.147.10.149/32\",\r\n - \ \"52.150.152.96/27\",\r\n \"52.150.153.128/25\",\r\n \"52.151.6.77/32\",\r\n - \ \"52.151.78.51/32\",\r\n \"52.158.236.252/32\",\r\n \"52.161.15.247/32\",\r\n - \ \"52.162.111.64/27\",\r\n \"52.163.212.39/32\",\r\n \"52.163.215.122/32\",\r\n - \ \"52.167.107.192/27\",\r\n \"52.167.155.89/32\",\r\n \"52.168.180.95/32\",\r\n - \ \"52.169.138.222/32\",\r\n \"52.172.203.144/32\",\r\n \"52.175.221.106/32\",\r\n - \ \"52.176.4.4/32\",\r\n \"52.176.92.27/32\",\r\n \"52.177.196.50/32\",\r\n - \ \"52.178.147.144/32\",\r\n \"52.179.159.231/32\",\r\n \"52.180.165.88/32\",\r\n - \ \"52.180.165.248/32\",\r\n \"52.180.177.125/32\",\r\n \"52.182.139.224/27\",\r\n - \ \"52.225.176.167/32\",\r\n \"52.225.177.25/32\",\r\n \"52.225.179.220/32\",\r\n - \ \"52.225.180.26/32\",\r\n \"52.225.180.217/32\",\r\n \"52.225.187.149/32\",\r\n - \ \"52.228.85.224/27\",\r\n \"52.228.86.0/25\",\r\n \"52.231.20.32/27\",\r\n - \ \"52.231.32.236/32\",\r\n \"52.231.148.128/27\",\r\n \"52.231.205.15/32\",\r\n - \ \"52.236.189.128/25\",\r\n \"52.237.27.123/32\",\r\n \"52.242.31.77/32\",\r\n - \ \"52.246.155.192/27\",\r\n \"52.250.225.32/27\",\r\n \"65.52.252.160/27\",\r\n - \ \"102.133.28.160/27\",\r\n \"102.133.59.0/25\",\r\n \"102.133.59.128/27\",\r\n - \ \"102.133.124.32/27\",\r\n \"102.133.156.64/27\",\r\n \"102.133.218.192/27\",\r\n - \ \"102.133.219.0/25\",\r\n \"102.133.251.128/27\",\r\n \"104.40.49.44/32\",\r\n - \ \"104.41.34.180/32\",\r\n \"104.43.252.98/32\",\r\n \"104.46.115.237/32\",\r\n - \ \"104.210.105.7/32\",\r\n \"104.211.210.195/32\",\r\n \"104.214.34.123/32\",\r\n - \ \"137.117.83.38/32\",\r\n \"168.61.54.255/32\",\r\n \"168.61.208.218/32\",\r\n - \ \"191.233.11.160/27\",\r\n \"191.233.14.0/25\",\r\n \"191.233.54.0/27\",\r\n - \ \"191.233.205.128/27\",\r\n \"191.234.136.128/25\",\r\n - \ \"191.234.137.0/27\",\r\n \"191.234.147.224/27\",\r\n \"191.234.155.224/27\",\r\n - \ \"207.46.138.102/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.AustraliaCentral\",\r\n \"id\": \"AzureIoTHub.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.108.160/27\",\r\n \"20.37.227.64/27\",\r\n - \ \"20.37.227.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.AustraliaCentral2\",\r\n \"id\": \"AzureIoTHub.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.117.64/27\",\r\n \"20.36.123.32/27\",\r\n - \ \"20.36.123.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.AustraliaEast\",\r\n \"id\": \"AzureIoTHub.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.74.192/27\",\r\n \"20.37.198.160/27\",\r\n - \ \"20.37.199.0/25\",\r\n \"40.79.163.32/27\",\r\n \"40.79.171.128/27\",\r\n - \ \"52.147.10.141/32\",\r\n \"52.147.10.149/32\",\r\n \"104.210.105.7/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureIoTHub.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"13.70.182.204/32\",\r\n \"13.70.182.210/32\",\r\n - \ \"13.73.115.51/32\",\r\n \"13.77.53.128/27\",\r\n \"20.42.230.160/27\",\r\n - \ \"20.42.231.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.BrazilSouth\",\r\n \"id\": \"AzureIoTHub.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"104.41.34.180/32\",\r\n \"191.233.205.128/27\",\r\n - \ \"191.234.136.128/25\",\r\n \"191.234.137.0/27\",\r\n \"191.234.147.224/27\",\r\n - \ \"191.234.155.224/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.CanadaCentral\",\r\n \"id\": \"AzureIoTHub.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.175.32/27\",\r\n \"20.38.147.192/27\",\r\n - \ \"52.228.85.224/27\",\r\n \"52.228.86.0/25\",\r\n \"52.237.27.123/32\",\r\n - \ \"52.246.155.192/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.CanadaEast\",\r\n \"id\": \"AzureIoTHub.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.108.128/27\",\r\n \"40.89.20.192/27\",\r\n - \ \"40.89.21.0/25\",\r\n \"52.242.31.77/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.CentralIndia\",\r\n - \ \"id\": \"AzureIoTHub.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"20.43.121.64/27\",\r\n \"20.192.99.224/27\",\r\n - \ \"40.80.51.128/27\",\r\n \"52.140.108.160/27\",\r\n \"52.140.109.0/25\",\r\n - \ \"52.172.203.144/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.CentralUS\",\r\n \"id\": \"AzureIoTHub.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.234.22/32\",\r\n \"13.89.174.160/27\",\r\n - \ \"13.89.231.149/32\",\r\n \"20.40.206.192/27\",\r\n \"20.40.207.0/25\",\r\n - \ \"20.44.8.224/27\",\r\n \"40.77.23.107/32\",\r\n \"52.176.4.4/32\",\r\n - \ \"52.176.92.27/32\",\r\n \"52.182.139.224/27\",\r\n \"104.43.252.98/32\",\r\n - \ \"168.61.208.218/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.CentralUSEUAP\",\r\n \"id\": \"AzureIoTHub.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.198.32/27\",\r\n \"20.45.198.128/25\",\r\n - \ \"40.78.204.64/27\",\r\n \"52.180.165.88/32\",\r\n \"52.180.165.248/32\",\r\n - \ \"52.180.177.125/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.EastAsia\",\r\n \"id\": \"AzureIoTHub.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.39.160/27\",\r\n \"13.94.40.72/32\",\r\n - \ \"20.187.195.0/25\",\r\n \"20.189.109.192/27\",\r\n \"23.99.109.81/32\",\r\n - \ \"23.102.235.31/32\",\r\n \"207.46.138.102/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS\",\r\n - \ \"id\": \"AzureIoTHub.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.82.93.138/32\",\r\n - \ \"20.49.109.128/25\",\r\n \"20.49.110.0/26\",\r\n \"20.49.110.128/25\",\r\n - \ \"40.71.14.128/25\",\r\n \"40.76.71.185/32\",\r\n \"40.78.229.128/25\",\r\n - \ \"40.79.156.128/25\",\r\n \"40.114.53.146/32\",\r\n \"52.168.180.95/32\",\r\n - \ \"137.117.83.38/32\",\r\n \"168.61.54.255/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS2\",\r\n - \ \"id\": \"AzureIoTHub.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"20.44.17.96/27\",\r\n - \ \"20.49.99.96/27\",\r\n \"20.49.99.128/25\",\r\n \"40.70.148.128/27\",\r\n - \ \"40.84.53.157/32\",\r\n \"52.167.107.192/27\",\r\n \"52.167.155.89/32\",\r\n - \ \"52.177.196.50/32\",\r\n \"52.179.159.231/32\",\r\n \"104.46.115.237/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS2EUAP\",\r\n - \ \"id\": \"AzureIoTHub.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"20.39.14.32/27\",\r\n \"20.39.14.128/25\",\r\n \"40.74.149.0/27\",\r\n - \ \"40.75.35.96/27\",\r\n \"40.79.114.144/32\",\r\n \"52.138.92.96/27\",\r\n - \ \"52.225.176.167/32\",\r\n \"52.225.177.25/32\",\r\n \"52.225.179.220/32\",\r\n - \ \"52.225.180.26/32\",\r\n \"52.225.180.217/32\",\r\n \"52.225.187.149/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.FranceCentral\",\r\n - \ \"id\": \"AzureIoTHub.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"20.43.44.160/27\",\r\n \"20.43.45.0/25\",\r\n \"20.188.39.126/32\",\r\n - \ \"40.79.132.128/27\",\r\n \"40.79.139.32/27\",\r\n \"40.79.148.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.FranceSouth\",\r\n - \ \"id\": \"AzureIoTHub.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"40.79.180.96/27\",\r\n \"51.105.91.128/25\",\r\n - \ \"51.105.92.0/27\",\r\n \"52.136.132.236/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.GermanyNorth\",\r\n - \ \"id\": \"AzureIoTHub.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"51.116.49.224/27\",\r\n \"51.116.50.0/25\",\r\n - \ \"51.116.60.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.GermanyWestCentral\",\r\n \"id\": \"AzureIoTHub.GermanyWestCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.145.192/27\",\r\n \"51.116.146.0/25\",\r\n - \ \"51.116.158.0/27\",\r\n \"51.116.243.160/27\",\r\n \"51.116.251.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.JapanEast\",\r\n - \ \"id\": \"AzureIoTHub.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.150.19/32\",\r\n - \ \"13.78.109.160/27\",\r\n \"20.43.70.160/27\",\r\n \"20.43.71.0/25\",\r\n - \ \"20.188.0.51/32\",\r\n \"20.188.3.145/32\",\r\n \"40.79.187.224/27\",\r\n - \ \"40.79.195.192/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.JapanWest\",\r\n \"id\": \"AzureIoTHub.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"23.100.105.192/32\",\r\n \"40.74.66.139/32\",\r\n - \ \"40.74.125.44/32\",\r\n \"40.80.62.64/27\",\r\n \"40.80.62.128/25\",\r\n - \ \"40.80.176.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.KoreaCentral\",\r\n \"id\": \"AzureIoTHub.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.68.96/27\",\r\n \"20.41.68.128/25\",\r\n - \ \"20.44.29.0/27\",\r\n \"20.194.67.96/27\",\r\n \"52.231.20.32/27\",\r\n - \ \"52.231.32.236/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.KoreaSouth\",\r\n \"id\": \"AzureIoTHub.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.172.64/27\",\r\n \"40.80.172.128/25\",\r\n - \ \"52.231.148.128/27\",\r\n \"52.231.205.15/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorthCentralUS\",\r\n - \ \"id\": \"AzureIoTHub.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"20.49.113.32/27\",\r\n \"20.49.113.128/25\",\r\n - \ \"23.96.222.45/32\",\r\n \"23.96.223.89/32\",\r\n \"52.162.111.64/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorthEurope\",\r\n - \ \"id\": \"AzureIoTHub.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"13.69.192.43/32\",\r\n \"13.69.230.64/27\",\r\n - \ \"13.74.108.192/27\",\r\n \"13.79.172.43/32\",\r\n \"20.50.65.128/25\",\r\n - \ \"20.50.68.0/27\",\r\n \"40.87.138.172/32\",\r\n \"40.87.143.97/32\",\r\n - \ \"40.127.132.17/32\",\r\n \"52.138.229.0/27\",\r\n \"52.169.138.222/32\",\r\n - \ \"52.178.147.144/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.NorwayEast\",\r\n \"id\": \"AzureIoTHub.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.43.128/25\",\r\n \"51.120.44.0/27\",\r\n - \ \"51.120.100.96/27\",\r\n \"51.120.107.224/27\",\r\n \"51.120.211.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorwayWest\",\r\n - \ \"id\": \"AzureIoTHub.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"51.120.227.128/25\",\r\n - \ \"51.120.228.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.SouthAfricaNorth\",\r\n \"id\": \"AzureIoTHub.SouthAfricaNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.124.32/27\",\r\n \"102.133.156.64/27\",\r\n - \ \"102.133.218.192/27\",\r\n \"102.133.219.0/25\",\r\n \"102.133.251.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.SouthAfricaWest\",\r\n - \ \"id\": \"AzureIoTHub.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"102.133.28.160/27\",\r\n \"102.133.59.0/25\",\r\n - \ \"102.133.59.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.SouthCentralUS\",\r\n \"id\": \"AzureIoTHub.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.244.0/27\",\r\n \"13.73.252.128/25\",\r\n - \ \"13.84.189.6/32\",\r\n \"13.85.68.113/32\",\r\n \"20.45.123.128/27\",\r\n - \ \"20.49.91.128/27\",\r\n \"40.119.11.224/27\",\r\n \"104.214.34.123/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.SoutheastAsia\",\r\n - \ \"id\": \"AzureIoTHub.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"13.67.10.224/27\",\r\n \"13.76.83.155/32\",\r\n - \ \"13.76.217.46/32\",\r\n \"23.98.86.0/27\",\r\n \"23.98.104.192/27\",\r\n - \ \"23.98.106.0/25\",\r\n \"23.101.29.228/32\",\r\n \"40.78.238.0/27\",\r\n - \ \"52.163.212.39/32\",\r\n \"52.163.215.122/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.SouthIndia\",\r\n - \ \"id\": \"AzureIoTHub.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.84.34/32\",\r\n - \ \"13.71.113.127/32\",\r\n \"20.41.197.64/27\",\r\n \"20.41.197.128/25\",\r\n - \ \"40.78.196.96/27\",\r\n \"104.211.210.195/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureIoTHub.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"51.107.51.64/27\",\r\n \"51.107.51.128/25\",\r\n - \ \"51.107.60.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.SwitzerlandWest\",\r\n \"id\": \"AzureIoTHub.SwitzerlandWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.147.64/27\",\r\n \"51.107.147.128/25\",\r\n - \ \"51.107.156.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.UAECentral\",\r\n \"id\": \"AzureIoTHub.UAECentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.67.128/25\",\r\n \"20.37.68.0/27\",\r\n - \ \"20.37.76.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.UAENorth\",\r\n \"id\": \"AzureIoTHub.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.139.128/25\",\r\n \"20.38.140.0/27\",\r\n - \ \"40.120.75.160/27\",\r\n \"65.52.252.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKNorth\",\r\n - \ \"id\": \"AzureIoTHub.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.87.124.96/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKSouth\",\r\n - \ \"id\": \"AzureIoTHub.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"51.104.30.0/25\",\r\n - \ \"51.104.30.128/27\",\r\n \"51.105.69.0/27\",\r\n \"51.105.75.192/27\",\r\n - \ \"51.140.84.251/32\",\r\n \"51.140.126.10/32\",\r\n \"51.140.149.32/27\",\r\n - \ \"52.151.78.51/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.UKSouth2\",\r\n \"id\": \"AzureIoTHub.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.58.96/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKWest\",\r\n - \ \"id\": \"AzureIoTHub.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"51.137.164.160/27\",\r\n - \ \"51.137.165.0/25\",\r\n \"51.140.212.160/27\",\r\n \"51.140.226.207/32\",\r\n - \ \"51.140.240.234/32\",\r\n \"51.141.49.253/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestCentralUS\",\r\n - \ \"id\": \"AzureIoTHub.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": - [\r\n \"13.71.196.224/27\",\r\n \"13.78.129.154/32\",\r\n - \ \"13.78.130.69/32\",\r\n \"52.150.152.96/27\",\r\n \"52.150.153.128/25\",\r\n - \ \"52.161.15.247/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.WestEurope\",\r\n \"id\": \"AzureIoTHub.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.71.0/25\",\r\n \"13.69.109.0/25\",\r\n - \ \"13.95.15.251/32\",\r\n \"23.100.4.253/32\",\r\n \"23.100.8.130/32\",\r\n - \ \"40.113.153.50/32\",\r\n \"40.113.176.160/27\",\r\n \"40.113.176.192/27\",\r\n - \ \"40.113.177.0/24\",\r\n \"40.118.27.192/32\",\r\n \"51.144.118.31/32\",\r\n - \ \"52.236.189.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.WestIndia\",\r\n \"id\": \"AzureIoTHub.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.128.128/27\",\r\n \"52.136.51.128/25\",\r\n - \ \"52.136.52.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureIoTHub.WestUS\",\r\n \"id\": \"AzureIoTHub.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.221.0/25\",\r\n \"20.49.120.96/27\",\r\n - \ \"20.49.120.128/25\",\r\n \"20.49.121.0/25\",\r\n \"40.78.22.17/32\",\r\n - \ \"40.83.177.42/32\",\r\n \"40.112.221.188/32\",\r\n \"40.112.223.235/32\",\r\n - \ \"52.250.225.32/27\",\r\n \"104.40.49.44/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestUS2\",\r\n - \ \"id\": \"AzureIoTHub.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.66.142.96/27\",\r\n - \ \"40.64.132.160/27\",\r\n \"40.64.134.0/25\",\r\n \"40.78.245.32/27\",\r\n - \ \"40.78.251.160/27\",\r\n \"52.151.6.77/32\",\r\n \"52.158.236.252/32\",\r\n - \ \"52.175.221.106/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault\",\r\n \"id\": \"AzureKeyVault\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.88/30\",\r\n \"13.66.226.249/32\",\r\n - \ \"13.66.230.241/32\",\r\n \"13.67.8.104/30\",\r\n \"13.68.24.216/32\",\r\n - \ \"13.68.29.203/32\",\r\n \"13.68.104.240/32\",\r\n \"13.69.64.72/30\",\r\n - \ \"13.69.227.72/30\",\r\n \"13.70.72.24/30\",\r\n \"13.70.138.129/32\",\r\n - \ \"13.71.170.40/30\",\r\n \"13.71.194.112/30\",\r\n \"13.72.250.239/32\",\r\n - \ \"13.74.10.39/32\",\r\n \"13.74.10.113/32\",\r\n \"13.75.34.144/30\",\r\n - \ \"13.77.50.64/30\",\r\n \"13.78.106.88/30\",\r\n \"13.80.247.19/32\",\r\n - \ \"13.80.247.42/32\",\r\n \"13.84.174.143/32\",\r\n \"13.87.34.51/32\",\r\n - \ \"13.87.39.0/32\",\r\n \"13.87.56.80/30\",\r\n \"13.87.101.60/32\",\r\n - \ \"13.87.101.111/32\",\r\n \"13.87.122.80/30\",\r\n \"13.89.61.248/32\",\r\n - \ \"13.89.170.200/30\",\r\n \"20.36.40.39/32\",\r\n \"20.36.40.42/32\",\r\n - \ \"20.36.72.34/32\",\r\n \"20.36.72.38/32\",\r\n \"20.36.106.64/30\",\r\n - \ \"20.36.114.16/30\",\r\n \"20.37.74.228/30\",\r\n \"20.43.56.38/32\",\r\n - \ \"20.43.56.66/32\",\r\n \"20.44.2.0/30\",\r\n \"20.45.123.240/30\",\r\n - \ \"20.49.82.0/30\",\r\n \"20.49.90.0/30\",\r\n \"20.150.170.0/30\",\r\n - \ \"20.150.181.28/30\",\r\n \"20.185.217.251/32\",\r\n \"20.185.218.1/32\",\r\n - \ \"20.186.41.83/32\",\r\n \"20.186.47.182/32\",\r\n \"20.188.2.148/32\",\r\n - \ \"20.188.2.156/32\",\r\n \"20.188.40.44/32\",\r\n \"20.188.40.46/32\",\r\n - \ \"20.192.234.0/30\",\r\n \"20.193.202.0/30\",\r\n \"20.194.66.0/30\",\r\n - \ \"23.96.210.207/32\",\r\n \"23.96.250.48/32\",\r\n \"23.97.50.43/32\",\r\n - \ \"23.97.178.0/32\",\r\n \"23.99.132.207/32\",\r\n \"23.100.57.24/32\",\r\n - \ \"23.100.58.149/32\",\r\n \"23.101.21.103/32\",\r\n \"23.101.21.193/32\",\r\n - \ \"23.101.23.190/32\",\r\n \"23.101.23.192/32\",\r\n \"23.102.72.114/32\",\r\n - \ \"23.102.75.18/32\",\r\n \"40.65.188.244/32\",\r\n \"40.65.189.219/32\",\r\n - \ \"40.67.58.0/30\",\r\n \"40.69.106.64/30\",\r\n \"40.70.146.72/30\",\r\n - \ \"40.70.204.6/32\",\r\n \"40.70.204.32/32\",\r\n \"40.71.10.200/30\",\r\n - \ \"40.74.100.48/30\",\r\n \"40.76.196.75/32\",\r\n \"40.76.212.37/32\",\r\n - \ \"40.78.194.64/30\",\r\n \"40.79.118.1/32\",\r\n \"40.79.118.5/32\",\r\n - \ \"40.79.130.40/30\",\r\n \"40.79.163.156/30\",\r\n \"40.79.178.64/30\",\r\n - \ \"40.85.185.208/32\",\r\n \"40.85.229.9/32\",\r\n \"40.85.231.231/32\",\r\n - \ \"40.86.224.94/32\",\r\n \"40.86.231.180/32\",\r\n \"40.87.69.184/32\",\r\n - \ \"40.89.145.89/32\",\r\n \"40.89.145.93/32\",\r\n \"40.89.180.10/32\",\r\n - \ \"40.89.180.25/32\",\r\n \"40.91.193.78/32\",\r\n \"40.91.199.213/32\",\r\n - \ \"40.112.242.144/30\",\r\n \"40.117.157.122/32\",\r\n \"40.120.74.0/30\",\r\n - \ \"51.12.98.0/30\",\r\n \"51.12.202.0/30\",\r\n \"51.104.192.129/32\",\r\n - \ \"51.104.192.138/32\",\r\n \"51.105.4.67/32\",\r\n \"51.105.4.75/32\",\r\n - \ \"51.107.58.0/30\",\r\n \"51.107.154.0/30\",\r\n \"51.116.58.0/30\",\r\n - \ \"51.116.154.64/30\",\r\n \"51.116.243.220/30\",\r\n \"51.116.251.188/30\",\r\n - \ \"51.120.98.8/30\",\r\n \"51.120.218.0/30\",\r\n \"51.140.146.56/30\",\r\n - \ \"51.140.157.60/32\",\r\n \"51.140.184.38/31\",\r\n \"51.140.210.80/30\",\r\n - \ \"51.141.8.42/31\",\r\n \"51.143.6.21/32\",\r\n \"52.136.136.15/32\",\r\n - \ \"52.136.136.16/32\",\r\n \"52.138.73.5/32\",\r\n \"52.138.73.51/32\",\r\n - \ \"52.138.160.103/32\",\r\n \"52.138.160.105/32\",\r\n \"52.148.84.142/32\",\r\n - \ \"52.148.84.145/32\",\r\n \"52.151.41.92/32\",\r\n \"52.151.47.4/32\",\r\n - \ \"52.151.75.86/32\",\r\n \"52.154.176.47/32\",\r\n \"52.154.177.179/32\",\r\n - \ \"52.157.162.137/32\",\r\n \"52.157.162.147/32\",\r\n \"52.158.236.253/32\",\r\n - \ \"52.158.239.35/32\",\r\n \"52.161.25.42/32\",\r\n \"52.161.31.136/32\",\r\n - \ \"52.161.31.139/32\",\r\n \"52.162.106.144/30\",\r\n \"52.162.255.194/32\",\r\n - \ \"52.165.21.159/32\",\r\n \"52.165.208.47/32\",\r\n \"52.167.143.179/32\",\r\n - \ \"52.167.228.54/32\",\r\n \"52.168.109.101/32\",\r\n \"52.169.232.147/32\",\r\n - \ \"52.173.90.250/32\",\r\n \"52.173.199.154/32\",\r\n \"52.173.216.55/32\",\r\n - \ \"52.175.236.86/32\",\r\n \"52.176.48.58/32\",\r\n \"52.176.254.165/32\",\r\n - \ \"52.180.176.121/32\",\r\n \"52.180.176.122/32\",\r\n \"52.183.24.22/32\",\r\n - \ \"52.183.80.133/32\",\r\n \"52.183.93.92/32\",\r\n \"52.183.94.166/32\",\r\n - \ \"52.184.155.181/32\",\r\n \"52.187.161.13/32\",\r\n \"52.187.163.139/32\",\r\n - \ \"52.225.179.130/32\",\r\n \"52.225.182.225/32\",\r\n \"52.225.188.225/32\",\r\n - \ \"52.225.191.36/32\",\r\n \"52.225.218.218/32\",\r\n \"52.231.18.40/30\",\r\n - \ \"52.231.32.65/32\",\r\n \"52.231.32.66/32\",\r\n \"52.231.146.80/30\",\r\n - \ \"52.231.200.107/32\",\r\n \"52.231.200.108/32\",\r\n \"52.237.253.194/32\",\r\n - \ \"52.246.157.4/30\",\r\n \"52.247.193.69/32\",\r\n \"52.255.63.107/32\",\r\n - \ \"52.255.152.252/32\",\r\n \"52.255.152.255/32\",\r\n \"65.52.250.0/30\",\r\n - \ \"102.133.26.0/30\",\r\n \"102.133.154.0/30\",\r\n \"104.41.0.141/32\",\r\n - \ \"104.41.1.239/32\",\r\n \"104.41.162.219/32\",\r\n \"104.41.162.228/32\",\r\n - \ \"104.42.6.91/32\",\r\n \"104.42.136.180/32\",\r\n \"104.43.161.34/32\",\r\n - \ \"104.43.192.26/32\",\r\n \"104.44.136.42/32\",\r\n \"104.46.40.31/32\",\r\n - \ \"104.46.219.151/32\",\r\n \"104.46.219.184/32\",\r\n \"104.208.26.47/32\",\r\n - \ \"104.210.195.61/32\",\r\n \"104.211.81.24/30\",\r\n \"104.211.98.11/32\",\r\n - \ \"104.211.99.174/32\",\r\n \"104.211.146.64/30\",\r\n \"104.211.166.82/32\",\r\n - \ \"104.211.167.57/32\",\r\n \"104.211.224.186/32\",\r\n - \ \"104.211.225.134/32\",\r\n \"104.214.18.168/30\",\r\n - \ \"104.215.18.67/32\",\r\n \"104.215.31.67/32\",\r\n \"104.215.94.76/32\",\r\n - \ \"104.215.99.117/32\",\r\n \"104.215.139.166/32\",\r\n - \ \"104.215.140.132/32\",\r\n \"137.116.44.148/32\",\r\n - \ \"137.116.120.244/32\",\r\n \"137.116.233.191/32\",\r\n - \ \"168.62.108.27/32\",\r\n \"168.62.237.29/32\",\r\n \"168.63.167.27/32\",\r\n - \ \"168.63.219.200/32\",\r\n \"168.63.219.205/32\",\r\n \"191.233.50.0/30\",\r\n - \ \"191.233.203.24/30\",\r\n \"191.234.149.140/30\",\r\n - \ \"191.234.157.44/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.AustraliaCentral\",\r\n \"id\": \"AzureKeyVault.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.36.40.39/32\",\r\n - \ \"20.36.40.42/32\",\r\n \"20.36.106.64/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.AustraliaCentral2\",\r\n - \ \"id\": \"AzureKeyVault.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.72.34/32\",\r\n \"20.36.72.38/32\",\r\n - \ \"20.36.114.16/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.AustraliaEast\",\r\n \"id\": \"AzureKeyVault.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.24/30\",\r\n - \ \"13.72.250.239/32\",\r\n \"40.79.163.156/30\",\r\n \"52.237.253.194/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureKeyVault.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.138.129/32\",\r\n \"13.77.50.64/30\",\r\n - \ \"52.255.63.107/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.BrazilSouth\",\r\n \"id\": \"AzureKeyVault.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"104.41.0.141/32\",\r\n \"104.41.1.239/32\",\r\n - \ \"191.233.203.24/30\",\r\n \"191.234.149.140/30\",\r\n - \ \"191.234.157.44/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.CanadaCentral\",\r\n \"id\": \"AzureKeyVault.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"13.71.170.40/30\",\r\n \"40.85.229.9/32\",\r\n \"40.85.231.231/32\",\r\n - \ \"52.246.157.4/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.CanadaEast\",\r\n \"id\": \"AzureKeyVault.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"40.69.106.64/30\",\r\n \"40.86.224.94/32\",\r\n - \ \"40.86.231.180/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.CentralIndia\",\r\n \"id\": \"AzureKeyVault.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"104.211.81.24/30\",\r\n \"104.211.98.11/32\",\r\n - \ \"104.211.99.174/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.CentralUS\",\r\n \"id\": \"AzureKeyVault.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.89.61.248/32\",\r\n - \ \"13.89.170.200/30\",\r\n \"23.99.132.207/32\",\r\n \"52.154.176.47/32\",\r\n - \ \"52.154.177.179/32\",\r\n \"52.165.21.159/32\",\r\n \"52.165.208.47/32\",\r\n - \ \"52.173.90.250/32\",\r\n \"52.173.199.154/32\",\r\n \"52.173.216.55/32\",\r\n - \ \"52.176.48.58/32\",\r\n \"104.43.161.34/32\",\r\n \"104.43.192.26/32\",\r\n - \ \"104.208.26.47/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.CentralUSEUAP\",\r\n \"id\": \"AzureKeyVault.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"52.176.254.165/32\",\r\n - \ \"52.180.176.121/32\",\r\n \"52.180.176.122/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.EastAsia\",\r\n - \ \"id\": \"AzureKeyVault.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"13.75.34.144/30\",\r\n \"168.63.219.200/32\",\r\n - \ \"168.63.219.205/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.EastUS\",\r\n \"id\": \"AzureKeyVault.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.185.217.251/32\",\r\n - \ \"20.185.218.1/32\",\r\n \"40.71.10.200/30\",\r\n \"40.76.196.75/32\",\r\n - \ \"40.76.212.37/32\",\r\n \"40.85.185.208/32\",\r\n \"40.87.69.184/32\",\r\n - \ \"40.117.157.122/32\",\r\n \"52.168.109.101/32\",\r\n \"52.255.152.252/32\",\r\n - \ \"52.255.152.255/32\",\r\n \"137.116.120.244/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.EastUS2\",\r\n - \ \"id\": \"AzureKeyVault.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"13.68.24.216/32\",\r\n \"13.68.29.203/32\",\r\n - \ \"13.68.104.240/32\",\r\n \"20.186.41.83/32\",\r\n \"20.186.47.182/32\",\r\n - \ \"40.70.146.72/30\",\r\n \"40.70.204.6/32\",\r\n \"40.70.204.32/32\",\r\n - \ \"52.167.143.179/32\",\r\n \"52.167.228.54/32\",\r\n \"52.184.155.181/32\",\r\n - \ \"52.225.218.218/32\",\r\n \"137.116.44.148/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.EastUS2EUAP\",\r\n - \ \"id\": \"AzureKeyVault.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.118.1/32\",\r\n \"40.79.118.5/32\",\r\n - \ \"52.138.73.5/32\",\r\n \"52.138.73.51/32\",\r\n \"52.225.179.130/32\",\r\n - \ \"52.225.182.225/32\",\r\n \"52.225.188.225/32\",\r\n \"52.225.191.36/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.FranceCentral\",\r\n - \ \"id\": \"AzureKeyVault.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.56.38/32\",\r\n \"20.43.56.66/32\",\r\n - \ \"20.188.40.44/32\",\r\n \"20.188.40.46/32\",\r\n \"40.79.130.40/30\",\r\n - \ \"40.89.145.89/32\",\r\n \"40.89.145.93/32\",\r\n \"40.89.180.10/32\",\r\n - \ \"40.89.180.25/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.FranceSouth\",\r\n \"id\": \"AzureKeyVault.FranceSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"40.79.178.64/30\",\r\n - \ \"52.136.136.15/32\",\r\n \"52.136.136.16/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.GermanyNorth\",\r\n - \ \"id\": \"AzureKeyVault.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.58.0/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.GermanyWestCentral\",\r\n - \ \"id\": \"AzureKeyVault.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.154.64/30\",\r\n \"51.116.243.220/30\",\r\n - \ \"51.116.251.188/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.JapanEast\",\r\n \"id\": \"AzureKeyVault.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.78.106.88/30\",\r\n - \ \"20.188.2.148/32\",\r\n \"20.188.2.156/32\",\r\n \"23.102.72.114/32\",\r\n - \ \"23.102.75.18/32\",\r\n \"104.41.162.219/32\",\r\n \"104.41.162.228/32\",\r\n - \ \"104.46.219.151/32\",\r\n \"104.46.219.184/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.JapanWest\",\r\n - \ \"id\": \"AzureKeyVault.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.100.48/30\",\r\n \"104.215.18.67/32\",\r\n - \ \"104.215.31.67/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.KoreaCentral\",\r\n \"id\": \"AzureKeyVault.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.194.66.0/30\",\r\n - \ \"52.231.18.40/30\",\r\n \"52.231.32.65/32\",\r\n \"52.231.32.66/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.KoreaSouth\",\r\n - \ \"id\": \"AzureKeyVault.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.146.80/30\",\r\n \"52.231.200.107/32\",\r\n - \ \"52.231.200.108/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.NorthCentralUS\",\r\n \"id\": \"AzureKeyVault.NorthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"23.96.210.207/32\",\r\n - \ \"23.96.250.48/32\",\r\n \"52.162.106.144/30\",\r\n \"52.162.255.194/32\",\r\n - \ \"168.62.108.27/32\",\r\n \"168.62.237.29/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.NorthEurope\",\r\n - \ \"id\": \"AzureKeyVault.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.227.72/30\",\r\n \"13.74.10.39/32\",\r\n - \ \"13.74.10.113/32\",\r\n \"23.100.57.24/32\",\r\n \"23.100.58.149/32\",\r\n - \ \"52.138.160.103/32\",\r\n \"52.138.160.105/32\",\r\n \"52.169.232.147/32\",\r\n - \ \"137.116.233.191/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.NorwayEast\",\r\n \"id\": \"AzureKeyVault.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.120.98.8/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.NorwayWest\",\r\n - \ \"id\": \"AzureKeyVault.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"51.120.218.0/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.SouthAfricaNorth\",\r\n \"id\": \"AzureKeyVault.SouthAfricaNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"102.133.154.0/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SouthAfricaWest\",\r\n - \ \"id\": \"AzureKeyVault.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.26.0/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SouthCentralUS\",\r\n - \ \"id\": \"AzureKeyVault.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.84.174.143/32\",\r\n \"20.45.123.240/30\",\r\n - \ \"20.49.90.0/30\",\r\n \"104.44.136.42/32\",\r\n \"104.210.195.61/32\",\r\n - \ \"104.214.18.168/30\",\r\n \"104.215.94.76/32\",\r\n \"104.215.99.117/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SoutheastAsia\",\r\n - \ \"id\": \"AzureKeyVault.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.8.104/30\",\r\n \"23.97.50.43/32\",\r\n - \ \"23.101.21.103/32\",\r\n \"23.101.21.193/32\",\r\n \"23.101.23.190/32\",\r\n - \ \"23.101.23.192/32\",\r\n \"40.65.188.244/32\",\r\n \"40.65.189.219/32\",\r\n - \ \"52.148.84.142/32\",\r\n \"52.148.84.145/32\",\r\n \"52.187.161.13/32\",\r\n - \ \"52.187.163.139/32\",\r\n \"104.215.139.166/32\",\r\n - \ \"104.215.140.132/32\",\r\n \"168.63.167.27/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SouthIndia\",\r\n - \ \"id\": \"AzureKeyVault.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.194.64/30\",\r\n \"104.211.224.186/32\",\r\n - \ \"104.211.225.134/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.SwitzerlandNorth\",\r\n \"id\": \"AzureKeyVault.SwitzerlandNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.107.58.0/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SwitzerlandWest\",\r\n - \ \"id\": \"AzureKeyVault.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.154.0/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UAECentral\",\r\n - \ \"id\": \"AzureKeyVault.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.74.228/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UAENorth\",\r\n - \ \"id\": \"AzureKeyVault.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"40.120.74.0/30\",\r\n \"65.52.250.0/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKNorth\",\r\n - \ \"id\": \"AzureKeyVault.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.87.101.60/32\",\r\n - \ \"13.87.101.111/32\",\r\n \"13.87.122.80/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKSouth\",\r\n - \ \"id\": \"AzureKeyVault.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"51.104.192.129/32\",\r\n \"51.104.192.138/32\",\r\n - \ \"51.105.4.67/32\",\r\n \"51.105.4.75/32\",\r\n \"51.140.146.56/30\",\r\n - \ \"51.140.157.60/32\",\r\n \"51.140.184.38/31\",\r\n \"52.151.75.86/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKSouth2\",\r\n - \ \"id\": \"AzureKeyVault.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.87.34.51/32\",\r\n - \ \"13.87.39.0/32\",\r\n \"13.87.56.80/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKWest\",\r\n - \ \"id\": \"AzureKeyVault.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"51.140.210.80/30\",\r\n \"51.141.8.42/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.WestCentralUS\",\r\n - \ \"id\": \"AzureKeyVault.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.112/30\",\r\n \"52.161.25.42/32\",\r\n - \ \"52.161.31.136/32\",\r\n \"52.161.31.139/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.WestEurope\",\r\n - \ \"id\": \"AzureKeyVault.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.64.72/30\",\r\n \"13.80.247.19/32\",\r\n - \ \"13.80.247.42/32\",\r\n \"23.97.178.0/32\",\r\n \"40.91.193.78/32\",\r\n - \ \"40.91.199.213/32\",\r\n \"52.157.162.137/32\",\r\n \"52.157.162.147/32\",\r\n - \ \"104.46.40.31/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.WestIndia\",\r\n \"id\": \"AzureKeyVault.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"104.211.146.64/30\",\r\n - \ \"104.211.166.82/32\",\r\n \"104.211.167.57/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.WestUS\",\r\n - \ \"id\": \"AzureKeyVault.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": - [\r\n \"40.112.242.144/30\",\r\n \"104.42.6.91/32\",\r\n - \ \"104.42.136.180/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureKeyVault.WestUS2\",\r\n \"id\": \"AzureKeyVault.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.66.138.88/30\",\r\n - \ \"13.66.226.249/32\",\r\n \"13.66.230.241/32\",\r\n \"51.143.6.21/32\",\r\n - \ \"52.151.41.92/32\",\r\n \"52.151.47.4/32\",\r\n \"52.158.236.253/32\",\r\n - \ \"52.158.239.35/32\",\r\n \"52.175.236.86/32\",\r\n \"52.183.24.22/32\",\r\n - \ \"52.183.80.133/32\",\r\n \"52.183.93.92/32\",\r\n \"52.183.94.166/32\",\r\n - \ \"52.247.193.69/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMachineLearning\",\r\n \"id\": \"AzureMachineLearning\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.66.87.135/32\",\r\n \"13.66.140.80/28\",\r\n - \ \"13.67.8.224/28\",\r\n \"13.69.64.192/28\",\r\n \"13.69.106.192/28\",\r\n - \ \"13.69.227.192/28\",\r\n \"13.70.72.144/28\",\r\n \"13.71.170.192/28\",\r\n - \ \"13.71.173.80/28\",\r\n \"13.71.194.240/28\",\r\n \"13.73.240.16/28\",\r\n - \ \"13.73.240.112/28\",\r\n \"13.73.240.240/28\",\r\n \"13.73.248.96/28\",\r\n - \ \"13.74.107.160/28\",\r\n \"13.75.36.16/28\",\r\n \"13.77.50.224/28\",\r\n - \ \"13.78.106.208/28\",\r\n \"13.86.195.35/32\",\r\n \"13.87.56.112/28\",\r\n - \ \"13.87.122.112/28\",\r\n \"13.87.160.129/32\",\r\n \"13.89.171.64/28\",\r\n - \ \"20.36.106.80/28\",\r\n \"20.36.114.160/28\",\r\n \"20.37.67.80/28\",\r\n - \ \"20.37.74.208/28\",\r\n \"20.37.152.240/28\",\r\n \"20.37.192.96/28\",\r\n - \ \"20.38.80.96/28\",\r\n \"20.38.128.48/28\",\r\n \"20.38.147.128/28\",\r\n - \ \"20.39.1.205/32\",\r\n \"20.39.11.80/28\",\r\n \"20.40.141.171/32\",\r\n - \ \"20.41.0.240/28\",\r\n \"20.41.64.80/28\",\r\n \"20.41.197.0/28\",\r\n - \ \"20.42.0.240/28\",\r\n \"20.42.129.16/28\",\r\n \"20.42.227.48/28\",\r\n - \ \"20.43.40.96/28\",\r\n \"20.43.64.96/28\",\r\n \"20.43.120.112/28\",\r\n - \ \"20.43.128.112/28\",\r\n \"20.44.3.32/28\",\r\n \"20.44.26.224/28\",\r\n - \ \"20.44.132.166/32\",\r\n \"20.150.161.128/28\",\r\n \"20.150.171.80/28\",\r\n - \ \"20.150.179.64/28\",\r\n \"20.150.187.64/28\",\r\n \"20.188.219.157/32\",\r\n - \ \"20.188.221.15/32\",\r\n \"20.189.106.80/28\",\r\n \"20.192.99.64/28\",\r\n - \ \"20.192.160.48/28\",\r\n \"20.192.225.144/28\",\r\n \"20.192.235.16/28\",\r\n - \ \"23.98.82.192/28\",\r\n \"23.100.232.216/32\",\r\n \"40.66.61.146/32\",\r\n - \ \"40.67.59.80/28\",\r\n \"40.69.106.224/28\",\r\n \"40.70.146.192/28\",\r\n - \ \"40.70.154.161/32\",\r\n \"40.71.11.64/28\",\r\n \"40.74.24.96/28\",\r\n - \ \"40.74.100.176/28\",\r\n \"40.74.147.48/28\",\r\n \"40.75.35.48/28\",\r\n - \ \"40.78.194.224/28\",\r\n \"40.78.202.80/28\",\r\n \"40.78.227.32/28\",\r\n - \ \"40.78.234.128/28\",\r\n \"40.78.242.176/28\",\r\n \"40.78.250.112/28\",\r\n - \ \"40.79.130.192/28\",\r\n \"40.79.138.128/28\",\r\n \"40.79.146.128/28\",\r\n - \ \"40.79.154.64/28\",\r\n \"40.79.162.48/28\",\r\n \"40.79.170.224/28\",\r\n - \ \"40.79.178.224/28\",\r\n \"40.79.186.160/28\",\r\n \"40.79.194.64/28\",\r\n - \ \"40.80.51.64/28\",\r\n \"40.80.57.176/28\",\r\n \"40.80.169.160/28\",\r\n - \ \"40.80.184.80/28\",\r\n \"40.80.188.96/28\",\r\n \"40.81.27.228/32\",\r\n - \ \"40.82.187.230/32\",\r\n \"40.82.248.80/28\",\r\n \"40.89.17.208/28\",\r\n - \ \"40.90.184.249/32\",\r\n \"40.91.77.76/32\",\r\n \"40.112.242.176/28\",\r\n - \ \"40.119.8.80/28\",\r\n \"51.11.24.49/32\",\r\n \"51.12.99.80/28\",\r\n - \ \"51.12.203.80/28\",\r\n \"51.12.227.64/28\",\r\n \"51.12.235.64/28\",\r\n - \ \"51.104.8.64/27\",\r\n \"51.104.24.96/28\",\r\n \"51.105.67.16/28\",\r\n - \ \"51.105.75.128/28\",\r\n \"51.105.88.224/28\",\r\n \"51.105.129.135/32\",\r\n - \ \"51.107.59.48/28\",\r\n \"51.107.147.32/28\",\r\n \"51.107.155.48/28\",\r\n - \ \"51.116.49.176/28\",\r\n \"51.116.59.48/28\",\r\n \"51.116.155.112/28\",\r\n - \ \"51.116.156.128/28\",\r\n \"51.116.250.224/28\",\r\n \"51.120.99.64/28\",\r\n - \ \"51.120.107.64/28\",\r\n \"51.120.211.64/28\",\r\n \"51.120.219.80/28\",\r\n - \ \"51.120.227.80/28\",\r\n \"51.137.161.224/28\",\r\n \"51.140.146.208/28\",\r\n - \ \"51.140.210.208/28\",\r\n \"51.144.184.47/32\",\r\n \"52.138.90.144/28\",\r\n - \ \"52.138.226.160/28\",\r\n \"52.139.3.33/32\",\r\n \"52.140.107.96/28\",\r\n - \ \"52.141.25.58/32\",\r\n \"52.141.26.97/32\",\r\n \"52.148.163.43/32\",\r\n - \ \"52.150.136.80/28\",\r\n \"52.151.111.249/32\",\r\n \"52.155.90.254/32\",\r\n - \ \"52.155.115.7/32\",\r\n \"52.156.193.50/32\",\r\n \"52.162.106.176/28\",\r\n - \ \"52.167.106.160/28\",\r\n \"52.177.164.219/32\",\r\n \"52.182.139.32/28\",\r\n - \ \"52.184.87.76/32\",\r\n \"52.185.70.56/32\",\r\n \"52.228.80.80/28\",\r\n - \ \"52.230.56.136/32\",\r\n \"52.231.18.192/28\",\r\n \"52.231.146.208/28\",\r\n - \ \"52.236.186.192/28\",\r\n \"52.242.224.215/32\",\r\n \"52.246.155.128/28\",\r\n - \ \"52.249.59.91/32\",\r\n \"52.252.160.26/32\",\r\n \"52.253.131.79/32\",\r\n - \ \"52.253.131.198/32\",\r\n \"52.253.227.208/32\",\r\n \"52.255.214.109/32\",\r\n - \ \"52.255.217.127/32\",\r\n \"65.52.250.192/28\",\r\n \"102.133.27.32/28\",\r\n - \ \"102.133.58.224/28\",\r\n \"102.133.122.224/27\",\r\n - \ \"102.133.155.32/28\",\r\n \"102.133.251.64/28\",\r\n \"104.208.16.160/28\",\r\n - \ \"104.208.144.160/28\",\r\n \"104.211.81.144/28\",\r\n - \ \"104.214.19.32/28\",\r\n \"191.233.8.48/28\",\r\n \"191.233.203.144/28\",\r\n - \ \"191.233.240.165/32\",\r\n \"191.233.242.167/32\",\r\n - \ \"191.234.147.64/28\",\r\n \"191.234.155.64/28\",\r\n \"191.235.224.96/28\",\r\n - \ \"2603:1000:104:1::2c0/122\",\r\n \"2603:1010:6:1::2c0/122\",\r\n - \ \"2603:1020:5:1::2c0/122\",\r\n \"2603:1020:206:1::2c0/122\",\r\n - \ \"2603:1020:705:1::2c0/122\",\r\n \"2603:1020:805:1::2c0/122\",\r\n - \ \"2603:1020:a04:1::2c0/122\",\r\n \"2603:1020:c04:1::2c0/122\",\r\n - \ \"2603:1020:e04:1::2c0/122\",\r\n \"2603:1020:1004::2c0/122\",\r\n - \ \"2603:1030:10:1::2c0/122\",\r\n \"2603:1030:104:1::2c0/122\",\r\n - \ \"2603:1030:210:1::2c0/122\",\r\n \"2603:1030:40b:1::2c0/122\",\r\n - \ \"2603:1030:40c:1::2c0/122\",\r\n \"2603:1030:504:1::2c0/122\",\r\n - \ \"2603:1030:807:1::2c0/122\",\r\n \"2603:1030:c06:1::2c0/122\",\r\n - \ \"2603:1030:f05:1::2c0/122\",\r\n \"2603:1040:5:1::2c0/122\",\r\n - \ \"2603:1040:407:1::2c0/122\",\r\n \"2603:1040:904:1::2c0/122\",\r\n - \ \"2603:1040:a06:1::2c0/122\",\r\n \"2603:1040:d04::2c0/122\",\r\n - \ \"2603:1040:f05:1::2c0/122\",\r\n \"2603:1050:6:1::2c0/122\",\r\n - \ \"2603:1050:403::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.AustraliaCentral\",\r\n \"id\": - \"AzureMachineLearning.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.36.106.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMachineLearning.AustraliaCentral2\",\r\n \"id\": - \"AzureMachineLearning.AustraliaCentral2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.36.114.160/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.AustraliaEast\",\r\n \"id\": - \"AzureMachineLearning.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.144/28\",\r\n - \ \"20.37.192.96/28\",\r\n \"20.188.219.157/32\",\r\n \"20.188.221.15/32\",\r\n - \ \"40.79.162.48/28\",\r\n \"40.79.170.224/28\",\r\n \"2603:1010:6:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureMachineLearning.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.77.50.224/28\",\r\n \"20.42.227.48/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.BrazilSouth\",\r\n - \ \"id\": \"AzureMachineLearning.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"191.233.203.144/28\",\r\n \"191.233.240.165/32\",\r\n - \ \"191.233.242.167/32\",\r\n \"191.234.147.64/28\",\r\n - \ \"191.234.155.64/28\",\r\n \"191.235.224.96/28\",\r\n \"2603:1050:6:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CanadaCentral\",\r\n - \ \"id\": \"AzureMachineLearning.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.71.170.192/28\",\r\n \"13.71.173.80/28\",\r\n - \ \"20.38.147.128/28\",\r\n \"40.82.187.230/32\",\r\n \"52.139.3.33/32\",\r\n - \ \"52.228.80.80/28\",\r\n \"52.246.155.128/28\",\r\n \"2603:1030:f05:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CanadaEast\",\r\n - \ \"id\": \"AzureMachineLearning.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"40.69.106.224/28\",\r\n \"40.89.17.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CentralIndia\",\r\n - \ \"id\": \"AzureMachineLearning.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.43.120.112/28\",\r\n \"20.192.99.64/28\",\r\n - \ \"40.80.51.64/28\",\r\n \"52.140.107.96/28\",\r\n \"104.211.81.144/28\",\r\n - \ \"2603:1040:a06:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.CentralUS\",\r\n \"id\": - \"AzureMachineLearning.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.64/28\",\r\n - \ \"20.37.152.240/28\",\r\n \"52.182.139.32/28\",\r\n \"52.185.70.56/32\",\r\n - \ \"52.242.224.215/32\",\r\n \"104.208.16.160/28\",\r\n \"2603:1030:10:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CentralUSEUAP\",\r\n - \ \"id\": \"AzureMachineLearning.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"40.78.202.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMachineLearning.EastAsia\",\r\n \"id\": \"AzureMachineLearning.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.36.16/28\",\r\n \"20.189.106.80/28\",\r\n - \ \"40.81.27.228/32\",\r\n \"52.184.87.76/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.EastUS\",\r\n - \ \"id\": \"AzureMachineLearning.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.42.0.240/28\",\r\n \"40.71.11.64/28\",\r\n \"40.78.227.32/28\",\r\n - \ \"40.79.154.64/28\",\r\n \"52.255.214.109/32\",\r\n \"52.255.217.127/32\",\r\n - \ \"2603:1030:210:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.EastUS2\",\r\n \"id\": - \"AzureMachineLearning.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"20.41.0.240/28\",\r\n - \ \"40.70.146.192/28\",\r\n \"40.70.154.161/32\",\r\n \"52.167.106.160/28\",\r\n - \ \"52.177.164.219/32\",\r\n \"104.208.144.160/28\",\r\n - \ \"2603:1030:40c:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.EastUS2EUAP\",\r\n \"id\": - \"AzureMachineLearning.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"20.39.1.205/32\",\r\n - \ \"20.39.11.80/28\",\r\n \"40.74.147.48/28\",\r\n \"40.75.35.48/28\",\r\n - \ \"52.138.90.144/28\",\r\n \"52.253.227.208/32\",\r\n \"2603:1030:40b:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.FranceCentral\",\r\n - \ \"id\": \"AzureMachineLearning.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.40.141.171/32\",\r\n \"20.43.40.96/28\",\r\n - \ \"40.66.61.146/32\",\r\n \"40.79.130.192/28\",\r\n \"40.79.138.128/28\",\r\n - \ \"40.79.146.128/28\",\r\n \"2603:1020:805:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.FranceSouth\",\r\n - \ \"id\": \"AzureMachineLearning.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"40.79.178.224/28\",\r\n \"51.105.88.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.GermanyNorth\",\r\n - \ \"id\": \"AzureMachineLearning.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.116.49.176/28\",\r\n \"51.116.59.48/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.GermanyWestCentral\",\r\n - \ \"id\": \"AzureMachineLearning.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.116.155.112/28\",\r\n \"51.116.156.128/28\",\r\n - \ \"51.116.250.224/28\",\r\n \"2603:1020:c04:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.JapanEast\",\r\n - \ \"id\": \"AzureMachineLearning.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.78.106.208/28\",\r\n \"20.43.64.96/28\",\r\n - \ \"20.44.132.166/32\",\r\n \"40.79.186.160/28\",\r\n \"40.79.194.64/28\",\r\n - \ \"52.155.115.7/32\",\r\n \"2603:1040:407:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.JapanWest\",\r\n - \ \"id\": \"AzureMachineLearning.JapanWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.176/28\",\r\n \"40.80.57.176/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.KoreaCentral\",\r\n - \ \"id\": \"AzureMachineLearning.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.41.64.80/28\",\r\n \"20.44.26.224/28\",\r\n \"52.141.25.58/32\",\r\n - \ \"52.141.26.97/32\",\r\n \"52.231.18.192/28\",\r\n \"2603:1040:f05:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.KoreaSouth\",\r\n - \ \"id\": \"AzureMachineLearning.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"40.80.169.160/28\",\r\n \"52.231.146.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorthCentralUS\",\r\n - \ \"id\": \"AzureMachineLearning.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"23.100.232.216/32\",\r\n \"40.80.184.80/28\",\r\n - \ \"40.80.188.96/28\",\r\n \"52.162.106.176/28\",\r\n \"52.252.160.26/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorthEurope\",\r\n - \ \"id\": \"AzureMachineLearning.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.69.227.192/28\",\r\n \"13.74.107.160/28\",\r\n - \ \"20.38.80.96/28\",\r\n \"52.138.226.160/28\",\r\n \"52.155.90.254/32\",\r\n - \ \"52.156.193.50/32\",\r\n \"2603:1020:5:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorwayEast\",\r\n - \ \"id\": \"AzureMachineLearning.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.120.99.64/28\",\r\n \"51.120.107.64/28\",\r\n - \ \"51.120.211.64/28\",\r\n \"2603:1020:e04:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorwayWest\",\r\n - \ \"id\": \"AzureMachineLearning.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.120.219.80/28\",\r\n \"51.120.227.80/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureMachineLearning.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"102.133.122.224/27\",\r\n \"102.133.155.32/28\",\r\n - \ \"102.133.251.64/28\",\r\n \"2603:1000:104:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SouthAfricaWest\",\r\n - \ \"id\": \"AzureMachineLearning.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"102.133.27.32/28\",\r\n \"102.133.58.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SouthCentralUS\",\r\n - \ \"id\": \"AzureMachineLearning.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.66.87.135/32\",\r\n \"13.73.240.16/28\",\r\n - \ \"13.73.240.112/28\",\r\n \"13.73.240.240/28\",\r\n \"13.73.248.96/28\",\r\n - \ \"40.119.8.80/28\",\r\n \"52.249.59.91/32\",\r\n \"104.214.19.32/28\",\r\n - \ \"2603:1030:807:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.SoutheastAsia\",\r\n \"id\": - \"AzureMachineLearning.SoutheastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.224/28\",\r\n - \ \"20.43.128.112/28\",\r\n \"23.98.82.192/28\",\r\n \"40.78.234.128/28\",\r\n - \ \"40.90.184.249/32\",\r\n \"52.230.56.136/32\",\r\n \"2603:1040:5:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SouthIndia\",\r\n - \ \"id\": \"AzureMachineLearning.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.41.197.0/28\",\r\n \"40.78.194.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureMachineLearning.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.107.59.48/28\",\r\n \"2603:1020:a04:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SwitzerlandWest\",\r\n - \ \"id\": \"AzureMachineLearning.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.107.147.32/28\",\r\n \"51.107.155.48/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UAECentral\",\r\n - \ \"id\": \"AzureMachineLearning.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.37.67.80/28\",\r\n \"20.37.74.208/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UAENorth\",\r\n - \ \"id\": \"AzureMachineLearning.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"65.52.250.192/28\",\r\n \"2603:1040:904:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UKNorth\",\r\n - \ \"id\": \"AzureMachineLearning.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.87.122.112/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.UKSouth\",\r\n \"id\": - \"AzureMachineLearning.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"51.11.24.49/32\",\r\n - \ \"51.104.8.64/27\",\r\n \"51.104.24.96/28\",\r\n \"51.105.67.16/28\",\r\n - \ \"51.105.75.128/28\",\r\n \"51.140.146.208/28\",\r\n \"52.151.111.249/32\",\r\n - \ \"2603:1020:705:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMachineLearning.UKSouth2\",\r\n \"id\": - \"AzureMachineLearning.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \"13.87.56.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UKWest\",\r\n - \ \"id\": \"AzureMachineLearning.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"51.137.161.224/28\",\r\n \"51.140.210.208/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.WestCentralUS\",\r\n - \ \"id\": \"AzureMachineLearning.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.71.194.240/28\",\r\n \"52.150.136.80/28\",\r\n - \ \"52.253.131.79/32\",\r\n \"52.253.131.198/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.WestEurope\",\r\n - \ \"id\": \"AzureMachineLearning.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.69.64.192/28\",\r\n \"13.69.106.192/28\",\r\n - \ \"40.74.24.96/28\",\r\n \"51.105.129.135/32\",\r\n \"51.144.184.47/32\",\r\n - \ \"52.236.186.192/28\",\r\n \"2603:1020:206:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.WestIndia\",\r\n - \ \"id\": \"AzureMachineLearning.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"20.38.128.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMachineLearning.WestUS\",\r\n \"id\": \"AzureMachineLearning.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.195.35/32\",\r\n \"13.87.160.129/32\",\r\n - \ \"40.82.248.80/28\",\r\n \"40.112.242.176/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.WestUS2\",\r\n - \ \"id\": \"AzureMachineLearning.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureMachineLearning\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.80/28\",\r\n \"20.42.129.16/28\",\r\n - \ \"40.78.242.176/28\",\r\n \"40.78.250.112/28\",\r\n \"40.91.77.76/32\",\r\n - \ \"52.148.163.43/32\",\r\n \"2603:1030:c06:1::2c0/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor\",\r\n - \ \"id\": \"AzureMonitor\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"13.65.96.175/32\",\r\n \"13.65.206.67/32\",\r\n - \ \"13.65.211.125/32\",\r\n \"13.66.36.144/32\",\r\n \"13.66.37.172/32\",\r\n - \ \"13.66.59.226/32\",\r\n \"13.66.60.151/32\",\r\n \"13.66.140.168/29\",\r\n - \ \"13.66.141.152/29\",\r\n \"13.66.143.218/32\",\r\n \"13.66.160.124/32\",\r\n - \ \"13.66.220.187/32\",\r\n \"13.66.231.27/32\",\r\n \"13.67.9.192/28\",\r\n - \ \"13.67.10.64/29\",\r\n \"13.67.10.92/30\",\r\n \"13.67.15.0/32\",\r\n - \ \"13.67.77.233/32\",\r\n \"13.67.89.191/32\",\r\n \"13.68.31.237/32\",\r\n - \ \"13.68.101.211/32\",\r\n \"13.68.106.77/32\",\r\n \"13.68.109.212/32\",\r\n - \ \"13.68.111.247/32\",\r\n \"13.69.51.175/32\",\r\n \"13.69.51.218/32\",\r\n - \ \"13.69.65.16/28\",\r\n \"13.69.66.136/29\",\r\n \"13.69.67.60/30\",\r\n - \ \"13.69.67.126/32\",\r\n \"13.69.106.88/29\",\r\n \"13.69.106.208/28\",\r\n - \ \"13.69.229.64/29\",\r\n \"13.69.229.240/29\",\r\n \"13.69.233.0/30\",\r\n - \ \"13.70.72.232/29\",\r\n \"13.70.73.104/29\",\r\n \"13.70.124.27/32\",\r\n - \ \"13.70.127.61/32\",\r\n \"13.71.172.128/28\",\r\n \"13.71.172.248/29\",\r\n - \ \"13.71.175.128/32\",\r\n \"13.71.187.91/32\",\r\n \"13.71.191.47/32\",\r\n - \ \"13.71.195.192/27\",\r\n \"13.71.196.56/29\",\r\n \"13.71.199.116/32\",\r\n - \ \"13.73.26.213/32\",\r\n \"13.73.240.0/29\",\r\n \"13.73.242.32/29\",\r\n - \ \"13.73.244.192/31\",\r\n \"13.74.107.88/30\",\r\n \"13.74.108.128/29\",\r\n - \ \"13.75.38.0/28\",\r\n \"13.75.38.120/29\",\r\n \"13.75.39.76/30\",\r\n - \ \"13.75.117.221/32\",\r\n \"13.75.119.169/32\",\r\n \"13.75.195.15/32\",\r\n - \ \"13.76.85.243/32\",\r\n \"13.76.87.86/32\",\r\n \"13.77.52.16/28\",\r\n - \ \"13.77.53.48/29\",\r\n \"13.77.53.220/32\",\r\n \"13.77.150.166/32\",\r\n - \ \"13.77.155.39/32\",\r\n \"13.77.174.177/32\",\r\n \"13.78.10.58/32\",\r\n - \ \"13.78.13.189/32\",\r\n \"13.78.108.160/29\",\r\n \"13.78.108.168/30\",\r\n - \ \"13.78.109.112/29\",\r\n \"13.78.111.192/32\",\r\n \"13.78.135.15/32\",\r\n - \ \"13.78.145.11/32\",\r\n \"13.78.151.158/32\",\r\n \"13.78.172.58/32\",\r\n - \ \"13.78.189.112/32\",\r\n \"13.78.236.149/32\",\r\n \"13.78.237.51/32\",\r\n - \ \"13.80.134.255/32\",\r\n \"13.82.100.176/32\",\r\n \"13.82.184.151/32\",\r\n - \ \"13.84.134.59/32\",\r\n \"13.84.148.7/32\",\r\n \"13.84.149.186/32\",\r\n - \ \"13.84.173.179/32\",\r\n \"13.84.189.95/32\",\r\n \"13.84.225.10/32\",\r\n - \ \"13.85.70.142/32\",\r\n \"13.86.218.224/28\",\r\n \"13.86.218.248/29\",\r\n - \ \"13.87.56.248/29\",\r\n \"13.87.57.128/28\",\r\n \"13.87.122.248/29\",\r\n - \ \"13.87.123.128/28\",\r\n \"13.88.177.28/32\",\r\n \"13.88.230.43/32\",\r\n - \ \"13.88.247.208/32\",\r\n \"13.88.255.115/32\",\r\n \"13.89.42.127/32\",\r\n - \ \"13.89.171.112/30\",\r\n \"13.89.174.128/29\",\r\n \"13.90.93.206/32\",\r\n - \ \"13.90.248.141/32\",\r\n \"13.90.249.229/32\",\r\n \"13.90.251.123/32\",\r\n - \ \"13.91.42.27/32\",\r\n \"13.91.102.27/32\",\r\n \"13.92.40.198/32\",\r\n - \ \"13.92.40.223/32\",\r\n \"13.92.138.16/32\",\r\n \"13.92.179.52/32\",\r\n - \ \"13.92.211.249/32\",\r\n \"13.92.232.146/32\",\r\n \"13.92.254.218/32\",\r\n - \ \"13.92.255.146/32\",\r\n \"13.93.215.80/32\",\r\n \"13.93.233.49/32\",\r\n - \ \"13.93.236.73/32\",\r\n \"13.94.39.13/32\",\r\n \"20.36.107.24/29\",\r\n - \ \"20.36.107.160/28\",\r\n \"20.36.114.200/29\",\r\n \"20.36.114.208/28\",\r\n - \ \"20.37.74.232/29\",\r\n \"20.37.74.240/28\",\r\n \"20.37.152.68/31\",\r\n - \ \"20.37.192.68/31\",\r\n \"20.37.198.112/28\",\r\n \"20.37.227.16/28\",\r\n - \ \"20.38.80.68/31\",\r\n \"20.38.128.64/29\",\r\n \"20.38.146.152/29\",\r\n - \ \"20.38.147.144/29\",\r\n \"20.39.14.0/28\",\r\n \"20.40.124.0/32\",\r\n - \ \"20.40.137.91/32\",\r\n \"20.40.140.212/32\",\r\n \"20.40.160.120/32\",\r\n - \ \"20.40.206.128/28\",\r\n \"20.41.49.208/32\",\r\n \"20.41.64.68/31\",\r\n - \ \"20.41.67.112/28\",\r\n \"20.42.0.68/31\",\r\n \"20.42.128.68/31\",\r\n - \ \"20.42.230.112/28\",\r\n \"20.43.40.68/31\",\r\n \"20.43.44.128/28\",\r\n - \ \"20.43.64.68/31\",\r\n \"20.43.70.96/28\",\r\n \"20.43.98.234/32\",\r\n - \ \"20.43.99.158/32\",\r\n \"20.43.120.0/29\",\r\n \"20.43.120.240/29\",\r\n - \ \"20.43.128.68/31\",\r\n \"20.43.152.45/32\",\r\n \"20.44.3.48/28\",\r\n - \ \"20.44.8.0/28\",\r\n \"20.44.16.0/29\",\r\n \"20.44.17.0/29\",\r\n - \ \"20.44.26.152/29\",\r\n \"20.44.26.248/29\",\r\n \"20.44.73.196/32\",\r\n - \ \"20.44.192.217/32\",\r\n \"20.45.122.152/29\",\r\n \"20.45.123.80/29\",\r\n - \ \"20.45.123.116/30\",\r\n \"20.45.125.224/28\",\r\n \"20.49.83.32/28\",\r\n - \ \"20.49.91.32/28\",\r\n \"20.49.99.64/28\",\r\n \"20.49.109.80/28\",\r\n - \ \"20.49.120.64/28\",\r\n \"20.50.65.80/28\",\r\n \"20.150.171.208/29\",\r\n - \ \"20.150.173.0/28\",\r\n \"20.150.178.152/29\",\r\n \"20.150.181.96/28\",\r\n - \ \"20.150.186.152/29\",\r\n \"20.188.36.28/32\",\r\n \"20.189.109.144/28\",\r\n - \ \"20.190.60.32/32\",\r\n \"20.190.60.38/32\",\r\n \"20.192.98.152/29\",\r\n - \ \"20.192.235.144/28\",\r\n \"20.193.203.112/28\",\r\n \"20.194.67.32/28\",\r\n - \ \"23.96.28.38/32\",\r\n \"23.96.245.125/32\",\r\n \"23.96.252.161/32\",\r\n - \ \"23.96.252.216/32\",\r\n \"23.97.65.103/32\",\r\n \"23.98.82.120/29\",\r\n - \ \"23.98.82.208/28\",\r\n \"23.98.104.160/28\",\r\n \"23.99.130.172/32\",\r\n - \ \"23.100.90.7/32\",\r\n \"23.100.94.221/32\",\r\n \"23.100.122.113/32\",\r\n - \ \"23.100.228.32/32\",\r\n \"23.101.0.142/32\",\r\n \"23.101.9.4/32\",\r\n - \ \"23.101.13.65/32\",\r\n \"23.101.69.223/32\",\r\n \"23.101.225.155/32\",\r\n - \ \"23.101.232.120/32\",\r\n \"23.101.239.238/32\",\r\n \"23.102.44.211/32\",\r\n - \ \"23.102.45.216/32\",\r\n \"23.102.66.132/32\",\r\n \"23.102.77.48/32\",\r\n - \ \"23.102.181.197/32\",\r\n \"40.64.132.128/28\",\r\n \"40.67.59.192/28\",\r\n - \ \"40.68.61.229/32\",\r\n \"40.68.154.39/32\",\r\n \"40.69.81.159/32\",\r\n - \ \"40.69.107.16/28\",\r\n \"40.69.108.48/29\",\r\n \"40.69.194.158/32\",\r\n - \ \"40.70.23.205/32\",\r\n \"40.70.148.0/30\",\r\n \"40.70.148.8/29\",\r\n - \ \"40.71.12.224/28\",\r\n \"40.71.12.240/30\",\r\n \"40.71.12.248/29\",\r\n - \ \"40.71.13.168/29\",\r\n \"40.71.14.112/30\",\r\n \"40.71.183.225/32\",\r\n - \ \"40.74.24.68/31\",\r\n \"40.74.36.208/32\",\r\n \"40.74.59.40/32\",\r\n - \ \"40.74.101.32/28\",\r\n \"40.74.101.200/29\",\r\n \"40.74.146.84/30\",\r\n - \ \"40.74.147.160/29\",\r\n \"40.74.249.98/32\",\r\n \"40.75.34.40/29\",\r\n - \ \"40.75.35.64/29\",\r\n \"40.76.29.55/32\",\r\n \"40.76.53.225/32\",\r\n - \ \"40.77.17.183/32\",\r\n \"40.77.22.234/32\",\r\n \"40.77.24.27/32\",\r\n - \ \"40.77.101.95/32\",\r\n \"40.77.109.134/32\",\r\n \"40.78.23.86/32\",\r\n - \ \"40.78.57.61/32\",\r\n \"40.78.107.177/32\",\r\n \"40.78.195.16/28\",\r\n - \ \"40.78.196.48/29\",\r\n \"40.78.202.144/28\",\r\n \"40.78.203.240/29\",\r\n - \ \"40.78.226.216/29\",\r\n \"40.78.229.32/29\",\r\n \"40.78.234.56/29\",\r\n - \ \"40.78.234.144/28\",\r\n \"40.78.242.168/30\",\r\n \"40.78.243.16/29\",\r\n - \ \"40.78.250.104/30\",\r\n \"40.78.250.208/29\",\r\n \"40.79.130.240/29\",\r\n - \ \"40.79.132.32/29\",\r\n \"40.79.138.40/30\",\r\n \"40.79.138.144/29\",\r\n - \ \"40.79.146.40/30\",\r\n \"40.79.146.144/29\",\r\n \"40.79.154.80/29\",\r\n - \ \"40.79.156.32/29\",\r\n \"40.79.162.40/29\",\r\n \"40.79.163.0/29\",\r\n - \ \"40.79.165.64/28\",\r\n \"40.79.170.24/29\",\r\n \"40.79.170.240/29\",\r\n - \ \"40.79.179.8/29\",\r\n \"40.79.179.16/28\",\r\n \"40.79.187.8/29\",\r\n - \ \"40.79.194.104/29\",\r\n \"40.79.194.112/29\",\r\n \"40.80.50.152/29\",\r\n - \ \"40.80.51.80/29\",\r\n \"40.80.191.224/28\",\r\n \"40.81.58.225/32\",\r\n - \ \"40.84.133.5/32\",\r\n \"40.84.150.47/32\",\r\n \"40.84.189.107/32\",\r\n - \ \"40.84.192.116/32\",\r\n \"40.85.180.90/32\",\r\n \"40.85.201.168/32\",\r\n - \ \"40.85.218.175/32\",\r\n \"40.85.248.43/32\",\r\n \"40.86.89.165/32\",\r\n - \ \"40.86.201.128/32\",\r\n \"40.87.67.118/32\",\r\n \"40.87.138.220/32\",\r\n - \ \"40.87.140.215/32\",\r\n \"40.89.153.171/32\",\r\n \"40.89.189.61/32\",\r\n - \ \"40.112.49.101/32\",\r\n \"40.112.74.241/32\",\r\n \"40.113.176.128/28\",\r\n - \ \"40.114.241.141/32\",\r\n \"40.115.54.120/32\",\r\n \"40.115.103.168/32\",\r\n - \ \"40.115.104.31/32\",\r\n \"40.117.80.207/32\",\r\n \"40.117.95.162/32\",\r\n - \ \"40.117.147.74/32\",\r\n \"40.117.190.239/32\",\r\n \"40.117.197.224/32\",\r\n - \ \"40.118.129.58/32\",\r\n \"40.119.4.128/32\",\r\n \"40.119.8.72/31\",\r\n - \ \"40.119.11.160/28\",\r\n \"40.120.75.32/28\",\r\n \"40.121.57.2/32\",\r\n - \ \"40.121.61.208/32\",\r\n \"40.121.135.131/32\",\r\n \"40.121.163.228/32\",\r\n - \ \"40.121.165.150/32\",\r\n \"40.121.210.163/32\",\r\n \"40.126.246.183/32\",\r\n - \ \"40.127.75.125/32\",\r\n \"40.127.84.197/32\",\r\n \"40.127.144.141/32\",\r\n - \ \"51.12.99.72/29\",\r\n \"51.12.203.208/28\",\r\n \"51.12.226.152/29\",\r\n - \ \"51.12.234.152/29\",\r\n \"51.104.8.104/29\",\r\n \"51.104.15.255/32\",\r\n - \ \"51.104.24.68/31\",\r\n \"51.104.29.192/28\",\r\n \"51.104.252.13/32\",\r\n - \ \"51.104.255.249/32\",\r\n \"51.105.66.152/29\",\r\n \"51.105.67.160/29\",\r\n - \ \"51.105.74.152/29\",\r\n \"51.105.75.144/29\",\r\n \"51.105.248.23/32\",\r\n - \ \"51.107.48.68/31\",\r\n \"51.107.51.16/28\",\r\n \"51.107.59.176/28\",\r\n - \ \"51.107.75.144/32\",\r\n \"51.107.75.207/32\",\r\n \"51.107.147.16/28\",\r\n - \ \"51.107.155.176/28\",\r\n \"51.107.156.48/29\",\r\n \"51.116.59.176/28\",\r\n - \ \"51.116.155.240/28\",\r\n \"51.116.242.152/29\",\r\n \"51.116.245.96/28\",\r\n - \ \"51.116.250.152/29\",\r\n \"51.116.253.32/28\",\r\n \"51.120.40.68/31\",\r\n - \ \"51.120.98.0/29\",\r\n \"51.120.98.248/29\",\r\n \"51.120.106.152/29\",\r\n - \ \"51.120.210.152/29\",\r\n \"51.120.219.208/28\",\r\n \"51.137.164.112/28\",\r\n - \ \"51.140.6.23/32\",\r\n \"51.140.54.208/32\",\r\n \"51.140.60.235/32\",\r\n - \ \"51.140.69.144/32\",\r\n \"51.140.148.48/28\",\r\n \"51.140.152.61/32\",\r\n - \ \"51.140.152.186/32\",\r\n \"51.140.163.207/32\",\r\n \"51.140.180.52/32\",\r\n - \ \"51.140.181.40/32\",\r\n \"51.140.211.160/28\",\r\n \"51.140.212.64/29\",\r\n - \ \"51.141.113.128/32\",\r\n \"51.143.88.183/32\",\r\n \"51.143.165.22/32\",\r\n - \ \"51.144.41.38/32\",\r\n \"51.144.81.252/32\",\r\n \"51.145.44.242/32\",\r\n - \ \"52.138.31.112/32\",\r\n \"52.138.31.127/32\",\r\n \"52.138.90.48/30\",\r\n - \ \"52.138.90.56/29\",\r\n \"52.138.222.110/32\",\r\n \"52.138.226.88/29\",\r\n - \ \"52.138.227.128/29\",\r\n \"52.139.8.32/32\",\r\n \"52.140.104.68/31\",\r\n - \ \"52.140.108.96/28\",\r\n \"52.141.22.149/32\",\r\n \"52.141.22.239/32\",\r\n - \ \"52.150.36.187/32\",\r\n \"52.150.152.48/28\",\r\n \"52.151.11.176/32\",\r\n - \ \"52.155.118.97/32\",\r\n \"52.155.162.238/32\",\r\n \"52.156.40.142/32\",\r\n - \ \"52.156.168.82/32\",\r\n \"52.161.8.76/32\",\r\n \"52.161.11.71/32\",\r\n - \ \"52.161.12.245/32\",\r\n \"52.162.87.50/32\",\r\n \"52.162.110.64/28\",\r\n - \ \"52.162.110.168/29\",\r\n \"52.162.214.75/32\",\r\n \"52.163.94.131/32\",\r\n - \ \"52.163.122.20/32\",\r\n \"52.164.120.183/32\",\r\n \"52.164.125.22/32\",\r\n - \ \"52.164.225.5/32\",\r\n \"52.165.27.187/32\",\r\n \"52.165.34.117/32\",\r\n - \ \"52.165.38.20/32\",\r\n \"52.165.150.242/32\",\r\n \"52.167.106.88/29\",\r\n - \ \"52.167.107.64/29\",\r\n \"52.167.221.184/32\",\r\n \"52.168.112.64/32\",\r\n - \ \"52.168.136.177/32\",\r\n \"52.169.4.236/32\",\r\n \"52.169.15.254/32\",\r\n - \ \"52.169.30.110/32\",\r\n \"52.169.64.244/32\",\r\n \"52.171.56.178/32\",\r\n - \ \"52.171.138.167/32\",\r\n \"52.172.209.125/32\",\r\n \"52.173.25.25/32\",\r\n - \ \"52.173.33.254/32\",\r\n \"52.173.90.199/32\",\r\n \"52.173.185.24/32\",\r\n - \ \"52.173.196.209/32\",\r\n \"52.173.196.230/32\",\r\n \"52.173.249.138/32\",\r\n - \ \"52.175.198.74/32\",\r\n \"52.175.231.105/32\",\r\n \"52.175.235.148/32\",\r\n - \ \"52.176.42.206/32\",\r\n \"52.176.46.30/32\",\r\n \"52.176.49.206/32\",\r\n - \ \"52.176.55.135/32\",\r\n \"52.176.92.196/32\",\r\n \"52.177.223.60/32\",\r\n - \ \"52.178.26.73/32\",\r\n \"52.178.37.209/32\",\r\n \"52.179.192.178/32\",\r\n - \ \"52.180.160.132/32\",\r\n \"52.180.164.91/32\",\r\n \"52.180.178.187/32\",\r\n - \ \"52.180.182.209/32\",\r\n \"52.182.138.216/29\",\r\n \"52.182.139.48/29\",\r\n - \ \"52.183.41.109/32\",\r\n \"52.183.66.112/32\",\r\n \"52.183.73.112/32\",\r\n - \ \"52.183.95.86/32\",\r\n \"52.183.127.155/32\",\r\n \"52.184.158.205/32\",\r\n - \ \"52.185.132.101/32\",\r\n \"52.185.132.170/32\",\r\n \"52.185.215.171/32\",\r\n - \ \"52.186.121.41/32\",\r\n \"52.186.126.31/32\",\r\n \"52.188.179.229/32\",\r\n - \ \"52.191.170.253/32\",\r\n \"52.191.197.52/32\",\r\n \"52.224.125.230/32\",\r\n - \ \"52.224.162.220/32\",\r\n \"52.224.235.3/32\",\r\n \"52.226.151.250/32\",\r\n - \ \"52.228.80.68/31\",\r\n \"52.228.85.192/28\",\r\n \"52.229.25.130/32\",\r\n - \ \"52.229.37.75/32\",\r\n \"52.229.218.221/32\",\r\n \"52.229.225.6/32\",\r\n - \ \"52.230.224.237/32\",\r\n \"52.231.18.240/28\",\r\n \"52.231.28.204/32\",\r\n - \ \"52.231.33.16/32\",\r\n \"52.231.64.72/32\",\r\n \"52.231.67.208/32\",\r\n - \ \"52.231.70.0/32\",\r\n \"52.231.108.46/32\",\r\n \"52.231.111.52/32\",\r\n - \ \"52.231.147.160/28\",\r\n \"52.231.148.80/29\",\r\n \"52.232.35.33/32\",\r\n - \ \"52.232.65.133/32\",\r\n \"52.232.106.242/32\",\r\n \"52.236.186.88/29\",\r\n - \ \"52.236.186.208/28\",\r\n \"52.237.34.41/32\",\r\n \"52.237.157.70/32\",\r\n - \ \"52.242.230.209/32\",\r\n \"52.246.154.152/29\",\r\n \"52.246.155.144/29\",\r\n - \ \"52.246.157.16/28\",\r\n \"52.247.202.90/32\",\r\n \"65.52.2.145/32\",\r\n - \ \"65.52.5.76/32\",\r\n \"65.52.122.208/32\",\r\n \"65.52.250.232/29\",\r\n - \ \"65.52.250.240/28\",\r\n \"102.133.27.48/28\",\r\n \"102.133.28.64/29\",\r\n - \ \"102.133.122.152/29\",\r\n \"102.133.123.240/29\",\r\n - \ \"102.133.155.48/28\",\r\n \"102.133.161.73/32\",\r\n \"102.133.162.233/32\",\r\n - \ \"102.133.216.68/31\",\r\n \"102.133.218.144/28\",\r\n - \ \"102.133.250.152/29\",\r\n \"102.133.251.80/29\",\r\n - \ \"104.40.222.36/32\",\r\n \"104.41.61.169/32\",\r\n \"104.41.152.101/32\",\r\n - \ \"104.41.157.59/32\",\r\n \"104.41.224.134/32\",\r\n \"104.42.40.28/32\",\r\n - \ \"104.44.140.84/32\",\r\n \"104.45.136.42/32\",\r\n \"104.45.230.69/32\",\r\n - \ \"104.45.232.72/32\",\r\n \"104.46.123.164/32\",\r\n \"104.208.33.155/32\",\r\n - \ \"104.208.34.98/32\",\r\n \"104.208.35.169/32\",\r\n \"104.209.156.106/32\",\r\n - \ \"104.209.161.217/32\",\r\n \"104.210.9.42/32\",\r\n \"104.211.79.84/32\",\r\n - \ \"104.211.90.234/32\",\r\n \"104.211.91.254/32\",\r\n \"104.211.92.54/32\",\r\n - \ \"104.211.92.218/32\",\r\n \"104.211.95.59/32\",\r\n \"104.211.96.228/32\",\r\n - \ \"104.211.103.96/32\",\r\n \"104.211.147.128/28\",\r\n - \ \"104.211.216.161/32\",\r\n \"104.214.70.219/32\",\r\n - \ \"104.214.104.109/32\",\r\n \"104.215.81.124/32\",\r\n - \ \"104.215.96.105/32\",\r\n \"104.215.100.22/32\",\r\n \"104.215.103.78/32\",\r\n - \ \"104.215.115.118/32\",\r\n \"111.221.88.173/32\",\r\n - \ \"137.116.82.175/32\",\r\n \"137.116.146.215/32\",\r\n - \ \"137.116.151.139/32\",\r\n \"137.116.226.81/32\",\r\n - \ \"137.117.144.33/32\",\r\n \"138.91.9.98/32\",\r\n \"138.91.32.98/32\",\r\n - \ \"138.91.37.93/32\",\r\n \"157.55.177.6/32\",\r\n \"168.61.179.178/32\",\r\n - \ \"168.62.169.17/32\",\r\n \"168.63.174.169/32\",\r\n \"168.63.242.221/32\",\r\n - \ \"191.232.33.83/32\",\r\n \"191.232.161.75/32\",\r\n \"191.232.213.23/32\",\r\n - \ \"191.232.213.239/32\",\r\n \"191.232.214.6/32\",\r\n \"191.232.239.181/32\",\r\n - \ \"191.233.51.128/28\",\r\n \"191.233.203.232/29\",\r\n - \ \"191.233.204.248/29\",\r\n \"191.234.136.80/28\",\r\n - \ \"191.234.146.152/29\",\r\n \"191.234.149.144/28\",\r\n - \ \"191.234.154.152/29\",\r\n \"191.234.157.48/28\",\r\n - \ \"191.235.224.68/31\",\r\n \"191.239.251.90/32\",\r\n \"207.46.224.101/32\",\r\n - \ \"207.46.236.191/32\",\r\n \"2603:1000:104:1::280/122\",\r\n - \ \"2603:1010:6:1::280/122\",\r\n \"2603:1020:5:1::280/122\",\r\n - \ \"2603:1020:206:1::280/122\",\r\n \"2603:1020:705:1::280/122\",\r\n - \ \"2603:1020:805:1::280/122\",\r\n \"2603:1020:a04:1::280/122\",\r\n - \ \"2603:1020:c01:2::b/128\",\r\n \"2603:1020:c01:2::e/128\",\r\n - \ \"2603:1020:c04:1::280/122\",\r\n \"2603:1020:d01:2::a/128\",\r\n - \ \"2603:1020:e04:1::280/122\",\r\n \"2603:1020:1004::280/122\",\r\n - \ \"2603:1030:10:1::280/122\",\r\n \"2603:1030:104:1::280/122\",\r\n - \ \"2603:1030:210:1::280/122\",\r\n \"2603:1030:40b:1::280/122\",\r\n - \ \"2603:1030:40c:1::280/122\",\r\n \"2603:1030:504:1::280/122\",\r\n - \ \"2603:1030:800:5::bfee:a418/128\",\r\n \"2603:1030:800:5::bfee:a42a/128\",\r\n - \ \"2603:1030:800:5::bfee:a435/128\",\r\n \"2603:1030:807:1::280/122\",\r\n - \ \"2603:1030:b00::e8/128\",\r\n \"2603:1030:b00::164/128\",\r\n - \ \"2603:1030:b00::2a1/128\",\r\n \"2603:1030:b00::4db/128\",\r\n - \ \"2603:1030:c02:2::4e1/128\",\r\n \"2603:1030:c06:1::280/122\",\r\n - \ \"2603:1030:d00::1d/128\",\r\n \"2603:1030:d00::48/128\",\r\n - \ \"2603:1030:d00::5a/128\",\r\n \"2603:1030:f05:1::280/122\",\r\n - \ \"2603:1040:5:1::280/122\",\r\n \"2603:1040:407:1::280/122\",\r\n - \ \"2603:1040:904:1::280/122\",\r\n \"2603:1040:a06:1::280/122\",\r\n - \ \"2603:1040:d04::280/122\",\r\n \"2603:1040:f05:1::280/122\",\r\n - \ \"2603:1050:6:1::280/122\",\r\n \"2603:1050:403::280/122\",\r\n - \ \"2a01:111:f100:1003::4134:36c2/128\",\r\n \"2a01:111:f100:1003::4134:36d9/128\",\r\n - \ \"2a01:111:f100:1003::4134:370d/128\",\r\n \"2a01:111:f100:2000::a83e:3015/128\",\r\n - \ \"2a01:111:f100:2000::a83e:301c/128\",\r\n \"2a01:111:f100:2000::a83e:3083/128\",\r\n - \ \"2a01:111:f100:2000::a83e:335c/128\",\r\n \"2a01:111:f100:2000::a83e:3370/128\",\r\n - \ \"2a01:111:f100:2002::8975:2c8c/128\",\r\n \"2a01:111:f100:2002::8975:2d44/128\",\r\n - \ \"2a01:111:f100:2002::8975:2e91/128\",\r\n \"2a01:111:f100:3000::a83e:187a/128\",\r\n - \ \"2a01:111:f100:3000::a83e:187c/128\",\r\n \"2a01:111:f100:3000::a83e:1913/128\",\r\n - \ \"2a01:111:f100:3000::a83e:19c0/128\",\r\n \"2a01:111:f100:3000::a83e:1a55/128\",\r\n - \ \"2a01:111:f100:3000::a83e:1a8e/128\",\r\n \"2a01:111:f100:3000::a83e:1adf/128\",\r\n - \ \"2a01:111:f100:4002::9d37:c0bd/128\",\r\n \"2a01:111:f100:6000::4134:a6cf/128\",\r\n - \ \"2a01:111:f100:7000::6fdd:5343/128\",\r\n \"2a01:111:f100:9001::1761:91e4/128\",\r\n - \ \"2a01:111:f100:a001::4134:e463/128\"\r\n ]\r\n }\r\n - \ },\r\n {\r\n \"name\": \"AzureMonitor.AustraliaCentral\",\r\n - \ \"id\": \"AzureMonitor.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.107.24/29\",\r\n \"20.36.107.160/28\",\r\n - \ \"20.37.227.16/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.AustraliaCentral2\",\r\n \"id\": \"AzureMonitor.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.200/29\",\r\n - \ \"20.36.114.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.AustraliaEast\",\r\n \"id\": \"AzureMonitor.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.232/29\",\r\n - \ \"13.70.73.104/29\",\r\n \"13.70.124.27/32\",\r\n \"13.70.127.61/32\",\r\n - \ \"13.75.195.15/32\",\r\n \"20.37.192.68/31\",\r\n \"20.37.198.112/28\",\r\n - \ \"20.40.124.0/32\",\r\n \"20.43.98.234/32\",\r\n \"20.43.99.158/32\",\r\n - \ \"40.79.162.40/29\",\r\n \"40.79.163.0/29\",\r\n \"40.79.165.64/28\",\r\n - \ \"40.79.170.24/29\",\r\n \"40.79.170.240/29\",\r\n \"40.126.246.183/32\",\r\n - \ \"52.156.168.82/32\",\r\n \"2603:1010:6:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureMonitor.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.52.16/28\",\r\n \"13.77.53.48/29\",\r\n - \ \"13.77.53.220/32\",\r\n \"20.40.160.120/32\",\r\n \"20.42.230.112/28\",\r\n - \ \"23.101.225.155/32\",\r\n \"23.101.232.120/32\",\r\n \"23.101.239.238/32\",\r\n - \ \"40.81.58.225/32\",\r\n \"40.127.75.125/32\",\r\n \"40.127.84.197/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.BrazilSouth\",\r\n - \ \"id\": \"AzureMonitor.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"104.41.61.169/32\",\r\n \"191.232.33.83/32\",\r\n - \ \"191.232.161.75/32\",\r\n \"191.232.213.23/32\",\r\n \"191.232.213.239/32\",\r\n - \ \"191.232.214.6/32\",\r\n \"191.232.239.181/32\",\r\n \"191.233.203.232/29\",\r\n - \ \"191.233.204.248/29\",\r\n \"191.234.136.80/28\",\r\n - \ \"191.234.146.152/29\",\r\n \"191.234.149.144/28\",\r\n - \ \"191.234.154.152/29\",\r\n \"191.234.157.48/28\",\r\n - \ \"191.235.224.68/31\",\r\n \"191.239.251.90/32\",\r\n \"2603:1050:6:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.CanadaCentral\",\r\n - \ \"id\": \"AzureMonitor.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.172.128/28\",\r\n \"13.71.172.248/29\",\r\n - \ \"13.71.175.128/32\",\r\n \"13.71.187.91/32\",\r\n \"13.71.191.47/32\",\r\n - \ \"13.88.230.43/32\",\r\n \"13.88.247.208/32\",\r\n \"13.88.255.115/32\",\r\n - \ \"20.38.146.152/29\",\r\n \"20.38.147.144/29\",\r\n \"40.85.201.168/32\",\r\n - \ \"40.85.218.175/32\",\r\n \"40.85.248.43/32\",\r\n \"52.138.31.112/32\",\r\n - \ \"52.138.31.127/32\",\r\n \"52.139.8.32/32\",\r\n \"52.228.80.68/31\",\r\n - \ \"52.228.85.192/28\",\r\n \"52.237.34.41/32\",\r\n \"52.246.154.152/29\",\r\n - \ \"52.246.155.144/29\",\r\n \"52.246.157.16/28\",\r\n \"2603:1030:f05:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.CanadaEast\",\r\n - \ \"id\": \"AzureMonitor.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.107.16/28\",\r\n \"40.69.108.48/29\",\r\n - \ \"40.86.201.128/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.CentralIndia\",\r\n \"id\": \"AzureMonitor.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.43.120.0/29\",\r\n - \ \"20.43.120.240/29\",\r\n \"20.192.98.152/29\",\r\n \"40.80.50.152/29\",\r\n - \ \"40.80.51.80/29\",\r\n \"52.140.104.68/31\",\r\n \"52.140.108.96/28\",\r\n - \ \"52.172.209.125/32\",\r\n \"104.211.79.84/32\",\r\n \"104.211.90.234/32\",\r\n - \ \"104.211.91.254/32\",\r\n \"104.211.92.54/32\",\r\n \"104.211.92.218/32\",\r\n - \ \"104.211.95.59/32\",\r\n \"104.211.96.228/32\",\r\n \"104.211.103.96/32\",\r\n - \ \"2603:1040:a06:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.CentralUS\",\r\n \"id\": \"AzureMonitor.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.89.42.127/32\",\r\n - \ \"13.89.171.112/30\",\r\n \"13.89.174.128/29\",\r\n \"20.37.152.68/31\",\r\n - \ \"20.40.206.128/28\",\r\n \"20.44.8.0/28\",\r\n \"23.99.130.172/32\",\r\n - \ \"40.77.17.183/32\",\r\n \"40.77.22.234/32\",\r\n \"40.77.24.27/32\",\r\n - \ \"40.77.101.95/32\",\r\n \"40.77.109.134/32\",\r\n \"40.86.89.165/32\",\r\n - \ \"52.165.27.187/32\",\r\n \"52.165.34.117/32\",\r\n \"52.165.38.20/32\",\r\n - \ \"52.165.150.242/32\",\r\n \"52.173.25.25/32\",\r\n \"52.173.33.254/32\",\r\n - \ \"52.173.90.199/32\",\r\n \"52.173.185.24/32\",\r\n \"52.173.196.209/32\",\r\n - \ \"52.173.196.230/32\",\r\n \"52.173.249.138/32\",\r\n \"52.176.42.206/32\",\r\n - \ \"52.176.46.30/32\",\r\n \"52.176.49.206/32\",\r\n \"52.176.55.135/32\",\r\n - \ \"52.176.92.196/32\",\r\n \"52.182.138.216/29\",\r\n \"52.182.139.48/29\",\r\n - \ \"52.230.224.237/32\",\r\n \"52.242.230.209/32\",\r\n \"104.208.33.155/32\",\r\n - \ \"104.208.34.98/32\",\r\n \"104.208.35.169/32\",\r\n \"168.61.179.178/32\",\r\n - \ \"2603:1030:10:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.CentralUSEUAP\",\r\n \"id\": - \"AzureMonitor.CentralUSEUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"40.78.202.144/28\",\r\n \"40.78.203.240/29\",\r\n - \ \"52.180.160.132/32\",\r\n \"52.180.164.91/32\",\r\n \"52.180.178.187/32\",\r\n - \ \"52.180.182.209/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.EastAsia\",\r\n \"id\": \"AzureMonitor.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.75.38.0/28\",\r\n - \ \"13.75.38.120/29\",\r\n \"13.75.39.76/30\",\r\n \"13.75.117.221/32\",\r\n - \ \"13.75.119.169/32\",\r\n \"13.94.39.13/32\",\r\n \"20.189.109.144/28\",\r\n - \ \"23.97.65.103/32\",\r\n \"23.100.90.7/32\",\r\n \"23.100.94.221/32\",\r\n - \ \"23.101.0.142/32\",\r\n \"23.101.9.4/32\",\r\n \"23.101.13.65/32\",\r\n - \ \"52.229.218.221/32\",\r\n \"52.229.225.6/32\",\r\n \"2a01:111:f100:6000::4134:a6cf/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.EastUS\",\r\n - \ \"id\": \"AzureMonitor.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"13.82.100.176/32\",\r\n \"13.82.184.151/32\",\r\n - \ \"13.90.93.206/32\",\r\n \"13.90.248.141/32\",\r\n \"13.90.249.229/32\",\r\n - \ \"13.90.251.123/32\",\r\n \"13.92.40.198/32\",\r\n \"13.92.40.223/32\",\r\n - \ \"13.92.138.16/32\",\r\n \"13.92.179.52/32\",\r\n \"13.92.211.249/32\",\r\n - \ \"13.92.232.146/32\",\r\n \"13.92.254.218/32\",\r\n \"13.92.255.146/32\",\r\n - \ \"20.42.0.68/31\",\r\n \"20.49.109.80/28\",\r\n \"23.96.28.38/32\",\r\n - \ \"40.71.12.224/28\",\r\n \"40.71.12.240/30\",\r\n \"40.71.12.248/29\",\r\n - \ \"40.71.13.168/29\",\r\n \"40.71.14.112/30\",\r\n \"40.71.183.225/32\",\r\n - \ \"40.76.29.55/32\",\r\n \"40.76.53.225/32\",\r\n \"40.78.226.216/29\",\r\n - \ \"40.78.229.32/29\",\r\n \"40.79.154.80/29\",\r\n \"40.79.156.32/29\",\r\n - \ \"40.85.180.90/32\",\r\n \"40.87.67.118/32\",\r\n \"40.112.49.101/32\",\r\n - \ \"40.117.80.207/32\",\r\n \"40.117.95.162/32\",\r\n \"40.117.147.74/32\",\r\n - \ \"40.117.190.239/32\",\r\n \"40.117.197.224/32\",\r\n \"40.121.57.2/32\",\r\n - \ \"40.121.61.208/32\",\r\n \"40.121.135.131/32\",\r\n \"40.121.163.228/32\",\r\n - \ \"40.121.165.150/32\",\r\n \"40.121.210.163/32\",\r\n \"52.150.36.187/32\",\r\n - \ \"52.168.112.64/32\",\r\n \"52.168.136.177/32\",\r\n \"52.186.121.41/32\",\r\n - \ \"52.186.126.31/32\",\r\n \"52.188.179.229/32\",\r\n \"52.191.197.52/32\",\r\n - \ \"52.224.125.230/32\",\r\n \"52.224.162.220/32\",\r\n \"52.224.235.3/32\",\r\n - \ \"52.226.151.250/32\",\r\n \"104.41.152.101/32\",\r\n \"104.41.157.59/32\",\r\n - \ \"104.45.136.42/32\",\r\n \"168.62.169.17/32\",\r\n \"2603:1030:210:1::280/122\",\r\n - \ \"2a01:111:f100:2000::a83e:3015/128\",\r\n \"2a01:111:f100:2000::a83e:301c/128\",\r\n - \ \"2a01:111:f100:2000::a83e:3083/128\",\r\n \"2a01:111:f100:2000::a83e:335c/128\",\r\n - \ \"2a01:111:f100:2000::a83e:3370/128\",\r\n \"2a01:111:f100:2002::8975:2c8c/128\",\r\n - \ \"2a01:111:f100:2002::8975:2d44/128\",\r\n \"2a01:111:f100:2002::8975:2e91/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.EastUS2\",\r\n - \ \"id\": \"AzureMonitor.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"13.68.31.237/32\",\r\n \"13.68.101.211/32\",\r\n - \ \"13.68.106.77/32\",\r\n \"13.68.109.212/32\",\r\n \"13.68.111.247/32\",\r\n - \ \"20.41.49.208/32\",\r\n \"20.44.16.0/29\",\r\n \"20.44.17.0/29\",\r\n - \ \"20.44.73.196/32\",\r\n \"20.49.99.64/28\",\r\n \"40.70.23.205/32\",\r\n - \ \"40.70.148.0/30\",\r\n \"40.70.148.8/29\",\r\n \"52.167.106.88/29\",\r\n - \ \"52.167.107.64/29\",\r\n \"52.167.221.184/32\",\r\n \"52.177.223.60/32\",\r\n - \ \"52.179.192.178/32\",\r\n \"52.184.158.205/32\",\r\n \"104.46.123.164/32\",\r\n - \ \"104.209.156.106/32\",\r\n \"104.209.161.217/32\",\r\n - \ \"104.210.9.42/32\",\r\n \"137.116.82.175/32\",\r\n \"2603:1030:40c:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.EastUS2EUAP\",\r\n - \ \"id\": \"AzureMonitor.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.14.0/28\",\r\n \"40.74.146.84/30\",\r\n - \ \"40.74.147.160/29\",\r\n \"40.75.34.40/29\",\r\n \"40.75.35.64/29\",\r\n - \ \"52.138.90.48/30\",\r\n \"52.138.90.56/29\",\r\n \"2603:1030:40b:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.FranceCentral\",\r\n - \ \"id\": \"AzureMonitor.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"20.40.137.91/32\",\r\n \"20.40.140.212/32\",\r\n - \ \"20.43.40.68/31\",\r\n \"20.43.44.128/28\",\r\n \"20.188.36.28/32\",\r\n - \ \"40.79.130.240/29\",\r\n \"40.79.132.32/29\",\r\n \"40.79.138.40/30\",\r\n - \ \"40.79.138.144/29\",\r\n \"40.79.146.40/30\",\r\n \"40.79.146.144/29\",\r\n - \ \"40.89.153.171/32\",\r\n \"40.89.189.61/32\",\r\n \"2603:1020:805:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.FranceSouth\",\r\n - \ \"id\": \"AzureMonitor.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.179.8/29\",\r\n \"40.79.179.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.GermanyNorth\",\r\n - \ \"id\": \"AzureMonitor.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.59.176/28\",\r\n \"2603:1020:d01:2::a/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.GermanyWestCentral\",\r\n - \ \"id\": \"AzureMonitor.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.155.240/28\",\r\n \"51.116.242.152/29\",\r\n - \ \"51.116.245.96/28\",\r\n \"51.116.250.152/29\",\r\n \"51.116.253.32/28\",\r\n - \ \"2603:1020:c01:2::b/128\",\r\n \"2603:1020:c01:2::e/128\",\r\n - \ \"2603:1020:c04:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.JapanEast\",\r\n \"id\": \"AzureMonitor.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.73.26.213/32\",\r\n - \ \"13.78.10.58/32\",\r\n \"13.78.13.189/32\",\r\n \"13.78.108.160/29\",\r\n - \ \"13.78.108.168/30\",\r\n \"13.78.109.112/29\",\r\n \"13.78.111.192/32\",\r\n - \ \"20.43.64.68/31\",\r\n \"20.43.70.96/28\",\r\n \"23.102.66.132/32\",\r\n - \ \"23.102.77.48/32\",\r\n \"40.79.187.8/29\",\r\n \"40.79.194.104/29\",\r\n - \ \"40.79.194.112/29\",\r\n \"52.155.118.97/32\",\r\n \"52.156.40.142/32\",\r\n - \ \"52.185.132.101/32\",\r\n \"52.185.132.170/32\",\r\n \"138.91.9.98/32\",\r\n - \ \"2603:1040:407:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.JapanWest\",\r\n \"id\": \"AzureMonitor.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"40.74.101.32/28\",\r\n - \ \"40.74.101.200/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.KoreaCentral\",\r\n \"id\": \"AzureMonitor.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.41.64.68/31\",\r\n - \ \"20.41.67.112/28\",\r\n \"20.44.26.152/29\",\r\n \"20.44.26.248/29\",\r\n - \ \"20.194.67.32/28\",\r\n \"52.141.22.149/32\",\r\n \"52.141.22.239/32\",\r\n - \ \"52.231.18.240/28\",\r\n \"52.231.28.204/32\",\r\n \"52.231.33.16/32\",\r\n - \ \"52.231.64.72/32\",\r\n \"52.231.67.208/32\",\r\n \"52.231.70.0/32\",\r\n - \ \"52.231.108.46/32\",\r\n \"52.231.111.52/32\",\r\n \"2603:1040:f05:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.KoreaSouth\",\r\n - \ \"id\": \"AzureMonitor.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.147.160/28\",\r\n \"52.231.148.80/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.NorthCentralUS\",\r\n - \ \"id\": \"AzureMonitor.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"23.96.245.125/32\",\r\n \"23.96.252.161/32\",\r\n - \ \"23.96.252.216/32\",\r\n \"23.100.228.32/32\",\r\n \"40.80.191.224/28\",\r\n - \ \"52.162.87.50/32\",\r\n \"52.162.110.64/28\",\r\n \"52.162.110.168/29\",\r\n - \ \"52.162.214.75/32\",\r\n \"52.237.157.70/32\",\r\n \"65.52.2.145/32\",\r\n - \ \"65.52.5.76/32\",\r\n \"2a01:111:f100:1003::4134:36c2/128\",\r\n - \ \"2a01:111:f100:1003::4134:36d9/128\",\r\n \"2a01:111:f100:1003::4134:370d/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.NorthEurope\",\r\n - \ \"id\": \"AzureMonitor.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.229.64/29\",\r\n \"13.69.229.240/29\",\r\n - \ \"13.69.233.0/30\",\r\n \"13.74.107.88/30\",\r\n \"13.74.108.128/29\",\r\n - \ \"20.38.80.68/31\",\r\n \"20.50.65.80/28\",\r\n \"23.102.44.211/32\",\r\n - \ \"23.102.45.216/32\",\r\n \"40.69.81.159/32\",\r\n \"40.69.194.158/32\",\r\n - \ \"40.87.138.220/32\",\r\n \"40.87.140.215/32\",\r\n \"40.112.74.241/32\",\r\n - \ \"40.115.103.168/32\",\r\n \"40.115.104.31/32\",\r\n \"40.127.144.141/32\",\r\n - \ \"52.138.222.110/32\",\r\n \"52.138.226.88/29\",\r\n \"52.138.227.128/29\",\r\n - \ \"52.155.162.238/32\",\r\n \"52.164.120.183/32\",\r\n \"52.164.125.22/32\",\r\n - \ \"52.164.225.5/32\",\r\n \"52.169.4.236/32\",\r\n \"52.169.15.254/32\",\r\n - \ \"52.169.30.110/32\",\r\n \"52.169.64.244/32\",\r\n \"104.41.224.134/32\",\r\n - \ \"137.116.226.81/32\",\r\n \"2603:1020:5:1::280/122\",\r\n - \ \"2a01:111:f100:a001::4134:e463/128\"\r\n ]\r\n }\r\n - \ },\r\n {\r\n \"name\": \"AzureMonitor.NorwayEast\",\r\n \"id\": - \"AzureMonitor.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"51.120.40.68/31\",\r\n \"51.120.98.0/29\",\r\n \"51.120.98.248/29\",\r\n - \ \"51.120.106.152/29\",\r\n \"51.120.210.152/29\",\r\n \"2603:1020:e04:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.NorwayWest\",\r\n - \ \"id\": \"AzureMonitor.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"51.120.219.208/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.SouthAfricaNorth\",\r\n \"id\": - \"AzureMonitor.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"102.133.122.152/29\",\r\n \"102.133.123.240/29\",\r\n - \ \"102.133.155.48/28\",\r\n \"102.133.161.73/32\",\r\n \"102.133.162.233/32\",\r\n - \ \"102.133.216.68/31\",\r\n \"102.133.218.144/28\",\r\n - \ \"102.133.250.152/29\",\r\n \"102.133.251.80/29\",\r\n - \ \"2603:1000:104:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.SouthAfricaWest\",\r\n \"id\": - \"AzureMonitor.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"102.133.27.48/28\",\r\n \"102.133.28.64/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SouthCentralUS\",\r\n - \ \"id\": \"AzureMonitor.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.96.175/32\",\r\n \"13.65.206.67/32\",\r\n - \ \"13.65.211.125/32\",\r\n \"13.66.36.144/32\",\r\n \"13.66.37.172/32\",\r\n - \ \"13.66.59.226/32\",\r\n \"13.66.60.151/32\",\r\n \"13.73.240.0/29\",\r\n - \ \"13.73.242.32/29\",\r\n \"13.73.244.192/31\",\r\n \"13.84.134.59/32\",\r\n - \ \"13.84.148.7/32\",\r\n \"13.84.149.186/32\",\r\n \"13.84.173.179/32\",\r\n - \ \"13.84.189.95/32\",\r\n \"13.84.225.10/32\",\r\n \"13.85.70.142/32\",\r\n - \ \"20.45.122.152/29\",\r\n \"20.45.123.80/29\",\r\n \"20.45.123.116/30\",\r\n - \ \"20.45.125.224/28\",\r\n \"20.49.91.32/28\",\r\n \"23.100.122.113/32\",\r\n - \ \"23.102.181.197/32\",\r\n \"40.74.249.98/32\",\r\n \"40.84.133.5/32\",\r\n - \ \"40.84.150.47/32\",\r\n \"40.84.189.107/32\",\r\n \"40.84.192.116/32\",\r\n - \ \"40.119.4.128/32\",\r\n \"40.119.8.72/31\",\r\n \"40.119.11.160/28\",\r\n - \ \"52.171.56.178/32\",\r\n \"52.171.138.167/32\",\r\n \"52.185.215.171/32\",\r\n - \ \"104.44.140.84/32\",\r\n \"104.214.70.219/32\",\r\n \"104.214.104.109/32\",\r\n - \ \"104.215.81.124/32\",\r\n \"104.215.96.105/32\",\r\n \"104.215.100.22/32\",\r\n - \ \"104.215.103.78/32\",\r\n \"104.215.115.118/32\",\r\n - \ \"157.55.177.6/32\",\r\n \"2603:1030:800:5::bfee:a418/128\",\r\n - \ \"2603:1030:800:5::bfee:a42a/128\",\r\n \"2603:1030:800:5::bfee:a435/128\",\r\n - \ \"2603:1030:807:1::280/122\",\r\n \"2a01:111:f100:4002::9d37:c0bd/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SoutheastAsia\",\r\n - \ \"id\": \"AzureMonitor.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.9.192/28\",\r\n \"13.67.10.64/29\",\r\n - \ \"13.67.10.92/30\",\r\n \"13.67.15.0/32\",\r\n \"13.67.77.233/32\",\r\n - \ \"13.67.89.191/32\",\r\n \"13.76.85.243/32\",\r\n \"13.76.87.86/32\",\r\n - \ \"20.43.128.68/31\",\r\n \"20.43.152.45/32\",\r\n \"20.44.192.217/32\",\r\n - \ \"23.98.82.120/29\",\r\n \"23.98.82.208/28\",\r\n \"23.98.104.160/28\",\r\n - \ \"40.78.234.56/29\",\r\n \"40.78.234.144/28\",\r\n \"52.163.94.131/32\",\r\n - \ \"52.163.122.20/32\",\r\n \"111.221.88.173/32\",\r\n \"137.116.146.215/32\",\r\n - \ \"137.116.151.139/32\",\r\n \"138.91.32.98/32\",\r\n \"138.91.37.93/32\",\r\n - \ \"168.63.174.169/32\",\r\n \"168.63.242.221/32\",\r\n \"207.46.224.101/32\",\r\n - \ \"207.46.236.191/32\",\r\n \"2603:1040:5:1::280/122\",\r\n - \ \"2a01:111:f100:7000::6fdd:5343/128\"\r\n ]\r\n }\r\n - \ },\r\n {\r\n \"name\": \"AzureMonitor.SouthIndia\",\r\n \"id\": - \"AzureMonitor.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"40.78.195.16/28\",\r\n \"40.78.196.48/29\",\r\n - \ \"104.211.216.161/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.SwitzerlandNorth\",\r\n \"id\": \"AzureMonitor.SwitzerlandNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.107.48.68/31\",\r\n - \ \"51.107.51.16/28\",\r\n \"51.107.59.176/28\",\r\n \"51.107.75.144/32\",\r\n - \ \"51.107.75.207/32\",\r\n \"2603:1020:a04:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SwitzerlandWest\",\r\n - \ \"id\": \"AzureMonitor.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.147.16/28\",\r\n \"51.107.155.176/28\",\r\n - \ \"51.107.156.48/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.UAECentral\",\r\n \"id\": \"AzureMonitor.UAECentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.232/29\",\r\n - \ \"20.37.74.240/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.UAENorth\",\r\n \"id\": \"AzureMonitor.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"40.120.75.32/28\",\r\n - \ \"65.52.250.232/29\",\r\n \"65.52.250.240/28\",\r\n \"2603:1040:904:1::280/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.UKNorth\",\r\n - \ \"id\": \"AzureMonitor.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.87.122.248/29\",\r\n - \ \"13.87.123.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureMonitor.UKSouth\",\r\n \"id\": \"AzureMonitor.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.104.8.104/29\",\r\n - \ \"51.104.15.255/32\",\r\n \"51.104.24.68/31\",\r\n \"51.104.29.192/28\",\r\n - \ \"51.104.252.13/32\",\r\n \"51.104.255.249/32\",\r\n \"51.105.66.152/29\",\r\n - \ \"51.105.67.160/29\",\r\n \"51.105.74.152/29\",\r\n \"51.105.75.144/29\",\r\n - \ \"51.140.6.23/32\",\r\n \"51.140.54.208/32\",\r\n \"51.140.60.235/32\",\r\n - \ \"51.140.69.144/32\",\r\n \"51.140.148.48/28\",\r\n \"51.140.152.61/32\",\r\n - \ \"51.140.152.186/32\",\r\n \"51.140.163.207/32\",\r\n \"51.140.180.52/32\",\r\n - \ \"51.140.181.40/32\",\r\n \"51.143.165.22/32\",\r\n \"51.145.44.242/32\",\r\n - \ \"2603:1020:705:1::280/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureMonitor.UKSouth2\",\r\n \"id\": \"AzureMonitor.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.56.248/29\",\r\n \"13.87.57.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.UKWest\",\r\n - \ \"id\": \"AzureMonitor.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"51.137.164.112/28\",\r\n \"51.140.211.160/28\",\r\n - \ \"51.140.212.64/29\",\r\n \"51.141.113.128/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestCentralUS\",\r\n - \ \"id\": \"AzureMonitor.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.195.192/27\",\r\n \"13.71.196.56/29\",\r\n - \ \"13.71.199.116/32\",\r\n \"13.78.135.15/32\",\r\n \"13.78.145.11/32\",\r\n - \ \"13.78.151.158/32\",\r\n \"13.78.172.58/32\",\r\n \"13.78.189.112/32\",\r\n - \ \"13.78.236.149/32\",\r\n \"13.78.237.51/32\",\r\n \"52.150.152.48/28\",\r\n - \ \"52.161.8.76/32\",\r\n \"52.161.11.71/32\",\r\n \"52.161.12.245/32\",\r\n - \ \"2603:1030:b00::e8/128\",\r\n \"2603:1030:b00::164/128\",\r\n - \ \"2603:1030:b00::2a1/128\",\r\n \"2603:1030:b00::4db/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestEurope\",\r\n - \ \"id\": \"AzureMonitor.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.51.175/32\",\r\n \"13.69.51.218/32\",\r\n - \ \"13.69.65.16/28\",\r\n \"13.69.66.136/29\",\r\n \"13.69.67.60/30\",\r\n - \ \"13.69.67.126/32\",\r\n \"13.69.106.88/29\",\r\n \"13.69.106.208/28\",\r\n - \ \"13.80.134.255/32\",\r\n \"23.101.69.223/32\",\r\n \"40.68.61.229/32\",\r\n - \ \"40.68.154.39/32\",\r\n \"40.74.24.68/31\",\r\n \"40.74.36.208/32\",\r\n - \ \"40.74.59.40/32\",\r\n \"40.113.176.128/28\",\r\n \"40.114.241.141/32\",\r\n - \ \"40.115.54.120/32\",\r\n \"51.105.248.23/32\",\r\n \"51.144.41.38/32\",\r\n - \ \"51.144.81.252/32\",\r\n \"52.178.26.73/32\",\r\n \"52.178.37.209/32\",\r\n - \ \"52.232.35.33/32\",\r\n \"52.232.65.133/32\",\r\n \"52.232.106.242/32\",\r\n - \ \"52.236.186.88/29\",\r\n \"52.236.186.208/28\",\r\n \"104.40.222.36/32\",\r\n - \ \"137.117.144.33/32\",\r\n \"2603:1020:206:1::280/122\",\r\n - \ \"2a01:111:f100:9001::1761:91e4/128\"\r\n ]\r\n }\r\n - \ },\r\n {\r\n \"name\": \"AzureMonitor.WestIndia\",\r\n \"id\": - \"AzureMonitor.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"20.38.128.64/29\",\r\n \"104.211.147.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestUS\",\r\n - \ \"id\": \"AzureMonitor.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"13.86.218.224/28\",\r\n \"13.86.218.248/29\",\r\n - \ \"13.88.177.28/32\",\r\n \"13.91.42.27/32\",\r\n \"13.91.102.27/32\",\r\n - \ \"13.93.215.80/32\",\r\n \"13.93.233.49/32\",\r\n \"13.93.236.73/32\",\r\n - \ \"20.49.120.64/28\",\r\n \"40.78.23.86/32\",\r\n \"40.78.57.61/32\",\r\n - \ \"40.78.107.177/32\",\r\n \"40.118.129.58/32\",\r\n \"65.52.122.208/32\",\r\n - \ \"104.42.40.28/32\",\r\n \"104.45.230.69/32\",\r\n \"104.45.232.72/32\",\r\n - \ \"2a01:111:f100:3000::a83e:187a/128\",\r\n \"2a01:111:f100:3000::a83e:187c/128\",\r\n - \ \"2a01:111:f100:3000::a83e:1913/128\",\r\n \"2a01:111:f100:3000::a83e:19c0/128\",\r\n - \ \"2a01:111:f100:3000::a83e:1a55/128\",\r\n \"2a01:111:f100:3000::a83e:1a8e/128\",\r\n - \ \"2a01:111:f100:3000::a83e:1adf/128\"\r\n ]\r\n }\r\n - \ },\r\n {\r\n \"name\": \"AzureMonitor.WestUS2\",\r\n \"id\": - \"AzureMonitor.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.168/29\",\r\n \"13.66.141.152/29\",\r\n - \ \"13.66.143.218/32\",\r\n \"13.66.160.124/32\",\r\n \"13.66.220.187/32\",\r\n - \ \"13.66.231.27/32\",\r\n \"13.77.150.166/32\",\r\n \"13.77.155.39/32\",\r\n - \ \"13.77.174.177/32\",\r\n \"20.42.128.68/31\",\r\n \"20.190.60.32/32\",\r\n - \ \"20.190.60.38/32\",\r\n \"40.64.132.128/28\",\r\n \"40.78.242.168/30\",\r\n - \ \"40.78.243.16/29\",\r\n \"40.78.250.104/30\",\r\n \"40.78.250.208/29\",\r\n - \ \"51.143.88.183/32\",\r\n \"52.151.11.176/32\",\r\n \"52.175.198.74/32\",\r\n - \ \"52.175.231.105/32\",\r\n \"52.175.235.148/32\",\r\n \"52.183.41.109/32\",\r\n - \ \"52.183.66.112/32\",\r\n \"52.183.73.112/32\",\r\n \"52.183.95.86/32\",\r\n - \ \"52.183.127.155/32\",\r\n \"52.191.170.253/32\",\r\n \"52.229.25.130/32\",\r\n - \ \"52.229.37.75/32\",\r\n \"52.247.202.90/32\",\r\n \"2603:1030:c02:2::4e1/128\",\r\n - \ \"2603:1030:c06:1::280/122\",\r\n \"2603:1030:d00::1d/128\",\r\n - \ \"2603:1030:d00::48/128\",\r\n \"2603:1030:d00::5a/128\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets\",\r\n - \ \"id\": \"AzureOpenDatasets\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"13.73.248.32/28\",\r\n \"20.36.120.192/28\",\r\n - \ \"20.37.64.192/28\",\r\n \"20.37.156.224/28\",\r\n \"20.37.195.32/28\",\r\n - \ \"20.37.224.192/28\",\r\n \"20.38.84.112/28\",\r\n \"20.38.136.192/28\",\r\n - \ \"20.39.11.32/28\",\r\n \"20.41.4.192/28\",\r\n \"20.41.65.160/28\",\r\n - \ \"20.41.193.128/28\",\r\n \"20.42.4.224/28\",\r\n \"20.42.131.0/28\",\r\n - \ \"20.42.227.0/28\",\r\n \"20.43.41.160/28\",\r\n \"20.43.65.160/28\",\r\n - \ \"20.43.130.112/28\",\r\n \"20.45.112.192/28\",\r\n \"20.45.192.192/28\",\r\n - \ \"20.150.160.192/28\",\r\n \"20.189.106.208/28\",\r\n \"20.192.225.128/28\",\r\n - \ \"40.67.48.192/28\",\r\n \"40.74.30.112/28\",\r\n \"40.80.57.128/28\",\r\n - \ \"40.80.169.128/28\",\r\n \"40.80.188.32/28\",\r\n \"40.82.253.80/28\",\r\n - \ \"40.89.17.128/28\",\r\n \"51.12.41.32/28\",\r\n \"51.12.193.32/28\",\r\n - \ \"51.104.25.160/28\",\r\n \"51.105.80.192/28\",\r\n \"51.105.88.192/28\",\r\n - \ \"51.107.48.192/28\",\r\n \"51.107.144.192/28\",\r\n \"51.116.48.112/28\",\r\n - \ \"51.116.144.112/28\",\r\n \"51.120.40.192/28\",\r\n \"51.120.224.192/28\",\r\n - \ \"51.137.161.144/28\",\r\n \"51.143.192.192/28\",\r\n \"52.136.48.192/28\",\r\n - \ \"52.140.105.128/28\",\r\n \"52.150.139.80/28\",\r\n \"52.228.81.144/28\",\r\n - \ \"102.133.56.112/28\",\r\n \"102.133.216.112/28\",\r\n - \ \"191.235.225.160/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureOpenDatasets.AustraliaCentral\",\r\n \"id\": \"AzureOpenDatasets.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"20.37.224.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.AustraliaCentral2\",\r\n - \ \"id\": \"AzureOpenDatasets.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.120.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.AustraliaEast\",\r\n - \ \"id\": \"AzureOpenDatasets.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.195.32/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureOpenDatasets.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.227.0/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.BrazilSouth\",\r\n - \ \"id\": \"AzureOpenDatasets.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"191.235.225.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CanadaCentral\",\r\n - \ \"id\": \"AzureOpenDatasets.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"52.228.81.144/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CanadaEast\",\r\n - \ \"id\": \"AzureOpenDatasets.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"40.89.17.128/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CentralIndia\",\r\n - \ \"id\": \"AzureOpenDatasets.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"52.140.105.128/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CentralUS\",\r\n - \ \"id\": \"AzureOpenDatasets.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.156.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CentralUSEUAP\",\r\n - \ \"id\": \"AzureOpenDatasets.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.192.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.EastAsia\",\r\n - \ \"id\": \"AzureOpenDatasets.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.106.208/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.EastUS\",\r\n - \ \"id\": \"AzureOpenDatasets.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"20.42.4.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureOpenDatasets.EastUS2\",\r\n \"id\": \"AzureOpenDatasets.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"20.41.4.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.EastUS2EUAP\",\r\n - \ \"id\": \"AzureOpenDatasets.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.11.32/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.FranceCentral\",\r\n - \ \"id\": \"AzureOpenDatasets.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.41.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.FranceSouth\",\r\n - \ \"id\": \"AzureOpenDatasets.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.88.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.GermanyNorth\",\r\n - \ \"id\": \"AzureOpenDatasets.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.48.112/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.GermanyWestCentral\",\r\n - \ \"id\": \"AzureOpenDatasets.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.144.112/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.JapanEast\",\r\n - \ \"id\": \"AzureOpenDatasets.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.65.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.JapanWest\",\r\n - \ \"id\": \"AzureOpenDatasets.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.57.128/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.KoreaCentral\",\r\n - \ \"id\": \"AzureOpenDatasets.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.65.160/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.KoreaSouth\",\r\n - \ \"id\": \"AzureOpenDatasets.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.169.128/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.NorthCentralUS\",\r\n - \ \"id\": \"AzureOpenDatasets.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.188.32/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.NorthEurope\",\r\n - \ \"id\": \"AzureOpenDatasets.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.84.112/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.NorwayEast\",\r\n - \ \"id\": \"AzureOpenDatasets.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"51.120.40.192/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.NorwayWest\",\r\n \"id\": - \"AzureOpenDatasets.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"51.120.224.192/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.SouthAfricaNorth\",\r\n \"id\": - \"AzureOpenDatasets.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"102.133.216.112/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.SouthAfricaWest\",\r\n \"id\": - \"AzureOpenDatasets.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"102.133.56.112/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.SouthCentralUS\",\r\n \"id\": - \"AzureOpenDatasets.SouthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"13.73.248.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureOpenDatasets.SoutheastAsia\",\r\n \"id\": \"AzureOpenDatasets.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"20.43.130.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SouthIndia\",\r\n - \ \"id\": \"AzureOpenDatasets.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.193.128/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureOpenDatasets.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SwitzerlandWest\",\r\n - \ \"id\": \"AzureOpenDatasets.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.144.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UAECentral\",\r\n - \ \"id\": \"AzureOpenDatasets.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UAENorth\",\r\n - \ \"id\": \"AzureOpenDatasets.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UKNorth\",\r\n - \ \"id\": \"AzureOpenDatasets.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"51.105.80.192/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.UKSouth\",\r\n \"id\": \"AzureOpenDatasets.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"51.104.25.160/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UKSouth2\",\r\n - \ \"id\": \"AzureOpenDatasets.UKSouth2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n - \ \"addressPrefixes\": [\r\n \"51.143.192.192/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UKWest\",\r\n - \ \"id\": \"AzureOpenDatasets.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"51.137.161.144/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.WestCentralUS\",\r\n \"id\": - \"AzureOpenDatasets.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"52.150.139.80/28\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzureOpenDatasets.WestEurope\",\r\n \"id\": - \"AzureOpenDatasets.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"40.74.30.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureOpenDatasets.WestIndia\",\r\n \"id\": \"AzureOpenDatasets.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"52.136.48.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.WestUS\",\r\n - \ \"id\": \"AzureOpenDatasets.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": - [\r\n \"40.82.253.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureOpenDatasets.WestUS2\",\r\n \"id\": \"AzureOpenDatasets.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"20.42.131.0/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.AustraliaCentral\",\r\n - \ \"id\": \"AzurePortal.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.225.128/27\",\r\n \"20.37.226.56/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.AustraliaCentral2\",\r\n - \ \"id\": \"AzurePortal.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.121.128/27\",\r\n \"20.36.122.56/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.AustraliaEast\",\r\n - \ \"id\": \"AzurePortal.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.195.224/27\",\r\n \"20.37.196.252/30\",\r\n - \ \"20.37.198.64/27\",\r\n \"2603:1010:6::100/121\",\r\n - \ \"2603:1010:6:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.AustraliaSoutheast\",\r\n \"id\": - \"AzurePortal.AustraliaSoutheast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiasoutheast\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"13.77.1.236/32\",\r\n \"13.77.55.208/28\",\r\n \"20.42.227.192/27\",\r\n - \ \"20.42.228.220/30\",\r\n \"20.42.228.224/27\",\r\n \"20.42.230.80/28\",\r\n - \ \"52.243.76.246/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.BrazilSouth\",\r\n \"id\": \"AzurePortal.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"191.234.136.0/27\",\r\n - \ \"191.234.136.48/30\",\r\n \"191.235.227.160/27\",\r\n - \ \"2603:1050:6::100/121\",\r\n \"2603:1050:6:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.CanadaCentral\",\r\n - \ \"id\": \"AzurePortal.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.149.208/28\",\r\n \"52.228.83.160/27\",\r\n - \ \"52.228.84.84/30\",\r\n \"52.228.84.96/28\",\r\n \"2603:1030:f05::100/121\",\r\n - \ \"2603:1030:f05:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.CanadaEast\",\r\n \"id\": \"AzurePortal.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"40.89.18.160/27\",\r\n - \ \"40.89.20.132/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.CentralIndia\",\r\n \"id\": \"AzurePortal.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"40.80.53.16/28\",\r\n - \ \"52.140.105.224/27\",\r\n \"52.140.107.112/28\",\r\n \"52.140.108.64/30\",\r\n - \ \"52.172.190.71/32\",\r\n \"52.172.191.4/32\",\r\n \"104.211.89.213/32\",\r\n - \ \"104.211.101.116/32\",\r\n \"2603:1040:a06::200/121\",\r\n - \ \"2603:1040:a06:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.CentralUS\",\r\n \"id\": \"AzurePortal.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.40.200.0/27\",\r\n - \ \"20.40.200.160/30\",\r\n \"2603:1030:10::100/121\",\r\n - \ \"2603:1030:10:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.CentralUSEUAP\",\r\n \"id\": \"AzurePortal.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.45.195.160/27\",\r\n - \ \"20.45.197.192/27\",\r\n \"20.45.197.228/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastAsia\",\r\n - \ \"id\": \"AzurePortal.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"13.88.220.109/32\",\r\n \"13.88.222.0/32\",\r\n - \ \"20.189.108.96/27\",\r\n \"20.189.109.88/30\",\r\n \"20.189.109.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastUS\",\r\n - \ \"id\": \"AzurePortal.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"13.68.130.251/32\",\r\n \"13.68.235.98/32\",\r\n - \ \"13.90.156.71/32\",\r\n \"13.92.138.76/32\",\r\n \"20.42.6.192/27\",\r\n - \ \"20.49.109.36/30\",\r\n \"20.49.109.44/31\",\r\n \"20.49.109.48/28\",\r\n - \ \"40.71.15.144/28\",\r\n \"40.114.78.132/32\",\r\n \"40.117.86.243/32\",\r\n - \ \"40.117.237.78/32\",\r\n \"2603:1030:210::100/121\",\r\n - \ \"2603:1030:210:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.EastUS2\",\r\n \"id\": \"AzurePortal.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.41.5.192/27\",\r\n - \ \"20.44.19.32/28\",\r\n \"20.49.99.16/28\",\r\n \"20.49.99.32/30\",\r\n - \ \"2603:1030:40c::100/121\",\r\n \"2603:1030:40c:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastUS2EUAP\",\r\n - \ \"id\": \"AzurePortal.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.12.32/27\",\r\n \"20.39.12.232/30\",\r\n - \ \"2603:1030:40b:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.FranceCentral\",\r\n \"id\": \"AzurePortal.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.43.42.64/27\",\r\n - \ \"20.43.43.164/30\",\r\n \"2603:1020:805::100/121\",\r\n - \ \"2603:1020:805:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.FranceSouth\",\r\n \"id\": \"AzurePortal.FranceSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.105.89.160/27\",\r\n - \ \"51.105.90.152/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.GermanyNorth\",\r\n \"id\": \"AzurePortal.GermanyNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanyn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.116.48.192/27\",\r\n - \ \"51.116.49.140/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.JapanEast\",\r\n \"id\": \"AzurePortal.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.78.49.187/32\",\r\n - \ \"20.43.66.64/27\",\r\n \"20.43.67.92/30\",\r\n \"20.43.67.96/27\",\r\n - \ \"20.43.70.64/28\",\r\n \"23.102.65.134/32\",\r\n \"40.79.189.96/28\",\r\n - \ \"2603:1040:407::100/121\",\r\n \"2603:1040:407:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.JapanWest\",\r\n - \ \"id\": \"AzurePortal.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"40.80.58.128/27\",\r\n \"40.80.59.28/30\",\r\n \"40.80.59.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.KoreaCentral\",\r\n - \ \"id\": \"AzurePortal.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.65.224/27\",\r\n \"20.41.67.88/30\",\r\n - \ \"2603:1040:f05::100/121\",\r\n \"2603:1040:f05:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.KoreaSouth\",\r\n - \ \"id\": \"AzurePortal.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"40.80.169.224/27\",\r\n \"40.80.172.16/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorthCentralUS\",\r\n - \ \"id\": \"AzurePortal.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.190.160/27\",\r\n \"40.80.191.200/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorthEurope\",\r\n - \ \"id\": \"AzurePortal.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.85.192/27\",\r\n \"20.38.87.224/27\",\r\n - \ \"20.50.65.72/30\",\r\n \"104.41.216.228/32\",\r\n \"137.116.247.179/32\",\r\n - \ \"2603:1020:5::100/121\",\r\n \"2603:1020:5:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorwayEast\",\r\n - \ \"id\": \"AzurePortal.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.120.41.160/27\",\r\n \"51.120.42.60/30\",\r\n - \ \"2603:1020:e04::100/121\",\r\n \"2603:1020:e04:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorwayWest\",\r\n - \ \"id\": \"AzurePortal.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.120.225.128/27\",\r\n \"51.120.226.56/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.SouthAfricaWest\",\r\n - \ \"id\": \"AzurePortal.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.56.160/27\",\r\n \"102.133.58.192/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.SouthCentralUS\",\r\n - \ \"id\": \"AzurePortal.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.249.32/27\",\r\n \"13.73.249.160/28\",\r\n - \ \"20.45.125.240/28\",\r\n \"40.84.132.239/32\",\r\n \"40.84.228.255/32\",\r\n - \ \"40.119.9.236/30\",\r\n \"104.214.117.155/32\",\r\n \"104.215.120.160/32\",\r\n - \ \"2603:1030:807::100/121\",\r\n \"2603:1030:807:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.SoutheastAsia\",\r\n - \ \"id\": \"AzurePortal.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.35.35/32\",\r\n \"13.67.35.77/32\",\r\n - \ \"20.43.132.32/27\",\r\n \"23.98.104.80/28\",\r\n \"23.98.104.96/27\",\r\n - \ \"23.98.104.128/30\",\r\n \"40.78.239.48/28\",\r\n \"52.163.207.80/32\",\r\n - \ \"104.215.146.128/32\",\r\n \"2603:1040:5::200/121\",\r\n - \ \"2603:1040:5:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.SouthIndia\",\r\n \"id\": \"AzurePortal.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.41.193.224/27\",\r\n - \ \"20.41.197.16/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.SwitzerlandNorth\",\r\n \"id\": \"AzurePortal.SwitzerlandNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.107.49.160/27\",\r\n - \ \"51.107.50.60/30\",\r\n \"2603:1020:a04::100/121\",\r\n - \ \"2603:1020:a04:1::680/121\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"AzurePortal.SwitzerlandWest\",\r\n \"id\": - \"AzurePortal.SwitzerlandWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.107.145.128/27\",\r\n \"51.107.146.56/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UAECentral\",\r\n - \ \"id\": \"AzurePortal.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"20.37.65.128/27\",\r\n \"20.37.66.56/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UAENorth\",\r\n - \ \"id\": \"AzurePortal.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"20.38.137.160/27\",\r\n \"20.38.138.60/30\",\r\n - \ \"2603:1040:904::100/121\",\r\n \"2603:1040:904:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UKNorth\",\r\n - \ \"id\": \"AzurePortal.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.105.80.124/30\",\r\n \"51.105.81.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UKSouth\",\r\n - \ \"id\": \"AzurePortal.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.104.27.96/27\",\r\n \"51.104.28.220/30\",\r\n - \ \"51.104.28.224/28\",\r\n \"51.140.69.25/32\",\r\n \"51.140.138.84/32\",\r\n - \ \"51.140.149.64/28\",\r\n \"51.145.3.27/32\",\r\n \"51.145.21.195/32\",\r\n - \ \"2603:1020:705::100/121\",\r\n \"2603:1020:705:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UKSouth2\",\r\n - \ \"id\": \"AzurePortal.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.143.192.124/30\",\r\n \"51.143.193.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UKWest\",\r\n - \ \"id\": \"AzurePortal.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"51.137.162.160/27\",\r\n \"51.137.164.80/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestCentralUS\",\r\n - \ \"id\": \"AzurePortal.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.202.2/32\",\r\n \"13.78.132.155/32\",\r\n - \ \"13.78.230.142/32\",\r\n \"40.67.121.128/28\",\r\n \"52.150.139.224/27\",\r\n - \ \"52.150.140.216/30\",\r\n \"52.150.152.16/28\",\r\n \"52.150.152.224/27\",\r\n - \ \"52.161.101.86/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzurePortal.WestEurope\",\r\n \"id\": \"AzurePortal.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.69.112.176/28\",\r\n - \ \"13.69.126.92/32\",\r\n \"20.50.1.32/27\",\r\n \"20.50.1.160/27\",\r\n - \ \"20.50.1.200/30\",\r\n \"20.50.1.208/28\",\r\n \"40.113.117.57/32\",\r\n - \ \"40.114.236.251/32\",\r\n \"213.199.128.226/32\",\r\n - \ \"2603:1020:206::100/121\",\r\n \"2603:1020:206:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestIndia\",\r\n - \ \"id\": \"AzurePortal.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"52.136.49.160/27\",\r\n \"52.136.51.72/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestUS2\",\r\n - \ \"id\": \"AzurePortal.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": - [\r\n \"40.64.128.128/27\",\r\n \"40.64.132.88/30\",\r\n - \ \"40.64.132.96/28\",\r\n \"40.65.114.234/32\",\r\n \"40.78.245.208/28\",\r\n - \ \"52.233.66.46/32\",\r\n \"2603:1030:c06:1::680/121\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager\",\r\n - \ \"id\": \"AzureResourceManager\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureResourceManager\",\r\n \"addressPrefixes\": [\r\n \"13.66.141.176/28\",\r\n - \ \"13.67.18.0/23\",\r\n \"13.69.67.32/28\",\r\n \"13.69.114.0/23\",\r\n - \ \"13.69.229.224/28\",\r\n \"13.69.234.0/23\",\r\n \"13.70.74.64/28\",\r\n - \ \"13.70.76.0/23\",\r\n \"13.71.173.192/28\",\r\n \"13.71.196.80/28\",\r\n - \ \"13.71.198.0/24\",\r\n \"13.73.240.224/28\",\r\n \"13.73.246.0/23\",\r\n - \ \"13.75.39.16/28\",\r\n \"13.77.53.32/28\",\r\n \"13.77.55.0/25\",\r\n - \ \"13.78.109.96/28\",\r\n \"13.86.219.80/28\",\r\n \"13.86.222.0/24\",\r\n - \ \"13.87.57.240/28\",\r\n \"13.87.60.0/23\",\r\n \"13.87.123.240/28\",\r\n - \ \"13.87.126.0/24\",\r\n \"13.89.180.0/23\",\r\n \"20.36.108.48/28\",\r\n - \ \"20.36.110.0/23\",\r\n \"20.36.115.144/28\",\r\n \"20.36.118.0/23\",\r\n - \ \"20.37.76.48/28\",\r\n \"20.37.78.0/23\",\r\n \"20.38.128.32/28\",\r\n - \ \"20.38.130.0/23\",\r\n \"20.38.150.0/23\",\r\n \"20.43.120.224/28\",\r\n - \ \"20.43.124.0/23\",\r\n \"20.44.3.240/28\",\r\n \"20.44.6.0/23\",\r\n - \ \"20.44.8.16/28\",\r\n \"20.44.16.112/28\",\r\n \"20.44.20.0/23\",\r\n - \ \"20.44.30.0/24\",\r\n \"20.150.172.32/28\",\r\n \"20.150.174.0/23\",\r\n - \ \"20.189.168.0/24\",\r\n \"20.192.236.0/23\",\r\n \"20.193.204.0/23\",\r\n - \ \"40.67.59.208/28\",\r\n \"40.67.62.0/23\",\r\n \"40.67.120.0/24\",\r\n - \ \"40.69.108.32/28\",\r\n \"40.69.112.0/22\",\r\n \"40.71.13.224/28\",\r\n - \ \"40.74.102.0/28\",\r\n \"40.75.35.32/28\",\r\n \"40.75.38.0/23\",\r\n - \ \"40.78.196.32/28\",\r\n \"40.78.198.0/23\",\r\n \"40.78.203.224/28\",\r\n - \ \"40.78.206.0/23\",\r\n \"40.78.234.176/28\",\r\n \"40.78.254.0/23\",\r\n - \ \"40.79.131.240/28\",\r\n \"40.79.134.0/23\",\r\n \"40.79.158.0/23\",\r\n - \ \"40.79.180.0/28\",\r\n \"40.79.182.0/23\",\r\n \"40.79.198.0/23\",\r\n - \ \"40.80.178.0/23\",\r\n \"51.11.64.0/24\",\r\n \"51.11.96.0/24\",\r\n - \ \"51.12.102.0/23\",\r\n \"51.12.206.0/23\",\r\n \"51.104.8.224/28\",\r\n - \ \"51.105.78.0/23\",\r\n \"51.107.60.32/28\",\r\n \"51.107.62.0/23\",\r\n - \ \"51.107.156.32/28\",\r\n \"51.107.158.0/23\",\r\n \"51.116.60.32/28\",\r\n - \ \"51.116.62.0/23\",\r\n \"51.116.156.32/28\",\r\n \"51.116.159.0/24\",\r\n - \ \"51.120.100.32/28\",\r\n \"51.120.102.0/23\",\r\n \"51.120.220.32/28\",\r\n - \ \"51.120.222.0/23\",\r\n \"51.140.212.16/28\",\r\n \"51.140.214.0/24\",\r\n - \ \"52.138.94.0/23\",\r\n \"52.147.96.0/24\",\r\n \"52.162.110.224/28\",\r\n - \ \"52.231.19.208/28\",\r\n \"52.231.22.0/24\",\r\n \"52.231.148.64/28\",\r\n - \ \"52.231.150.0/24\",\r\n \"52.240.242.0/23\",\r\n \"65.52.252.48/28\",\r\n - \ \"65.52.254.0/23\",\r\n \"102.133.28.16/28\",\r\n \"102.133.30.0/23\",\r\n - \ \"102.133.123.224/28\",\r\n \"102.133.158.0/23\",\r\n \"104.46.160.0/24\",\r\n - \ \"104.46.161.0/25\",\r\n \"104.214.162.0/23\",\r\n \"168.61.138.0/23\",\r\n - \ \"191.233.52.0/23\",\r\n \"191.233.205.16/28\",\r\n \"191.234.158.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.AustraliaCentral\",\r\n - \ \"id\": \"AzureResourceManager.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.36.108.48/28\",\r\n \"20.36.110.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.AustraliaCentral2\",\r\n - \ \"id\": \"AzureResourceManager.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.36.115.144/28\",\r\n \"20.36.118.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.AustraliaSoutheast\",\r\n - \ \"id\": \"AzureResourceManager.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.77.53.32/28\",\r\n \"13.77.55.0/25\",\r\n \"104.46.160.0/24\",\r\n - \ \"104.46.161.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureResourceManager.BrazilSouth\",\r\n \"id\": \"AzureResourceManager.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.205.16/28\",\r\n \"191.234.158.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CanadaCentral\",\r\n - \ \"id\": \"AzureResourceManager.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.71.173.192/28\",\r\n \"20.38.150.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CanadaEast\",\r\n - \ \"id\": \"AzureResourceManager.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.69.108.32/28\",\r\n \"40.69.112.0/22\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CentralIndia\",\r\n - \ \"id\": \"AzureResourceManager.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.43.120.224/28\",\r\n \"20.43.124.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CentralUS\",\r\n - \ \"id\": \"AzureResourceManager.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.89.180.0/23\",\r\n \"20.44.8.16/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CentralUSEUAP\",\r\n - \ \"id\": \"AzureResourceManager.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.78.203.224/28\",\r\n \"40.78.206.0/23\",\r\n - \ \"168.61.138.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureResourceManager.EastAsia\",\r\n \"id\": \"AzureResourceManager.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.39.16/28\",\r\n \"104.214.162.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.EastUS\",\r\n - \ \"id\": \"AzureResourceManager.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.71.13.224/28\",\r\n \"40.79.158.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.EastUS2\",\r\n - \ \"id\": \"AzureResourceManager.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.44.16.112/28\",\r\n \"20.44.20.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.EastUS2EUAP\",\r\n - \ \"id\": \"AzureResourceManager.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.75.35.32/28\",\r\n \"40.75.38.0/23\",\r\n \"52.138.94.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.FranceCentral\",\r\n - \ \"id\": \"AzureResourceManager.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.79.131.240/28\",\r\n \"40.79.134.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.GermanyNorth\",\r\n - \ \"id\": \"AzureResourceManager.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"51.116.60.32/28\",\r\n \"51.116.62.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.GermanyWestCentral\",\r\n - \ \"id\": \"AzureResourceManager.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"51.116.156.32/28\",\r\n \"51.116.159.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.JapanEast\",\r\n - \ \"id\": \"AzureResourceManager.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.78.109.96/28\",\r\n \"40.79.198.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.JapanWest\",\r\n - \ \"id\": \"AzureResourceManager.JapanWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.74.102.0/28\",\r\n \"40.80.178.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.KoreaCentral\",\r\n - \ \"id\": \"AzureResourceManager.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.44.30.0/24\",\r\n \"52.231.19.208/28\",\r\n \"52.231.22.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.KoreaSouth\",\r\n - \ \"id\": \"AzureResourceManager.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"52.147.96.0/24\",\r\n \"52.231.148.64/28\",\r\n - \ \"52.231.150.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureResourceManager.NorthCentralUS\",\r\n \"id\": - \"AzureResourceManager.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureResourceManager\",\r\n \"addressPrefixes\": [\r\n \"52.162.110.224/28\",\r\n - \ \"52.240.242.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureResourceManager.NorthEurope\",\r\n \"id\": \"AzureResourceManager.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.229.224/28\",\r\n \"13.69.234.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SouthAfricaNorth\",\r\n - \ \"id\": \"AzureResourceManager.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"102.133.123.224/28\",\r\n \"102.133.158.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SouthAfricaWest\",\r\n - \ \"id\": \"AzureResourceManager.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"102.133.28.16/28\",\r\n \"102.133.30.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SouthCentralUS\",\r\n - \ \"id\": \"AzureResourceManager.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.73.240.224/28\",\r\n \"13.73.246.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SoutheastAsia\",\r\n - \ \"id\": \"AzureResourceManager.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.67.18.0/23\",\r\n \"40.78.234.176/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SouthIndia\",\r\n - \ \"id\": \"AzureResourceManager.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"40.78.196.32/28\",\r\n \"40.78.198.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SwitzerlandNorth\",\r\n - \ \"id\": \"AzureResourceManager.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"51.107.60.32/28\",\r\n \"51.107.62.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.SwitzerlandWest\",\r\n - \ \"id\": \"AzureResourceManager.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"51.107.156.32/28\",\r\n \"51.107.158.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.UAECentral\",\r\n - \ \"id\": \"AzureResourceManager.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.37.76.48/28\",\r\n \"20.37.78.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.UKNorth\",\r\n - \ \"id\": \"AzureResourceManager.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.87.123.240/28\",\r\n \"13.87.126.0/24\",\r\n - \ \"51.11.64.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureResourceManager.UKSouth2\",\r\n \"id\": \"AzureResourceManager.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.57.240/28\",\r\n \"13.87.60.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.UKWest\",\r\n - \ \"id\": \"AzureResourceManager.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"51.11.96.0/24\",\r\n \"51.140.212.16/28\",\r\n \"51.140.214.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestCentralUS\",\r\n - \ \"id\": \"AzureResourceManager.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.71.196.80/28\",\r\n \"13.71.198.0/24\",\r\n \"40.67.120.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestEurope\",\r\n - \ \"id\": \"AzureResourceManager.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.69.67.32/28\",\r\n \"13.69.114.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestIndia\",\r\n - \ \"id\": \"AzureResourceManager.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"20.38.128.32/28\",\r\n \"20.38.130.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestUS\",\r\n - \ \"id\": \"AzureResourceManager.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.86.219.80/28\",\r\n \"13.86.222.0/24\",\r\n \"20.189.168.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestUS2\",\r\n - \ \"id\": \"AzureResourceManager.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\": - [\r\n \"13.66.141.176/28\",\r\n \"40.78.254.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR\",\r\n \"id\": - \"AzureSignalR\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"13.66.145.0/26\",\r\n - \ \"13.69.113.0/24\",\r\n \"13.69.232.128/25\",\r\n \"13.70.74.224/27\",\r\n - \ \"13.71.199.32/27\",\r\n \"13.73.244.64/27\",\r\n \"13.74.111.0/25\",\r\n - \ \"13.78.109.224/27\",\r\n \"13.89.175.128/26\",\r\n \"20.42.64.128/25\",\r\n - \ \"20.42.72.0/25\",\r\n \"20.44.10.128/26\",\r\n \"20.44.17.128/26\",\r\n - \ \"20.45.123.192/27\",\r\n \"20.189.170.0/24\",\r\n \"40.69.108.192/26\",\r\n - \ \"40.69.110.128/27\",\r\n \"40.70.148.192/26\",\r\n \"40.71.15.0/25\",\r\n - \ \"40.78.204.96/27\",\r\n \"40.78.238.64/26\",\r\n \"40.78.238.128/25\",\r\n - \ \"40.78.245.64/26\",\r\n \"40.78.253.0/26\",\r\n \"40.79.132.160/27\",\r\n - \ \"40.79.139.96/27\",\r\n \"40.79.148.32/27\",\r\n \"40.79.163.96/27\",\r\n - \ \"40.79.171.192/27\",\r\n \"40.79.189.0/27\",\r\n \"40.79.197.0/27\",\r\n - \ \"51.104.9.64/27\",\r\n \"51.105.69.32/27\",\r\n \"51.105.77.0/27\",\r\n - \ \"52.138.229.128/25\",\r\n \"52.167.109.0/26\",\r\n \"52.178.16.0/24\",\r\n - \ \"52.182.141.64/26\",\r\n \"52.231.20.96/27\",\r\n \"52.231.20.192/26\",\r\n - \ \"52.236.190.0/24\",\r\n \"191.233.207.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.AustraliaEast\",\r\n - \ \"id\": \"AzureSignalR.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.74.224/27\",\r\n \"40.79.163.96/27\",\r\n - \ \"40.79.171.192/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.BrazilSouth\",\r\n \"id\": \"AzureSignalR.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.207.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.CanadaEast\",\r\n - \ \"id\": \"AzureSignalR.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": - [\r\n \"40.69.108.192/26\",\r\n \"40.69.110.128/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.CentralUS\",\r\n - \ \"id\": \"AzureSignalR.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"13.89.175.128/26\",\r\n - \ \"20.44.10.128/26\",\r\n \"52.182.141.64/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.CentralUSEUAP\",\r\n - \ \"id\": \"AzureSignalR.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": - [\r\n \"40.78.204.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.EastUS\",\r\n \"id\": \"AzureSignalR.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.64.128/25\",\r\n \"20.42.72.0/25\",\r\n - \ \"40.71.15.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.EastUS2\",\r\n \"id\": \"AzureSignalR.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.17.128/26\",\r\n \"40.70.148.192/26\",\r\n - \ \"52.167.109.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.FranceCentral\",\r\n \"id\": \"AzureSignalR.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.132.160/27\",\r\n \"40.79.139.96/27\",\r\n - \ \"40.79.148.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.JapanEast\",\r\n \"id\": \"AzureSignalR.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.109.224/27\",\r\n \"40.79.189.0/27\",\r\n - \ \"40.79.197.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.KoreaCentral\",\r\n \"id\": \"AzureSignalR.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.20.96/27\",\r\n \"52.231.20.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.NorthEurope\",\r\n - \ \"id\": \"AzureSignalR.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": - [\r\n \"13.69.232.128/25\",\r\n \"13.74.111.0/25\",\r\n - \ \"52.138.229.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.SouthCentralUS\",\r\n \"id\": \"AzureSignalR.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.244.64/27\",\r\n \"20.45.123.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.SoutheastAsia\",\r\n - \ \"id\": \"AzureSignalR.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": - [\r\n \"40.78.238.64/26\",\r\n \"40.78.238.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.UKSouth\",\r\n - \ \"id\": \"AzureSignalR.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"51.104.9.64/27\",\r\n - \ \"51.105.69.32/27\",\r\n \"51.105.77.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestCentralUS\",\r\n - \ \"id\": \"AzureSignalR.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": - [\r\n \"13.71.199.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.WestEurope\",\r\n \"id\": \"AzureSignalR.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.113.0/24\",\r\n \"52.178.16.0/24\",\r\n - \ \"52.236.190.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"AzureSignalR.WestUS\",\r\n \"id\": \"AzureSignalR.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.170.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestUS2\",\r\n - \ \"id\": \"AzureSignalR.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"13.66.145.0/26\",\r\n - \ \"40.78.245.64/26\",\r\n \"40.78.253.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"AzureSiteRecovery\",\r\n \"id\": - \"AzureSiteRecovery\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSiteRecovery\",\r\n \"addressPrefixes\": [\r\n \"13.66.141.240/28\",\r\n - \ \"13.67.10.96/28\",\r\n \"13.69.67.80/28\",\r\n \"13.69.107.80/28\",\r\n - \ \"13.69.230.16/28\",\r\n \"13.70.74.96/28\",\r\n \"13.70.159.158/32\",\r\n - \ \"13.71.173.224/28\",\r\n \"13.71.196.144/28\",\r\n \"13.73.242.192/28\",\r\n - \ \"13.74.108.144/28\",\r\n \"13.75.39.80/28\",\r\n \"13.77.53.64/28\",\r\n - \ \"13.78.109.128/28\",\r\n \"13.82.88.226/32\",\r\n \"13.84.148.14/32\",\r\n - \ \"13.86.219.176/28\",\r\n \"13.87.37.4/32\",\r\n \"13.87.58.48/28\",\r\n - \ \"13.87.124.48/28\",\r\n \"13.89.174.144/28\",\r\n \"20.36.34.70/32\",\r\n - \ \"20.36.69.62/32\",\r\n \"20.36.108.96/28\",\r\n \"20.36.115.224/28\",\r\n - \ \"20.36.120.80/28\",\r\n \"20.37.64.80/28\",\r\n \"20.37.76.128/28\",\r\n - \ \"20.37.156.96/28\",\r\n \"20.37.192.112/28\",\r\n \"20.37.224.80/28\",\r\n - \ \"20.38.80.112/28\",\r\n \"20.38.128.80/28\",\r\n \"20.38.136.80/28\",\r\n - \ \"20.38.147.160/28\",\r\n \"20.39.8.80/28\",\r\n \"20.41.4.64/28\",\r\n - \ \"20.41.64.96/28\",\r\n \"20.41.192.80/28\",\r\n \"20.42.4.96/28\",\r\n - \ \"20.42.129.128/28\",\r\n \"20.42.224.80/28\",\r\n \"20.43.40.112/28\",\r\n - \ \"20.43.64.112/28\",\r\n \"20.43.121.16/28\",\r\n \"20.43.130.64/28\",\r\n - \ \"20.44.4.80/28\",\r\n \"20.44.8.176/28\",\r\n \"20.44.17.32/28\",\r\n - \ \"20.44.27.192/28\",\r\n \"20.45.75.232/32\",\r\n \"20.45.112.80/28\",\r\n - \ \"20.45.123.96/28\",\r\n \"20.45.192.80/28\",\r\n \"20.49.83.48/28\",\r\n - \ \"20.49.91.48/28\",\r\n \"20.150.160.80/28\",\r\n \"20.150.172.48/28\",\r\n - \ \"20.150.179.208/28\",\r\n \"20.150.187.208/28\",\r\n \"20.189.106.96/28\",\r\n - \ \"20.192.99.208/28\",\r\n \"20.192.160.0/28\",\r\n \"20.192.225.0/28\",\r\n - \ \"20.192.235.224/28\",\r\n \"20.193.203.208/28\",\r\n \"20.194.67.48/28\",\r\n - \ \"23.96.195.247/32\",\r\n \"23.98.83.80/28\",\r\n \"40.67.48.80/28\",\r\n - \ \"40.67.60.80/28\",\r\n \"40.69.108.64/28\",\r\n \"40.69.144.231/32\",\r\n - \ \"40.69.212.238/32\",\r\n \"40.70.148.96/28\",\r\n \"40.71.14.0/28\",\r\n - \ \"40.74.24.112/28\",\r\n \"40.74.147.176/28\",\r\n \"40.75.35.80/28\",\r\n - \ \"40.78.196.64/28\",\r\n \"40.78.204.16/28\",\r\n \"40.78.229.48/28\",\r\n - \ \"40.78.236.144/28\",\r\n \"40.78.243.160/28\",\r\n \"40.78.251.96/28\",\r\n - \ \"40.79.132.64/28\",\r\n \"40.79.139.0/28\",\r\n \"40.79.146.192/28\",\r\n - \ \"40.79.156.48/28\",\r\n \"40.79.163.16/28\",\r\n \"40.79.171.96/28\",\r\n - \ \"40.79.180.32/28\",\r\n \"40.79.187.176/28\",\r\n \"40.79.195.160/28\",\r\n - \ \"40.80.51.96/28\",\r\n \"40.80.56.80/28\",\r\n \"40.80.168.80/28\",\r\n - \ \"40.80.176.16/28\",\r\n \"40.80.184.96/28\",\r\n \"40.82.248.96/28\",\r\n - \ \"40.83.179.48/32\",\r\n \"40.89.16.80/28\",\r\n \"40.119.9.192/28\",\r\n - \ \"40.120.75.96/28\",\r\n \"40.123.219.238/32\",\r\n \"51.12.100.32/28\",\r\n - \ \"51.12.204.32/28\",\r\n \"51.12.227.208/28\",\r\n \"51.12.235.208/28\",\r\n - \ \"51.104.9.0/28\",\r\n \"51.104.24.112/28\",\r\n \"51.105.67.192/28\",\r\n - \ \"51.105.75.160/28\",\r\n \"51.105.80.80/28\",\r\n \"51.105.88.80/28\",\r\n - \ \"51.107.48.80/28\",\r\n \"51.107.60.64/28\",\r\n \"51.107.68.31/32\",\r\n - \ \"51.107.144.80/28\",\r\n \"51.107.156.80/28\",\r\n \"51.107.231.223/32\",\r\n - \ \"51.116.48.80/28\",\r\n \"51.116.60.64/28\",\r\n \"51.116.144.80/28\",\r\n - \ \"51.116.156.176/28\",\r\n \"51.116.208.58/32\",\r\n \"51.116.243.128/28\",\r\n - \ \"51.116.251.48/28\",\r\n \"51.120.40.80/28\",\r\n \"51.120.100.64/28\",\r\n - \ \"51.120.107.208/28\",\r\n \"51.120.211.208/28\",\r\n \"51.120.220.64/28\",\r\n - \ \"51.120.224.80/28\",\r\n \"51.137.160.96/28\",\r\n \"51.140.43.158/32\",\r\n - \ \"51.140.212.80/28\",\r\n \"51.141.3.203/32\",\r\n \"51.142.209.167/32\",\r\n - \ \"51.143.192.80/28\",\r\n \"52.136.48.80/28\",\r\n \"52.136.139.227/32\",\r\n - \ \"52.138.92.64/28\",\r\n \"52.138.227.144/28\",\r\n \"52.140.104.80/28\",\r\n - \ \"52.143.138.106/32\",\r\n \"52.150.136.96/28\",\r\n \"52.161.20.168/32\",\r\n - \ \"52.162.111.0/28\",\r\n \"52.166.13.64/32\",\r\n \"52.167.107.80/28\",\r\n - \ \"52.172.46.220/32\",\r\n \"52.172.187.37/32\",\r\n \"52.175.17.132/32\",\r\n - \ \"52.175.146.69/32\",\r\n \"52.180.178.64/32\",\r\n \"52.182.139.192/28\",\r\n - \ \"52.183.45.166/32\",\r\n \"52.184.158.163/32\",\r\n \"52.185.150.140/32\",\r\n - \ \"52.187.58.193/32\",\r\n \"52.187.191.206/32\",\r\n \"52.225.188.170/32\",\r\n - \ \"52.228.36.192/32\",\r\n \"52.228.80.96/28\",\r\n \"52.229.125.98/32\",\r\n - \ \"52.231.20.16/28\",\r\n \"52.231.28.253/32\",\r\n \"52.231.148.96/28\",\r\n - \ \"52.231.198.185/32\",\r\n \"52.236.187.64/28\",\r\n \"52.246.155.160/28\",\r\n - \ \"65.52.252.192/28\",\r\n \"102.133.28.128/28\",\r\n \"102.133.59.160/28\",\r\n - \ \"102.133.72.51/32\",\r\n \"102.133.124.64/28\",\r\n \"102.133.156.96/28\",\r\n - \ \"102.133.160.44/32\",\r\n \"102.133.218.176/28\",\r\n - \ \"102.133.251.160/28\",\r\n \"104.210.113.114/32\",\r\n - \ \"104.211.177.6/32\",\r\n \"191.233.8.0/28\",\r\n \"191.233.51.192/28\",\r\n - \ \"191.233.205.80/28\",\r\n \"191.234.147.208/28\",\r\n - \ \"191.234.155.208/28\",\r\n \"191.234.185.172/32\",\r\n - \ \"191.235.224.112/28\",\r\n \"2603:1000:104:1::/123\",\r\n - \ \"2603:1010:6:1::/123\",\r\n \"2603:1020:5:1::/123\",\r\n - \ \"2603:1020:206:1::/123\",\r\n \"2603:1020:705:1::/123\",\r\n - \ \"2603:1020:805:1::/123\",\r\n \"2603:1020:a04:1::/123\",\r\n - \ \"2603:1020:c04:1::/123\",\r\n \"2603:1020:e04:1::/123\",\r\n - \ \"2603:1020:1004::/123\",\r\n \"2603:1030:10:1::/123\",\r\n - \ \"2603:1030:104:1::/123\",\r\n \"2603:1030:210:1::/123\",\r\n - \ \"2603:1030:40b:1::/123\",\r\n \"2603:1030:40c:1::/123\",\r\n - \ \"2603:1030:504:1::/123\",\r\n \"2603:1030:807:1::/123\",\r\n - \ \"2603:1030:c06:1::/123\",\r\n \"2603:1030:f05:1::/123\",\r\n - \ \"2603:1040:5:1::/123\",\r\n \"2603:1040:407:1::/123\",\r\n - \ \"2603:1040:904:1::/123\",\r\n \"2603:1040:a06:1::/123\",\r\n - \ \"2603:1040:d04::/123\",\r\n \"2603:1040:f05:1::/123\",\r\n - \ \"2603:1050:6:1::/123\",\r\n \"2603:1050:403::/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureTrafficManager\",\r\n - \ \"id\": \"AzureTrafficManager\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"AzureTrafficManager\",\r\n \"addressPrefixes\": - [\r\n \"13.65.92.252/32\",\r\n \"13.65.95.152/32\",\r\n - \ \"13.75.124.254/32\",\r\n \"13.75.127.63/32\",\r\n \"13.75.152.253/32\",\r\n - \ \"13.75.153.124/32\",\r\n \"13.84.222.37/32\",\r\n \"23.96.236.252/32\",\r\n - \ \"23.101.191.199/32\",\r\n \"40.68.30.66/32\",\r\n \"40.68.31.178/32\",\r\n - \ \"40.78.67.110/32\",\r\n \"40.87.147.10/32\",\r\n \"40.87.151.34/32\",\r\n - \ \"40.114.5.197/32\",\r\n \"52.172.155.168/32\",\r\n \"52.172.158.37/32\",\r\n - \ \"52.173.90.107/32\",\r\n \"52.173.250.232/32\",\r\n \"52.240.144.45/32\",\r\n - \ \"52.240.151.125/32\",\r\n \"65.52.217.19/32\",\r\n \"104.41.187.209/32\",\r\n - \ \"104.41.190.203/32\",\r\n \"104.42.192.195/32\",\r\n \"104.45.149.110/32\",\r\n - \ \"104.215.91.84/32\",\r\n \"137.135.46.163/32\",\r\n \"137.135.47.215/32\",\r\n - \ \"137.135.80.149/32\",\r\n \"137.135.82.249/32\",\r\n \"191.232.208.52/32\",\r\n - \ \"191.232.214.62/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement\",\r\n \"id\": \"BatchNodeManagement\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"13.65.192.161/32\",\r\n - \ \"13.65.208.36/32\",\r\n \"13.66.141.32/27\",\r\n \"13.66.225.240/32\",\r\n - \ \"13.66.227.117/32\",\r\n \"13.66.227.193/32\",\r\n \"13.67.9.160/27\",\r\n - \ \"13.67.58.116/32\",\r\n \"13.67.190.3/32\",\r\n \"13.67.237.249/32\",\r\n - \ \"13.69.65.64/26\",\r\n \"13.69.106.128/26\",\r\n \"13.69.125.173/32\",\r\n - \ \"13.69.229.32/27\",\r\n \"13.70.73.0/27\",\r\n \"13.71.144.135/32\",\r\n - \ \"13.71.172.96/27\",\r\n \"13.71.195.160/27\",\r\n \"13.73.117.100/32\",\r\n - \ \"13.73.153.226/32\",\r\n \"13.73.157.134/32\",\r\n \"13.73.249.64/27\",\r\n - \ \"13.74.107.128/27\",\r\n \"13.75.36.96/27\",\r\n \"13.77.52.128/27\",\r\n - \ \"13.77.80.138/32\",\r\n \"13.78.108.128/27\",\r\n \"13.78.145.2/32\",\r\n - \ \"13.78.145.73/32\",\r\n \"13.78.150.134/32\",\r\n \"13.78.187.18/32\",\r\n - \ \"13.79.172.125/32\",\r\n \"13.80.117.88/32\",\r\n \"13.81.1.133/32\",\r\n - \ \"13.81.59.254/32\",\r\n \"13.81.63.6/32\",\r\n \"13.81.104.137/32\",\r\n - \ \"13.86.218.192/27\",\r\n \"13.87.32.176/32\",\r\n \"13.87.32.218/32\",\r\n - \ \"13.87.33.133/32\",\r\n \"13.87.57.96/27\",\r\n \"13.87.97.57/32\",\r\n - \ \"13.87.97.82/32\",\r\n \"13.87.100.219/32\",\r\n \"13.87.123.96/27\",\r\n - \ \"13.89.55.147/32\",\r\n \"13.89.171.224/27\",\r\n \"13.91.55.167/32\",\r\n - \ \"13.91.88.93/32\",\r\n \"13.91.107.154/32\",\r\n \"13.92.114.103/32\",\r\n - \ \"13.93.206.144/32\",\r\n \"13.94.214.82/32\",\r\n \"13.95.9.27/32\",\r\n - \ \"20.36.40.22/32\",\r\n \"20.36.47.197/32\",\r\n \"20.36.107.128/27\",\r\n - \ \"20.36.121.160/27\",\r\n \"20.37.65.160/27\",\r\n \"20.37.75.224/27\",\r\n - \ \"20.37.196.128/27\",\r\n \"20.37.225.160/27\",\r\n \"20.38.85.224/27\",\r\n - \ \"20.38.137.192/27\",\r\n \"20.38.146.224/27\",\r\n \"20.39.1.125/32\",\r\n - \ \"20.39.1.239/32\",\r\n \"20.39.2.44/32\",\r\n \"20.39.2.122/32\",\r\n - \ \"20.39.3.157/32\",\r\n \"20.39.3.186/32\",\r\n \"20.39.12.64/27\",\r\n - \ \"20.40.137.186/32\",\r\n \"20.40.149.165/32\",\r\n \"20.40.200.32/27\",\r\n - \ \"20.41.5.224/27\",\r\n \"20.41.66.128/27\",\r\n \"20.41.195.128/27\",\r\n - \ \"20.42.6.224/27\",\r\n \"20.42.227.224/27\",\r\n \"20.43.42.96/27\",\r\n - \ \"20.43.66.96/27\",\r\n \"20.43.132.64/27\",\r\n \"20.44.4.112/29\",\r\n - \ \"20.44.27.64/27\",\r\n \"20.45.113.160/27\",\r\n \"20.45.122.224/27\",\r\n - \ \"20.45.195.192/27\",\r\n \"20.49.83.64/27\",\r\n \"20.49.91.64/27\",\r\n - \ \"20.50.1.64/26\",\r\n \"20.150.161.224/27\",\r\n \"20.150.172.0/27\",\r\n - \ \"20.150.179.96/27\",\r\n \"20.150.187.96/27\",\r\n \"20.189.109.0/27\",\r\n - \ \"20.192.99.96/27\",\r\n \"20.192.161.224/27\",\r\n \"20.192.228.160/27\",\r\n - \ \"20.192.235.192/27\",\r\n \"20.193.203.128/27\",\r\n \"23.96.12.112/32\",\r\n - \ \"23.96.101.73/32\",\r\n \"23.96.109.140/32\",\r\n \"23.96.232.67/32\",\r\n - \ \"23.97.48.186/32\",\r\n \"23.97.51.12/32\",\r\n \"23.97.97.29/32\",\r\n - \ \"23.97.180.74/32\",\r\n \"23.98.82.160/27\",\r\n \"23.99.98.61/32\",\r\n - \ \"23.99.107.229/32\",\r\n \"23.99.195.236/32\",\r\n \"23.100.100.145/32\",\r\n - \ \"23.100.103.112/32\",\r\n \"23.101.176.33/32\",\r\n \"23.102.178.148/32\",\r\n - \ \"23.102.185.64/32\",\r\n \"40.64.128.160/27\",\r\n \"40.67.49.160/27\",\r\n - \ \"40.67.60.0/27\",\r\n \"40.68.100.153/32\",\r\n \"40.68.191.54/32\",\r\n - \ \"40.68.218.90/32\",\r\n \"40.69.107.128/27\",\r\n \"40.70.147.224/27\",\r\n - \ \"40.71.12.192/27\",\r\n \"40.74.101.0/27\",\r\n \"40.74.140.140/32\",\r\n - \ \"40.74.149.48/29\",\r\n \"40.74.177.177/32\",\r\n \"40.75.35.136/29\",\r\n - \ \"40.77.18.99/32\",\r\n \"40.78.195.128/27\",\r\n \"40.78.203.0/27\",\r\n - \ \"40.78.227.0/27\",\r\n \"40.78.234.96/27\",\r\n \"40.78.242.224/27\",\r\n - \ \"40.78.250.160/27\",\r\n \"40.79.131.96/27\",\r\n \"40.79.138.96/27\",\r\n - \ \"40.79.146.96/27\",\r\n \"40.79.154.32/27\",\r\n \"40.79.162.96/27\",\r\n - \ \"40.79.170.192/27\",\r\n \"40.79.186.128/27\",\r\n \"40.79.194.32/27\",\r\n - \ \"40.80.50.224/27\",\r\n \"40.80.58.160/27\",\r\n \"40.80.170.128/27\",\r\n - \ \"40.80.190.192/27\",\r\n \"40.82.255.64/27\",\r\n \"40.84.49.170/32\",\r\n - \ \"40.84.62.82/32\",\r\n \"40.85.226.213/32\",\r\n \"40.85.227.37/32\",\r\n - \ \"40.86.224.98/32\",\r\n \"40.86.224.104/32\",\r\n \"40.88.48.36/32\",\r\n - \ \"40.89.18.192/27\",\r\n \"40.89.65.161/32\",\r\n \"40.89.66.236/32\",\r\n - \ \"40.89.67.77/32\",\r\n \"40.89.70.17/32\",\r\n \"40.112.254.235/32\",\r\n - \ \"40.115.50.9/32\",\r\n \"40.118.208.127/32\",\r\n \"40.122.166.234/32\",\r\n - \ \"51.12.41.192/27\",\r\n \"51.12.100.0/27\",\r\n \"51.12.193.192/27\",\r\n - \ \"51.12.204.0/27\",\r\n \"51.12.227.96/27\",\r\n \"51.12.235.96/27\",\r\n - \ \"51.104.28.0/27\",\r\n \"51.105.66.224/27\",\r\n \"51.105.74.224/27\",\r\n - \ \"51.105.81.160/27\",\r\n \"51.105.89.192/27\",\r\n \"51.107.49.192/27\",\r\n - \ \"51.107.59.224/27\",\r\n \"51.107.145.160/27\",\r\n \"51.107.155.224/27\",\r\n - \ \"51.116.48.224/27\",\r\n \"51.116.59.224/27\",\r\n \"51.116.144.224/27\",\r\n - \ \"51.116.154.32/27\",\r\n \"51.116.243.0/27\",\r\n \"51.116.251.0/27\",\r\n - \ \"51.120.41.192/27\",\r\n \"51.120.99.224/27\",\r\n \"51.120.107.96/27\",\r\n - \ \"51.120.211.96/27\",\r\n \"51.120.220.0/27\",\r\n \"51.120.225.160/27\",\r\n - \ \"51.137.162.192/27\",\r\n \"51.140.148.160/27\",\r\n \"51.140.184.59/32\",\r\n - \ \"51.140.184.61/32\",\r\n \"51.140.184.63/32\",\r\n \"51.140.211.128/27\",\r\n - \ \"51.141.8.61/32\",\r\n \"51.141.8.62/32\",\r\n \"51.141.8.64/32\",\r\n - \ \"51.143.193.160/27\",\r\n \"52.136.49.192/27\",\r\n \"52.136.143.192/31\",\r\n - \ \"52.137.105.46/32\",\r\n \"52.138.90.64/27\",\r\n \"52.138.226.128/27\",\r\n - \ \"52.140.106.128/27\",\r\n \"52.143.139.121/32\",\r\n \"52.143.140.12/32\",\r\n - \ \"52.148.148.46/32\",\r\n \"52.150.140.128/27\",\r\n \"52.161.95.12/32\",\r\n - \ \"52.161.107.48/32\",\r\n \"52.162.110.32/27\",\r\n \"52.164.244.189/32\",\r\n - \ \"52.164.245.81/32\",\r\n \"52.165.44.224/32\",\r\n \"52.166.19.45/32\",\r\n - \ \"52.167.106.128/27\",\r\n \"52.169.27.79/32\",\r\n \"52.169.30.175/32\",\r\n - \ \"52.169.235.90/32\",\r\n \"52.174.33.113/32\",\r\n \"52.174.34.69/32\",\r\n - \ \"52.174.35.218/32\",\r\n \"52.174.38.99/32\",\r\n \"52.174.176.203/32\",\r\n - \ \"52.174.179.66/32\",\r\n \"52.174.180.164/32\",\r\n \"52.175.218.150/32\",\r\n - \ \"52.178.149.188/32\",\r\n \"52.180.176.58/32\",\r\n \"52.180.177.108/32\",\r\n - \ \"52.180.177.206/32\",\r\n \"52.180.179.94/32\",\r\n \"52.180.181.0/32\",\r\n - \ \"52.180.181.239/32\",\r\n \"52.182.139.0/27\",\r\n \"52.188.222.115/32\",\r\n - \ \"52.189.217.254/32\",\r\n \"52.191.129.21/32\",\r\n \"52.191.166.57/32\",\r\n - \ \"52.225.185.38/32\",\r\n \"52.225.191.67/32\",\r\n \"52.228.44.187/32\",\r\n - \ \"52.228.83.192/27\",\r\n \"52.231.19.96/27\",\r\n \"52.231.32.70/31\",\r\n - \ \"52.231.32.82/32\",\r\n \"52.231.147.128/27\",\r\n \"52.231.200.112/31\",\r\n - \ \"52.231.200.126/32\",\r\n \"52.233.40.34/32\",\r\n \"52.233.157.9/32\",\r\n - \ \"52.233.157.78/32\",\r\n \"52.233.161.238/32\",\r\n \"52.233.172.80/32\",\r\n - \ \"52.235.41.66/32\",\r\n \"52.236.186.128/26\",\r\n \"52.237.30.175/32\",\r\n - \ \"52.242.22.129/32\",\r\n \"52.242.33.105/32\",\r\n \"52.246.154.224/27\",\r\n - \ \"52.249.60.22/32\",\r\n \"52.253.227.240/32\",\r\n \"65.52.199.156/32\",\r\n - \ \"65.52.199.188/32\",\r\n \"65.52.251.224/27\",\r\n \"70.37.49.163/32\",\r\n - \ \"102.133.27.192/27\",\r\n \"102.133.56.192/27\",\r\n \"102.133.123.64/27\",\r\n - \ \"102.133.155.192/27\",\r\n \"102.133.217.224/27\",\r\n - \ \"102.133.250.224/27\",\r\n \"104.40.69.159/32\",\r\n \"104.40.183.25/32\",\r\n - \ \"104.41.2.182/32\",\r\n \"104.41.129.99/32\",\r\n \"104.43.128.78/32\",\r\n - \ \"104.43.131.156/32\",\r\n \"104.43.132.75/32\",\r\n \"104.45.13.8/32\",\r\n - \ \"104.45.82.201/32\",\r\n \"104.45.88.181/32\",\r\n \"104.46.232.208/32\",\r\n - \ \"104.46.236.29/32\",\r\n \"104.47.149.96/32\",\r\n \"104.208.16.128/27\",\r\n - \ \"104.208.144.128/27\",\r\n \"104.208.156.99/32\",\r\n - \ \"104.208.157.18/32\",\r\n \"104.210.3.254/32\",\r\n \"104.210.115.52/32\",\r\n - \ \"104.211.82.96/27\",\r\n \"104.211.96.142/32\",\r\n \"104.211.96.144/31\",\r\n - \ \"104.211.147.96/27\",\r\n \"104.211.160.72/32\",\r\n \"104.211.160.74/31\",\r\n - \ \"104.211.224.117/32\",\r\n \"104.211.224.119/32\",\r\n - \ \"104.211.224.121/32\",\r\n \"104.214.19.192/27\",\r\n - \ \"104.214.65.153/32\",\r\n \"111.221.104.48/32\",\r\n \"137.116.33.5/32\",\r\n - \ \"137.116.33.29/32\",\r\n \"137.116.33.71/32\",\r\n \"137.116.37.146/32\",\r\n - \ \"137.116.46.180/32\",\r\n \"137.116.193.225/32\",\r\n - \ \"137.117.45.176/32\",\r\n \"137.117.109.143/32\",\r\n - \ \"138.91.1.114/32\",\r\n \"138.91.17.36/32\",\r\n \"157.55.167.71/32\",\r\n - \ \"157.55.210.88/32\",\r\n \"168.61.161.154/32\",\r\n \"168.61.209.228/32\",\r\n - \ \"168.62.4.114/32\",\r\n \"168.62.36.128/32\",\r\n \"168.62.168.27/32\",\r\n - \ \"168.63.5.53/32\",\r\n \"168.63.36.126/32\",\r\n \"168.63.133.23/32\",\r\n - \ \"168.63.208.148/32\",\r\n \"191.232.37.60/32\",\r\n \"191.233.10.0/27\",\r\n - \ \"191.233.76.85/32\",\r\n \"191.233.204.96/27\",\r\n \"191.234.147.96/27\",\r\n - \ \"191.234.155.96/27\",\r\n \"191.235.227.192/27\",\r\n - \ \"191.236.37.239/32\",\r\n \"191.236.38.142/32\",\r\n \"191.236.161.35/32\",\r\n - \ \"191.236.163.245/32\",\r\n \"191.236.164.44/32\",\r\n - \ \"191.239.18.3/32\",\r\n \"191.239.21.73/32\",\r\n \"191.239.40.217/32\",\r\n - \ \"191.239.64.139/32\",\r\n \"191.239.64.152/32\",\r\n \"191.239.160.161/32\",\r\n - \ \"191.239.160.185/32\",\r\n \"207.46.149.75/32\",\r\n \"207.46.225.72/32\",\r\n - \ \"2603:1000:104:1::340/122\",\r\n \"2603:1010:6:1::340/122\",\r\n - \ \"2603:1020:5:1::340/122\",\r\n \"2603:1020:206:1::340/122\",\r\n - \ \"2603:1020:705:1::340/122\",\r\n \"2603:1020:805:1::340/122\",\r\n - \ \"2603:1020:a04:1::340/122\",\r\n \"2603:1020:c04:1::340/122\",\r\n - \ \"2603:1020:e04:1::340/122\",\r\n \"2603:1020:1004::340/122\",\r\n - \ \"2603:1030:10:1::340/122\",\r\n \"2603:1030:104:1::340/122\",\r\n - \ \"2603:1030:210:1::340/122\",\r\n \"2603:1030:40b:1::340/122\",\r\n - \ \"2603:1030:40c:1::340/122\",\r\n \"2603:1030:504:1::340/122\",\r\n - \ \"2603:1030:807:1::340/122\",\r\n \"2603:1030:c06:1::340/122\",\r\n - \ \"2603:1030:f05:1::340/122\",\r\n \"2603:1040:5:1::340/122\",\r\n - \ \"2603:1040:407:1::340/122\",\r\n \"2603:1040:904:1::340/122\",\r\n - \ \"2603:1040:a06:1::340/122\",\r\n \"2603:1040:d04::340/122\",\r\n - \ \"2603:1040:f05:1::340/122\",\r\n \"2603:1050:6:1::340/122\",\r\n - \ \"2603:1050:403::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.AustraliaCentral\",\r\n \"id\": - \"BatchNodeManagement.AustraliaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiacentral\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"20.36.40.22/32\",\r\n \"20.36.47.197/32\",\r\n \"20.36.107.128/27\",\r\n - \ \"20.37.225.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.AustraliaCentral2\",\r\n \"id\": - \"BatchNodeManagement.AustraliaCentral2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"20.36.121.160/27\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.AustraliaEast\",\r\n \"id\": - \"BatchNodeManagement.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.70.73.0/27\",\r\n \"20.37.196.128/27\",\r\n \"40.79.162.96/27\",\r\n - \ \"40.79.170.192/27\",\r\n \"104.210.115.52/32\",\r\n \"191.239.64.139/32\",\r\n - \ \"191.239.64.152/32\",\r\n \"2603:1010:6:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.AustraliaSoutheast\",\r\n - \ \"id\": \"BatchNodeManagement.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.117.100/32\",\r\n \"13.77.52.128/27\",\r\n - \ \"20.42.227.224/27\",\r\n \"52.189.217.254/32\",\r\n \"191.239.160.161/32\",\r\n - \ \"191.239.160.185/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.BrazilSouth\",\r\n \"id\": \"BatchNodeManagement.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"23.97.97.29/32\",\r\n - \ \"104.41.2.182/32\",\r\n \"191.232.37.60/32\",\r\n \"191.233.204.96/27\",\r\n - \ \"191.234.147.96/27\",\r\n \"191.234.155.96/27\",\r\n \"191.235.227.192/27\",\r\n - \ \"2603:1050:6:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.CanadaCentral\",\r\n \"id\": - \"BatchNodeManagement.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.71.172.96/27\",\r\n \"20.38.146.224/27\",\r\n - \ \"40.85.226.213/32\",\r\n \"40.85.227.37/32\",\r\n \"52.228.44.187/32\",\r\n - \ \"52.228.83.192/27\",\r\n \"52.233.40.34/32\",\r\n \"52.237.30.175/32\",\r\n - \ \"52.246.154.224/27\",\r\n \"2603:1030:f05:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CanadaEast\",\r\n - \ \"id\": \"BatchNodeManagement.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.107.128/27\",\r\n \"40.86.224.98/32\",\r\n - \ \"40.86.224.104/32\",\r\n \"40.89.18.192/27\",\r\n \"52.235.41.66/32\",\r\n - \ \"52.242.22.129/32\",\r\n \"52.242.33.105/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralIndia\",\r\n - \ \"id\": \"BatchNodeManagement.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.192.99.96/27\",\r\n \"40.80.50.224/27\",\r\n - \ \"52.140.106.128/27\",\r\n \"104.211.82.96/27\",\r\n \"104.211.96.142/32\",\r\n - \ \"104.211.96.144/31\",\r\n \"2603:1040:a06:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralUS\",\r\n - \ \"id\": \"BatchNodeManagement.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.190.3/32\",\r\n \"13.67.237.249/32\",\r\n - \ \"13.89.55.147/32\",\r\n \"13.89.171.224/27\",\r\n \"20.40.200.32/27\",\r\n - \ \"23.99.195.236/32\",\r\n \"40.77.18.99/32\",\r\n \"40.122.166.234/32\",\r\n - \ \"52.165.44.224/32\",\r\n \"52.182.139.0/27\",\r\n \"104.43.128.78/32\",\r\n - \ \"104.43.131.156/32\",\r\n \"104.43.132.75/32\",\r\n \"104.208.16.128/27\",\r\n - \ \"168.61.161.154/32\",\r\n \"168.61.209.228/32\",\r\n \"2603:1030:10:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralUSEUAP\",\r\n - \ \"id\": \"BatchNodeManagement.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.195.192/27\",\r\n \"40.78.203.0/27\",\r\n - \ \"52.180.176.58/32\",\r\n \"52.180.177.108/32\",\r\n \"52.180.177.206/32\",\r\n - \ \"52.180.179.94/32\",\r\n \"52.180.181.0/32\",\r\n \"52.180.181.239/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.EastAsia\",\r\n - \ \"id\": \"BatchNodeManagement.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.36.96/27\",\r\n \"20.189.109.0/27\",\r\n - \ \"23.99.98.61/32\",\r\n \"23.99.107.229/32\",\r\n \"168.63.133.23/32\",\r\n - \ \"168.63.208.148/32\",\r\n \"207.46.149.75/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.EastUS\",\r\n - \ \"id\": \"BatchNodeManagement.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.92.114.103/32\",\r\n \"20.42.6.224/27\",\r\n - \ \"23.96.12.112/32\",\r\n \"23.96.101.73/32\",\r\n \"23.96.109.140/32\",\r\n - \ \"40.71.12.192/27\",\r\n \"40.78.227.0/27\",\r\n \"40.79.154.32/27\",\r\n - \ \"40.88.48.36/32\",\r\n \"52.188.222.115/32\",\r\n \"104.41.129.99/32\",\r\n - \ \"137.117.45.176/32\",\r\n \"137.117.109.143/32\",\r\n - \ \"168.62.36.128/32\",\r\n \"168.62.168.27/32\",\r\n \"191.236.37.239/32\",\r\n - \ \"191.236.38.142/32\",\r\n \"2603:1030:210:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.EastUS2\",\r\n - \ \"id\": \"BatchNodeManagement.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.77.80.138/32\",\r\n \"20.41.5.224/27\",\r\n \"40.70.147.224/27\",\r\n - \ \"40.84.49.170/32\",\r\n \"40.84.62.82/32\",\r\n \"52.167.106.128/27\",\r\n - \ \"104.208.144.128/27\",\r\n \"104.208.156.99/32\",\r\n - \ \"104.208.157.18/32\",\r\n \"104.210.3.254/32\",\r\n \"137.116.33.5/32\",\r\n - \ \"137.116.33.29/32\",\r\n \"137.116.33.71/32\",\r\n \"137.116.37.146/32\",\r\n - \ \"137.116.46.180/32\",\r\n \"2603:1030:40c:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.EastUS2EUAP\",\r\n - \ \"id\": \"BatchNodeManagement.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.1.125/32\",\r\n \"20.39.1.239/32\",\r\n - \ \"20.39.2.44/32\",\r\n \"20.39.2.122/32\",\r\n \"20.39.3.157/32\",\r\n - \ \"20.39.3.186/32\",\r\n \"20.39.12.64/27\",\r\n \"40.74.149.48/29\",\r\n - \ \"40.75.35.136/29\",\r\n \"40.89.65.161/32\",\r\n \"40.89.66.236/32\",\r\n - \ \"40.89.67.77/32\",\r\n \"40.89.70.17/32\",\r\n \"52.138.90.64/27\",\r\n - \ \"52.225.185.38/32\",\r\n \"52.225.191.67/32\",\r\n \"52.253.227.240/32\",\r\n - \ \"2603:1030:40b:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.FranceCentral\",\r\n \"id\": - \"BatchNodeManagement.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"20.40.137.186/32\",\r\n \"20.40.149.165/32\",\r\n - \ \"20.43.42.96/27\",\r\n \"40.79.131.96/27\",\r\n \"40.79.138.96/27\",\r\n - \ \"40.79.146.96/27\",\r\n \"52.143.139.121/32\",\r\n \"52.143.140.12/32\",\r\n - \ \"2603:1020:805:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.FranceSouth\",\r\n \"id\": - \"BatchNodeManagement.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.105.89.192/27\",\r\n \"52.136.143.192/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.GermanyNorth\",\r\n - \ \"id\": \"BatchNodeManagement.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.48.224/27\",\r\n \"51.116.59.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.GermanyWestCentral\",\r\n - \ \"id\": \"BatchNodeManagement.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.144.224/27\",\r\n \"51.116.154.32/27\",\r\n - \ \"51.116.243.0/27\",\r\n \"51.116.251.0/27\",\r\n \"2603:1020:c04:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.JapanEast\",\r\n - \ \"id\": \"BatchNodeManagement.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.144.135/32\",\r\n \"13.78.108.128/27\",\r\n - \ \"20.43.66.96/27\",\r\n \"23.100.100.145/32\",\r\n \"23.100.103.112/32\",\r\n - \ \"40.79.186.128/27\",\r\n \"40.79.194.32/27\",\r\n \"138.91.1.114/32\",\r\n - \ \"2603:1040:407:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.JapanWest\",\r\n \"id\": - \"BatchNodeManagement.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"40.74.101.0/27\",\r\n \"40.74.140.140/32\",\r\n - \ \"40.80.58.160/27\",\r\n \"104.46.232.208/32\",\r\n \"104.46.236.29/32\",\r\n - \ \"138.91.17.36/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.KoreaCentral\",\r\n \"id\": \"BatchNodeManagement.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"20.41.66.128/27\",\r\n - \ \"20.44.27.64/27\",\r\n \"52.231.19.96/27\",\r\n \"52.231.32.70/31\",\r\n - \ \"52.231.32.82/32\",\r\n \"2603:1040:f05:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.KoreaSouth\",\r\n - \ \"id\": \"BatchNodeManagement.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.170.128/27\",\r\n \"52.231.147.128/27\",\r\n - \ \"52.231.200.112/31\",\r\n \"52.231.200.126/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.NorthCentralUS\",\r\n - \ \"id\": \"BatchNodeManagement.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"23.96.232.67/32\",\r\n \"40.80.190.192/27\",\r\n - \ \"52.162.110.32/27\",\r\n \"65.52.199.156/32\",\r\n \"65.52.199.188/32\",\r\n - \ \"157.55.167.71/32\",\r\n \"157.55.210.88/32\",\r\n \"191.236.161.35/32\",\r\n - \ \"191.236.163.245/32\",\r\n \"191.236.164.44/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.NorthEurope\",\r\n - \ \"id\": \"BatchNodeManagement.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.229.32/27\",\r\n \"13.74.107.128/27\",\r\n - \ \"13.79.172.125/32\",\r\n \"20.38.85.224/27\",\r\n \"52.138.226.128/27\",\r\n - \ \"52.164.244.189/32\",\r\n \"52.164.245.81/32\",\r\n \"52.169.27.79/32\",\r\n - \ \"52.169.30.175/32\",\r\n \"52.169.235.90/32\",\r\n \"52.178.149.188/32\",\r\n - \ \"104.45.82.201/32\",\r\n \"104.45.88.181/32\",\r\n \"168.63.36.126/32\",\r\n - \ \"2603:1020:5:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.NorwayEast\",\r\n \"id\": - \"BatchNodeManagement.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.120.41.192/27\",\r\n \"51.120.99.224/27\",\r\n - \ \"51.120.107.96/27\",\r\n \"51.120.211.96/27\",\r\n \"2603:1020:e04:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.NorwayWest\",\r\n - \ \"id\": \"BatchNodeManagement.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.220.0/27\",\r\n \"51.120.225.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SouthAfricaNorth\",\r\n - \ \"id\": \"BatchNodeManagement.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.123.64/27\",\r\n \"102.133.155.192/27\",\r\n - \ \"102.133.217.224/27\",\r\n \"102.133.250.224/27\",\r\n - \ \"2603:1000:104:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.SouthAfricaWest\",\r\n \"id\": - \"BatchNodeManagement.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"102.133.27.192/27\",\r\n \"102.133.56.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SouthCentralUS\",\r\n - \ \"id\": \"BatchNodeManagement.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.192.161/32\",\r\n \"13.65.208.36/32\",\r\n - \ \"13.73.249.64/27\",\r\n \"20.45.122.224/27\",\r\n \"20.49.91.64/27\",\r\n - \ \"23.101.176.33/32\",\r\n \"23.102.178.148/32\",\r\n \"23.102.185.64/32\",\r\n - \ \"40.74.177.177/32\",\r\n \"52.249.60.22/32\",\r\n \"70.37.49.163/32\",\r\n - \ \"104.214.19.192/27\",\r\n \"104.214.65.153/32\",\r\n \"2603:1030:807:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SoutheastAsia\",\r\n - \ \"id\": \"BatchNodeManagement.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.9.160/27\",\r\n \"13.67.58.116/32\",\r\n - \ \"20.43.132.64/27\",\r\n \"23.97.48.186/32\",\r\n \"23.97.51.12/32\",\r\n - \ \"23.98.82.160/27\",\r\n \"40.78.234.96/27\",\r\n \"111.221.104.48/32\",\r\n - \ \"207.46.225.72/32\",\r\n \"2603:1040:5:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SouthIndia\",\r\n - \ \"id\": \"BatchNodeManagement.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.195.128/27\",\r\n \"40.78.195.128/27\",\r\n - \ \"104.211.224.117/32\",\r\n \"104.211.224.119/32\",\r\n - \ \"104.211.224.121/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.SwitzerlandNorth\",\r\n \"id\": - \"BatchNodeManagement.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"switzerlandn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.107.49.192/27\",\r\n \"51.107.59.224/27\",\r\n - \ \"2603:1020:a04:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.SwitzerlandWest\",\r\n \"id\": - \"BatchNodeManagement.SwitzerlandWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"51.107.145.160/27\",\r\n \"51.107.155.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UAECentral\",\r\n - \ \"id\": \"BatchNodeManagement.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.65.160/27\",\r\n \"20.37.75.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UAENorth\",\r\n - \ \"id\": \"BatchNodeManagement.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.137.192/27\",\r\n \"65.52.251.224/27\",\r\n - \ \"2603:1040:904:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.UKNorth\",\r\n \"id\": - \"BatchNodeManagement.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"13.87.97.57/32\",\r\n - \ \"13.87.97.82/32\",\r\n \"13.87.100.219/32\",\r\n \"13.87.123.96/27\",\r\n - \ \"51.105.81.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.UKSouth\",\r\n \"id\": \"BatchNodeManagement.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"51.104.28.0/27\",\r\n - \ \"51.105.66.224/27\",\r\n \"51.105.74.224/27\",\r\n \"51.140.148.160/27\",\r\n - \ \"51.140.184.59/32\",\r\n \"51.140.184.61/32\",\r\n \"51.140.184.63/32\",\r\n - \ \"2603:1020:705:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.UKSouth2\",\r\n \"id\": - \"BatchNodeManagement.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"13.87.32.176/32\",\r\n - \ \"13.87.32.218/32\",\r\n \"13.87.33.133/32\",\r\n \"13.87.57.96/27\",\r\n - \ \"51.143.193.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.UKWest\",\r\n \"id\": \"BatchNodeManagement.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"51.137.162.192/27\",\r\n - \ \"51.140.211.128/27\",\r\n \"51.141.8.61/32\",\r\n \"51.141.8.62/32\",\r\n - \ \"51.141.8.64/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.WestCentralUS\",\r\n \"id\": \"BatchNodeManagement.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"13.71.195.160/27\",\r\n - \ \"13.78.145.2/32\",\r\n \"13.78.145.73/32\",\r\n \"13.78.150.134/32\",\r\n - \ \"13.78.187.18/32\",\r\n \"52.150.140.128/27\",\r\n \"52.161.95.12/32\",\r\n - \ \"52.161.107.48/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"BatchNodeManagement.WestEurope\",\r\n \"id\": \"BatchNodeManagement.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"13.69.65.64/26\",\r\n - \ \"13.69.106.128/26\",\r\n \"13.69.125.173/32\",\r\n \"13.73.153.226/32\",\r\n - \ \"13.73.157.134/32\",\r\n \"13.80.117.88/32\",\r\n \"13.81.1.133/32\",\r\n - \ \"13.81.59.254/32\",\r\n \"13.81.63.6/32\",\r\n \"13.81.104.137/32\",\r\n - \ \"13.94.214.82/32\",\r\n \"13.95.9.27/32\",\r\n \"20.50.1.64/26\",\r\n - \ \"23.97.180.74/32\",\r\n \"40.68.100.153/32\",\r\n \"40.68.191.54/32\",\r\n - \ \"40.68.218.90/32\",\r\n \"40.115.50.9/32\",\r\n \"52.166.19.45/32\",\r\n - \ \"52.174.33.113/32\",\r\n \"52.174.34.69/32\",\r\n \"52.174.35.218/32\",\r\n - \ \"52.174.38.99/32\",\r\n \"52.174.176.203/32\",\r\n \"52.174.179.66/32\",\r\n - \ \"52.174.180.164/32\",\r\n \"52.233.157.9/32\",\r\n \"52.233.157.78/32\",\r\n - \ \"52.233.161.238/32\",\r\n \"52.233.172.80/32\",\r\n \"52.236.186.128/26\",\r\n - \ \"104.40.183.25/32\",\r\n \"104.45.13.8/32\",\r\n \"104.47.149.96/32\",\r\n - \ \"137.116.193.225/32\",\r\n \"168.63.5.53/32\",\r\n \"191.233.76.85/32\",\r\n - \ \"2603:1020:206:1::340/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"BatchNodeManagement.WestIndia\",\r\n \"id\": - \"BatchNodeManagement.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"52.136.49.192/27\",\r\n \"104.211.147.96/27\",\r\n - \ \"104.211.160.72/32\",\r\n \"104.211.160.74/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestUS\",\r\n - \ \"id\": \"BatchNodeManagement.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.86.218.192/27\",\r\n \"13.91.55.167/32\",\r\n - \ \"13.91.88.93/32\",\r\n \"13.91.107.154/32\",\r\n \"13.93.206.144/32\",\r\n - \ \"40.82.255.64/27\",\r\n \"40.112.254.235/32\",\r\n \"40.118.208.127/32\",\r\n - \ \"104.40.69.159/32\",\r\n \"168.62.4.114/32\",\r\n \"191.239.18.3/32\",\r\n - \ \"191.239.21.73/32\",\r\n \"191.239.40.217/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestUS2\",\r\n - \ \"id\": \"BatchNodeManagement.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\": - [\r\n \"13.66.141.32/27\",\r\n \"13.66.225.240/32\",\r\n - \ \"13.66.227.117/32\",\r\n \"13.66.227.193/32\",\r\n \"40.64.128.160/27\",\r\n - \ \"40.78.242.224/27\",\r\n \"40.78.250.160/27\",\r\n \"52.137.105.46/32\",\r\n - \ \"52.148.148.46/32\",\r\n \"52.175.218.150/32\",\r\n \"52.191.129.21/32\",\r\n - \ \"52.191.166.57/32\",\r\n \"2603:1030:c06:1::340/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"CognitiveServicesManagement\",\r\n - \ \"id\": \"CognitiveServicesManagement\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"\",\r\n \"addressPrefixes\": - [\r\n \"13.66.56.76/32\",\r\n \"13.66.141.232/29\",\r\n - \ \"13.67.10.80/29\",\r\n \"13.67.35.35/32\",\r\n \"13.67.35.77/32\",\r\n - \ \"13.68.82.4/32\",\r\n \"13.68.130.251/32\",\r\n \"13.68.211.223/32\",\r\n - \ \"13.68.235.98/32\",\r\n \"13.69.67.64/28\",\r\n \"13.69.112.176/28\",\r\n - \ \"13.69.126.92/32\",\r\n \"13.69.230.0/29\",\r\n \"13.70.74.88/29\",\r\n - \ \"13.70.127.50/32\",\r\n \"13.70.149.125/32\",\r\n \"13.71.173.216/29\",\r\n - \ \"13.71.196.136/29\",\r\n \"13.73.242.48/29\",\r\n \"13.73.249.0/27\",\r\n - \ \"13.73.249.96/27\",\r\n \"13.73.249.128/28\",\r\n \"13.73.249.160/28\",\r\n - \ \"13.74.139.192/32\",\r\n \"13.74.170.104/32\",\r\n \"13.75.39.64/29\",\r\n - \ \"13.75.92.220/32\",\r\n \"13.75.137.81/32\",\r\n \"13.75.163.9/32\",\r\n - \ \"13.75.168.111/32\",\r\n \"13.77.1.236/32\",\r\n \"13.77.55.152/30\",\r\n - \ \"13.77.55.208/28\",\r\n \"13.77.202.2/32\",\r\n \"13.78.17.188/32\",\r\n - \ \"13.78.49.187/32\",\r\n \"13.78.70.7/32\",\r\n \"13.78.132.155/32\",\r\n - \ \"13.78.185.44/32\",\r\n \"13.78.187.168/32\",\r\n \"13.78.230.142/32\",\r\n - \ \"13.79.2.84/32\",\r\n \"13.83.68.180/32\",\r\n \"13.84.42.205/32\",\r\n - \ \"13.86.219.128/27\",\r\n \"13.87.216.38/32\",\r\n \"13.88.14.63/32\",\r\n - \ \"13.88.26.200/32\",\r\n \"13.88.220.109/32\",\r\n \"13.88.222.0/32\",\r\n - \ \"13.89.235.89/32\",\r\n \"13.91.130.201/32\",\r\n \"13.91.243.134/32\",\r\n - \ \"13.92.138.76/32\",\r\n \"13.92.179.108/32\",\r\n \"13.93.122.1/32\",\r\n - \ \"13.94.26.39/32\",\r\n \"20.36.120.224/27\",\r\n \"20.36.121.192/27\",\r\n - \ \"20.36.121.224/28\",\r\n \"20.37.64.224/27\",\r\n \"20.37.65.192/27\",\r\n - \ \"20.37.65.224/28\",\r\n \"20.37.76.200/30\",\r\n \"20.37.156.204/30\",\r\n - \ \"20.37.157.96/27\",\r\n \"20.37.195.112/28\",\r\n \"20.37.195.192/27\",\r\n - \ \"20.37.196.160/27\",\r\n \"20.37.224.224/27\",\r\n \"20.37.225.192/27\",\r\n - \ \"20.37.225.224/28\",\r\n \"20.38.84.108/30\",\r\n \"20.38.85.160/27\",\r\n - \ \"20.38.87.128/27\",\r\n \"20.38.87.160/28\",\r\n \"20.38.136.240/28\",\r\n - \ \"20.38.137.128/27\",\r\n \"20.38.137.224/27\",\r\n \"20.38.149.208/28\",\r\n - \ \"20.39.11.112/28\",\r\n \"20.39.12.0/27\",\r\n \"20.39.12.96/27\",\r\n - \ \"20.40.125.208/32\",\r\n \"20.40.164.245/32\",\r\n \"20.40.170.73/32\",\r\n - \ \"20.40.187.210/32\",\r\n \"20.40.188.109/32\",\r\n \"20.40.190.135/32\",\r\n - \ \"20.40.190.225/32\",\r\n \"20.40.200.64/27\",\r\n \"20.40.200.96/28\",\r\n - \ \"20.41.5.160/27\",\r\n \"20.41.65.192/27\",\r\n \"20.41.66.160/27\",\r\n - \ \"20.41.66.192/28\",\r\n \"20.41.193.176/28\",\r\n \"20.41.193.192/27\",\r\n - \ \"20.41.195.160/27\",\r\n \"20.41.208.0/30\",\r\n \"20.42.4.204/30\",\r\n - \ \"20.42.6.144/28\",\r\n \"20.42.6.160/27\",\r\n \"20.42.7.128/27\",\r\n - \ \"20.42.131.240/28\",\r\n \"20.42.227.144/28\",\r\n \"20.42.227.160/27\",\r\n - \ \"20.42.228.128/27\",\r\n \"20.42.230.80/28\",\r\n \"20.43.42.16/28\",\r\n - \ \"20.43.42.32/27\",\r\n \"20.43.43.0/27\",\r\n \"20.43.66.16/28\",\r\n - \ \"20.43.66.32/27\",\r\n \"20.43.67.0/27\",\r\n \"20.43.70.64/28\",\r\n - \ \"20.43.88.240/32\",\r\n \"20.43.121.0/29\",\r\n \"20.43.131.48/28\",\r\n - \ \"20.43.132.0/27\",\r\n \"20.43.132.96/27\",\r\n \"20.44.8.160/29\",\r\n - \ \"20.44.17.16/29\",\r\n \"20.44.19.32/28\",\r\n \"20.44.27.120/29\",\r\n - \ \"20.45.67.213/32\",\r\n \"20.45.112.224/27\",\r\n \"20.45.113.192/27\",\r\n - \ \"20.45.113.224/28\",\r\n \"20.45.125.240/28\",\r\n \"20.45.195.128/27\",\r\n - \ \"20.45.195.224/27\",\r\n \"20.45.196.0/28\",\r\n \"20.49.96.128/27\",\r\n - \ \"20.49.96.160/28\",\r\n \"20.49.99.16/28\",\r\n \"20.49.109.48/28\",\r\n - \ \"20.50.1.16/28\",\r\n \"20.50.1.208/28\",\r\n \"20.150.161.160/27\",\r\n - \ \"20.150.164.128/27\",\r\n \"20.150.164.160/28\",\r\n \"20.184.58.62/32\",\r\n - \ \"20.184.240.78/32\",\r\n \"20.184.241.66/32\",\r\n \"20.184.241.238/32\",\r\n - \ \"20.184.242.113/32\",\r\n \"20.184.242.115/32\",\r\n \"20.184.242.189/32\",\r\n - \ \"20.189.108.64/27\",\r\n \"20.189.109.32/27\",\r\n \"20.189.109.64/28\",\r\n - \ \"20.192.161.144/28\",\r\n \"20.192.161.160/27\",\r\n \"20.192.164.128/27\",\r\n - \ \"20.192.225.208/28\",\r\n \"20.192.225.224/27\",\r\n \"20.192.228.192/27\",\r\n - \ \"23.96.13.121/32\",\r\n \"23.96.229.148/32\",\r\n \"23.97.152.121/32\",\r\n - \ \"23.98.104.80/28\",\r\n \"23.100.0.32/32\",\r\n \"23.100.57.171/32\",\r\n - \ \"23.100.59.49/32\",\r\n \"23.102.65.134/32\",\r\n \"40.64.128.192/27\",\r\n - \ \"40.64.132.96/28\",\r\n \"40.65.114.234/32\",\r\n \"40.67.48.224/27\",\r\n - \ \"40.67.49.192/27\",\r\n \"40.67.49.224/28\",\r\n \"40.67.121.128/28\",\r\n - \ \"40.69.73.194/32\",\r\n \"40.69.104.32/30\",\r\n \"40.70.47.165/32\",\r\n - \ \"40.70.241.203/32\",\r\n \"40.71.15.144/28\",\r\n \"40.74.30.108/30\",\r\n - \ \"40.74.31.64/27\",\r\n \"40.74.31.96/27\",\r\n \"40.74.64.203/32\",\r\n - \ \"40.78.20.224/32\",\r\n \"40.78.204.0/29\",\r\n \"40.78.239.48/28\",\r\n - \ \"40.78.245.208/28\",\r\n \"40.79.132.48/29\",\r\n \"40.79.156.64/27\",\r\n - \ \"40.79.176.32/30\",\r\n \"40.79.187.168/29\",\r\n \"40.79.189.96/28\",\r\n - \ \"40.80.53.16/28\",\r\n \"40.80.57.208/28\",\r\n \"40.80.57.224/27\",\r\n - \ \"40.80.58.192/27\",\r\n \"40.80.169.192/27\",\r\n \"40.80.170.160/27\",\r\n - \ \"40.80.170.192/28\",\r\n \"40.80.176.0/29\",\r\n \"40.80.188.112/28\",\r\n - \ \"40.80.190.128/27\",\r\n \"40.80.190.224/27\",\r\n \"40.82.253.200/30\",\r\n - \ \"40.82.253.208/28\",\r\n \"40.82.255.0/26\",\r\n \"40.82.255.96/27\",\r\n - \ \"40.84.132.239/32\",\r\n \"40.84.228.255/32\",\r\n \"40.85.230.100/32\",\r\n - \ \"40.86.227.247/32\",\r\n \"40.89.17.240/28\",\r\n \"40.89.18.128/27\",\r\n - \ \"40.89.18.224/27\",\r\n \"40.89.133.209/32\",\r\n \"40.89.134.214/32\",\r\n - \ \"40.90.138.4/32\",\r\n \"40.90.139.2/32\",\r\n \"40.90.139.36/32\",\r\n - \ \"40.90.139.163/32\",\r\n \"40.90.141.99/32\",\r\n \"40.112.254.71/32\",\r\n - \ \"40.113.117.57/32\",\r\n \"40.113.124.208/32\",\r\n \"40.113.194.60/32\",\r\n - \ \"40.113.226.173/32\",\r\n \"40.114.78.132/32\",\r\n \"40.114.236.251/32\",\r\n - \ \"40.115.248.103/32\",\r\n \"40.117.86.243/32\",\r\n \"40.117.154.42/32\",\r\n - \ \"40.117.232.90/32\",\r\n \"40.117.237.78/32\",\r\n \"40.119.2.134/32\",\r\n - \ \"40.121.217.232/32\",\r\n \"40.122.42.111/32\",\r\n \"40.123.218.49/32\",\r\n - \ \"40.127.76.4/32\",\r\n \"40.127.76.10/32\",\r\n \"40.127.165.113/32\",\r\n - \ \"51.12.41.48/28\",\r\n \"51.12.41.128/27\",\r\n \"51.12.41.224/27\",\r\n - \ \"51.12.193.48/28\",\r\n \"51.12.193.128/27\",\r\n \"51.12.193.224/27\",\r\n - \ \"51.104.25.240/28\",\r\n \"51.104.27.64/27\",\r\n \"51.104.28.32/27\",\r\n - \ \"51.104.28.224/28\",\r\n \"51.105.67.176/29\",\r\n \"51.105.80.224/27\",\r\n - \ \"51.105.81.192/27\",\r\n \"51.105.81.224/28\",\r\n \"51.105.89.128/27\",\r\n - \ \"51.105.89.224/27\",\r\n \"51.105.90.0/28\",\r\n \"51.105.170.64/32\",\r\n - \ \"51.107.48.240/28\",\r\n \"51.107.49.128/27\",\r\n \"51.107.49.224/27\",\r\n - \ \"51.107.144.224/27\",\r\n \"51.107.145.192/27\",\r\n \"51.107.145.224/28\",\r\n - \ \"51.116.48.144/28\",\r\n \"51.116.48.160/27\",\r\n \"51.116.49.0/27\",\r\n - \ \"51.116.144.144/28\",\r\n \"51.116.144.160/27\",\r\n \"51.116.145.0/27\",\r\n - \ \"51.120.40.240/28\",\r\n \"51.120.41.128/27\",\r\n \"51.120.41.224/27\",\r\n - \ \"51.120.224.224/27\",\r\n \"51.120.225.192/27\",\r\n \"51.120.225.224/28\",\r\n - \ \"51.124.95.46/32\",\r\n \"51.124.140.143/32\",\r\n \"51.137.162.128/27\",\r\n - \ \"51.137.162.224/27\",\r\n \"51.137.163.0/28\",\r\n \"51.138.40.194/32\",\r\n - \ \"51.138.41.75/32\",\r\n \"51.140.5.56/32\",\r\n \"51.140.69.25/32\",\r\n - \ \"51.140.105.165/32\",\r\n \"51.140.138.84/32\",\r\n \"51.140.149.64/28\",\r\n - \ \"51.140.202.0/32\",\r\n \"51.143.192.224/27\",\r\n \"51.143.193.192/27\",\r\n - \ \"51.143.193.224/28\",\r\n \"51.144.83.210/32\",\r\n \"51.145.3.27/32\",\r\n - \ \"51.145.21.195/32\",\r\n \"52.136.48.240/28\",\r\n \"52.136.49.128/27\",\r\n - \ \"52.136.49.224/27\",\r\n \"52.138.41.171/32\",\r\n \"52.138.92.172/30\",\r\n - \ \"52.140.105.192/27\",\r\n \"52.140.106.160/27\",\r\n \"52.140.106.192/28\",\r\n - \ \"52.140.107.112/28\",\r\n \"52.142.81.236/32\",\r\n \"52.142.83.87/32\",\r\n - \ \"52.142.84.66/32\",\r\n \"52.142.85.51/32\",\r\n \"52.143.91.192/28\",\r\n - \ \"52.147.43.145/32\",\r\n \"52.147.44.12/32\",\r\n \"52.147.97.4/30\",\r\n - \ \"52.149.31.64/28\",\r\n \"52.150.139.192/27\",\r\n \"52.150.140.160/27\",\r\n - \ \"52.150.140.192/28\",\r\n \"52.150.152.16/28\",\r\n \"52.152.207.160/28\",\r\n - \ \"52.152.207.192/28\",\r\n \"52.155.218.251/32\",\r\n \"52.156.93.240/28\",\r\n - \ \"52.156.103.64/27\",\r\n \"52.156.103.96/28\",\r\n \"52.161.16.73/32\",\r\n - \ \"52.161.101.86/32\",\r\n \"52.162.110.248/29\",\r\n \"52.163.56.146/32\",\r\n - \ \"52.163.207.80/32\",\r\n \"52.171.134.140/32\",\r\n \"52.172.187.21/32\",\r\n - \ \"52.172.190.71/32\",\r\n \"52.172.191.4/32\",\r\n \"52.173.240.242/32\",\r\n - \ \"52.174.60.141/32\",\r\n \"52.175.18.186/32\",\r\n \"52.175.35.166/32\",\r\n - \ \"52.179.13.227/32\",\r\n \"52.179.14.109/32\",\r\n \"52.179.113.96/27\",\r\n - \ \"52.179.113.128/28\",\r\n \"52.180.162.194/32\",\r\n \"52.180.166.172/32\",\r\n - \ \"52.180.178.146/32\",\r\n \"52.180.179.119/32\",\r\n \"52.183.33.203/32\",\r\n - \ \"52.186.33.48/28\",\r\n \"52.186.91.216/32\",\r\n \"52.187.20.181/32\",\r\n - \ \"52.187.39.99/32\",\r\n \"52.190.33.56/32\",\r\n \"52.190.33.61/32\",\r\n - \ \"52.190.33.154/32\",\r\n \"52.191.14.164/32\",\r\n \"52.191.173.81/32\",\r\n - \ \"52.224.200.129/32\",\r\n \"52.225.176.80/32\",\r\n \"52.228.83.128/27\",\r\n - \ \"52.228.83.224/27\",\r\n \"52.228.84.0/28\",\r\n \"52.228.84.96/28\",\r\n - \ \"52.229.16.14/32\",\r\n \"52.231.74.63/32\",\r\n \"52.231.79.142/32\",\r\n - \ \"52.231.159.35/32\",\r\n \"52.233.66.46/32\",\r\n \"52.233.163.218/32\",\r\n - \ \"52.234.229.248/32\",\r\n \"52.237.137.4/32\",\r\n \"52.243.76.246/32\",\r\n - \ \"52.249.207.163/32\",\r\n \"52.255.83.208/28\",\r\n \"52.255.84.176/28\",\r\n - \ \"52.255.84.192/28\",\r\n \"52.255.124.16/28\",\r\n \"52.255.124.80/28\",\r\n - \ \"52.255.124.96/28\",\r\n \"65.52.205.19/32\",\r\n \"65.52.252.208/29\",\r\n - \ \"102.133.28.72/29\",\r\n \"102.133.56.144/28\",\r\n \"102.133.56.224/27\",\r\n - \ \"102.133.75.174/32\",\r\n \"102.133.123.248/29\",\r\n - \ \"102.133.124.88/29\",\r\n \"102.133.156.128/29\",\r\n - \ \"102.133.162.221/32\",\r\n \"102.133.217.80/28\",\r\n - \ \"102.133.217.96/27\",\r\n \"102.133.218.0/27\",\r\n \"102.133.236.198/32\",\r\n - \ \"104.40.225.182/32\",\r\n \"104.41.216.228/32\",\r\n \"104.42.100.80/32\",\r\n - \ \"104.42.239.93/32\",\r\n \"104.44.89.44/32\",\r\n \"104.46.112.239/32\",\r\n - \ \"104.46.239.137/32\",\r\n \"104.211.88.173/32\",\r\n \"104.211.89.213/32\",\r\n - \ \"104.211.101.116/32\",\r\n \"104.211.222.193/32\",\r\n - \ \"104.214.49.162/32\",\r\n \"104.214.117.155/32\",\r\n - \ \"104.214.233.86/32\",\r\n \"104.215.9.217/32\",\r\n \"104.215.120.160/32\",\r\n - \ \"104.215.146.128/32\",\r\n \"137.116.247.179/32\",\r\n - \ \"137.117.70.195/32\",\r\n \"137.135.45.32/32\",\r\n \"168.61.158.107/32\",\r\n - \ \"168.61.165.229/32\",\r\n \"168.63.20.177/32\",\r\n \"191.232.39.30/32\",\r\n - \ \"191.232.162.204/32\",\r\n \"191.233.10.48/28\",\r\n \"191.233.10.64/27\",\r\n - \ \"191.233.10.128/27\",\r\n \"191.233.205.72/29\",\r\n \"191.235.227.128/27\",\r\n - \ \"191.235.227.224/27\",\r\n \"191.235.228.0/28\",\r\n \"213.199.128.226/32\",\r\n - \ \"2603:1000:104::180/122\",\r\n \"2603:1000:104::380/122\",\r\n - \ \"2603:1000:104:1::640/122\",\r\n \"2603:1010:6::80/122\",\r\n - \ \"2603:1010:6:1::640/122\",\r\n \"2603:1020:5::80/122\",\r\n - \ \"2603:1020:5:1::640/122\",\r\n \"2603:1020:206::80/122\",\r\n - \ \"2603:1020:206:1::640/122\",\r\n \"2603:1020:705::80/122\",\r\n - \ \"2603:1020:705:1::640/122\",\r\n \"2603:1020:805::80/122\",\r\n - \ \"2603:1020:805:1::640/122\",\r\n \"2603:1020:a04::80/122\",\r\n - \ \"2603:1020:a04:1::640/122\",\r\n \"2603:1020:c04::80/122\",\r\n - \ \"2603:1020:c04:1::640/122\",\r\n \"2603:1020:e04::80/122\",\r\n - \ \"2603:1020:e04:1::640/122\",\r\n \"2603:1020:1004::640/122\",\r\n - \ \"2603:1020:1004:1::80/122\",\r\n \"2603:1030:10::80/122\",\r\n - \ \"2603:1030:10:1::640/122\",\r\n \"2603:1030:104::80/122\",\r\n - \ \"2603:1030:104:1::640/122\",\r\n \"2603:1030:210::80/122\",\r\n - \ \"2603:1030:210:1::640/122\",\r\n \"2603:1030:40b:1::640/122\",\r\n - \ \"2603:1030:40c::80/122\",\r\n \"2603:1030:40c:1::640/122\",\r\n - \ \"2603:1030:504::80/122\",\r\n \"2603:1030:504:1::640/122\",\r\n - \ \"2603:1030:807::80/122\",\r\n \"2603:1030:807:1::640/122\",\r\n - \ \"2603:1030:c06:1::640/122\",\r\n \"2603:1030:f05::80/122\",\r\n - \ \"2603:1030:f05:1::640/122\",\r\n \"2603:1040:5::180/122\",\r\n - \ \"2603:1040:5:1::640/122\",\r\n \"2603:1040:407::80/122\",\r\n - \ \"2603:1040:407:1::640/122\",\r\n \"2603:1040:904::80/122\",\r\n - \ \"2603:1040:904:1::640/122\",\r\n \"2603:1040:a06::180/122\",\r\n - \ \"2603:1040:a06:1::640/122\",\r\n \"2603:1040:d04::640/122\",\r\n - \ \"2603:1040:d04:1::80/122\",\r\n \"2603:1040:f05::80/122\",\r\n - \ \"2603:1040:f05:1::640/122\",\r\n \"2603:1050:6::80/122\",\r\n - \ \"2603:1050:6:1::640/122\",\r\n \"2603:1050:403::640/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory\",\r\n - \ \"id\": \"DataFactory\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.66.143.128/28\",\r\n \"13.67.10.208/28\",\r\n - \ \"13.69.67.192/28\",\r\n \"13.69.107.112/28\",\r\n \"13.69.112.128/28\",\r\n - \ \"13.69.230.96/28\",\r\n \"13.70.74.144/28\",\r\n \"13.71.175.80/28\",\r\n - \ \"13.71.199.0/28\",\r\n \"13.73.244.32/28\",\r\n \"13.73.253.96/29\",\r\n - \ \"13.74.108.224/28\",\r\n \"13.75.39.112/28\",\r\n \"13.77.53.160/28\",\r\n - \ \"13.78.109.192/28\",\r\n \"13.86.219.208/28\",\r\n \"13.89.174.192/28\",\r\n - \ \"13.104.248.64/27\",\r\n \"20.37.154.0/23\",\r\n \"20.37.156.0/26\",\r\n - \ \"20.37.193.0/25\",\r\n \"20.37.193.128/26\",\r\n \"20.37.198.224/29\",\r\n - \ \"20.38.80.192/26\",\r\n \"20.38.82.0/23\",\r\n \"20.38.147.224/28\",\r\n - \ \"20.39.8.96/27\",\r\n \"20.39.8.128/26\",\r\n \"20.39.15.0/29\",\r\n - \ \"20.40.206.224/29\",\r\n \"20.41.2.0/23\",\r\n \"20.41.4.0/26\",\r\n - \ \"20.41.64.128/25\",\r\n \"20.41.65.0/26\",\r\n \"20.41.69.8/29\",\r\n - \ \"20.41.192.128/25\",\r\n \"20.41.193.0/26\",\r\n \"20.41.197.112/29\",\r\n - \ \"20.41.198.0/25\",\r\n \"20.41.198.128/26\",\r\n \"20.42.2.0/23\",\r\n - \ \"20.42.4.0/26\",\r\n \"20.42.64.0/28\",\r\n \"20.42.129.64/26\",\r\n - \ \"20.42.132.0/23\",\r\n \"20.42.225.0/25\",\r\n \"20.42.225.128/26\",\r\n - \ \"20.42.230.136/29\",\r\n \"20.43.40.128/25\",\r\n \"20.43.41.0/26\",\r\n - \ \"20.43.44.208/29\",\r\n \"20.43.64.128/25\",\r\n \"20.43.65.0/26\",\r\n - \ \"20.43.70.120/29\",\r\n \"20.43.121.48/28\",\r\n \"20.43.128.128/25\",\r\n - \ \"20.43.130.0/26\",\r\n \"20.44.10.64/28\",\r\n \"20.44.17.80/28\",\r\n - \ \"20.44.27.240/28\",\r\n \"20.45.123.160/28\",\r\n \"20.49.83.224/28\",\r\n - \ \"20.49.102.16/29\",\r\n \"20.49.111.0/29\",\r\n \"20.49.114.24/29\",\r\n - \ \"20.50.68.56/29\",\r\n \"20.150.162.0/23\",\r\n \"20.150.173.16/28\",\r\n - \ \"20.150.181.112/28\",\r\n \"20.189.104.128/25\",\r\n \"20.189.106.0/26\",\r\n - \ \"20.189.109.232/29\",\r\n \"20.192.162.0/23\",\r\n \"20.192.184.96/28\",\r\n - \ \"20.192.226.0/23\",\r\n \"20.192.238.96/28\",\r\n \"20.194.67.192/28\",\r\n - \ \"23.98.83.112/28\",\r\n \"23.98.106.128/29\",\r\n \"40.64.132.232/29\",\r\n - \ \"40.69.108.160/28\",\r\n \"40.70.148.160/28\",\r\n \"40.71.14.32/28\",\r\n - \ \"40.74.24.192/26\",\r\n \"40.74.26.0/23\",\r\n \"40.74.149.64/28\",\r\n - \ \"40.75.35.144/28\",\r\n \"40.78.196.128/28\",\r\n \"40.78.229.96/28\",\r\n - \ \"40.78.236.176/28\",\r\n \"40.78.245.16/28\",\r\n \"40.78.251.192/28\",\r\n - \ \"40.79.132.112/28\",\r\n \"40.79.139.80/28\",\r\n \"40.79.146.240/28\",\r\n - \ \"40.79.163.80/28\",\r\n \"40.79.171.160/28\",\r\n \"40.79.187.208/28\",\r\n - \ \"40.79.195.224/28\",\r\n \"40.80.51.160/28\",\r\n \"40.80.56.128/25\",\r\n - \ \"40.80.57.0/26\",\r\n \"40.80.62.24/29\",\r\n \"40.80.168.128/25\",\r\n - \ \"40.80.169.0/26\",\r\n \"40.80.172.112/29\",\r\n \"40.80.176.96/28\",\r\n - \ \"40.80.185.0/24\",\r\n \"40.80.186.0/25\",\r\n \"40.82.249.64/26\",\r\n - \ \"40.82.250.0/23\",\r\n \"40.89.16.128/25\",\r\n \"40.89.17.0/26\",\r\n - \ \"40.89.20.224/29\",\r\n \"40.113.176.232/29\",\r\n \"40.119.9.0/25\",\r\n - \ \"40.119.9.128/26\",\r\n \"40.120.75.112/28\",\r\n \"51.104.9.32/28\",\r\n - \ \"51.104.24.128/25\",\r\n \"51.104.25.0/26\",\r\n \"51.104.29.216/29\",\r\n - \ \"51.105.67.240/28\",\r\n \"51.105.75.240/28\",\r\n \"51.107.51.40/29\",\r\n - \ \"51.107.52.0/25\",\r\n \"51.107.52.128/26\",\r\n \"51.107.128.0/28\",\r\n - \ \"51.116.245.112/28\",\r\n \"51.116.253.48/28\",\r\n \"51.137.160.128/25\",\r\n - \ \"51.137.161.0/26\",\r\n \"51.137.164.192/29\",\r\n \"51.140.212.112/28\",\r\n - \ \"52.138.92.128/28\",\r\n \"52.138.229.32/28\",\r\n \"52.140.104.128/25\",\r\n - \ \"52.140.105.0/26\",\r\n \"52.140.108.208/29\",\r\n \"52.150.136.192/26\",\r\n - \ \"52.150.137.128/25\",\r\n \"52.150.154.16/29\",\r\n \"52.162.111.48/28\",\r\n - \ \"52.167.107.224/28\",\r\n \"52.182.141.16/28\",\r\n \"52.228.80.128/25\",\r\n - \ \"52.228.81.0/26\",\r\n \"52.228.86.144/29\",\r\n \"52.231.20.64/28\",\r\n - \ \"52.231.148.160/28\",\r\n \"52.236.187.112/28\",\r\n \"52.246.155.224/28\",\r\n - \ \"52.250.228.0/29\",\r\n \"102.133.124.104/29\",\r\n \"102.133.156.136/29\",\r\n - \ \"102.133.216.128/25\",\r\n \"102.133.217.0/26\",\r\n \"102.133.218.248/29\",\r\n - \ \"102.133.251.184/29\",\r\n \"191.233.12.0/23\",\r\n \"191.233.54.224/28\",\r\n - \ \"191.233.205.160/28\",\r\n \"191.234.137.32/29\",\r\n - \ \"191.234.149.0/28\",\r\n \"191.234.157.0/28\",\r\n \"191.235.224.128/25\",\r\n - \ \"191.235.225.0/26\",\r\n \"2603:1000:104::/121\",\r\n - \ \"2603:1000:104::80/122\",\r\n \"2603:1000:104::1c0/122\",\r\n - \ \"2603:1000:104::280/121\",\r\n \"2603:1000:104:1::480/121\",\r\n - \ \"2603:1000:104:1::500/122\",\r\n \"2603:1000:104:1::700/121\",\r\n - \ \"2603:1000:104:1::780/122\",\r\n \"2603:1010:6:1::480/121\",\r\n - \ \"2603:1010:6:1::500/122\",\r\n \"2603:1010:6:1::700/121\",\r\n - \ \"2603:1010:6:1::780/122\",\r\n \"2603:1020:5:1::480/121\",\r\n - \ \"2603:1020:5:1::500/122\",\r\n \"2603:1020:5:1::700/121\",\r\n - \ \"2603:1020:5:1::780/122\",\r\n \"2603:1020:206:1::480/121\",\r\n - \ \"2603:1020:206:1::500/122\",\r\n \"2603:1020:206:1::700/121\",\r\n - \ \"2603:1020:206:1::780/122\",\r\n \"2603:1020:705:1::480/121\",\r\n - \ \"2603:1020:705:1::500/122\",\r\n \"2603:1020:705:1::700/121\",\r\n - \ \"2603:1020:705:1::780/122\",\r\n \"2603:1020:805:1::480/121\",\r\n - \ \"2603:1020:805:1::500/122\",\r\n \"2603:1020:805:1::700/121\",\r\n - \ \"2603:1020:805:1::780/122\",\r\n \"2603:1020:a04:1::480/121\",\r\n - \ \"2603:1020:a04:1::500/122\",\r\n \"2603:1020:a04:1::700/121\",\r\n - \ \"2603:1020:a04:1::780/122\",\r\n \"2603:1020:c04:1::480/121\",\r\n - \ \"2603:1020:c04:1::500/122\",\r\n \"2603:1020:c04:1::700/121\",\r\n - \ \"2603:1020:c04:1::780/122\",\r\n \"2603:1020:e04:1::480/121\",\r\n - \ \"2603:1020:e04:1::500/122\",\r\n \"2603:1020:e04:1::700/121\",\r\n - \ \"2603:1020:e04:1::780/122\",\r\n \"2603:1020:1004::480/121\",\r\n - \ \"2603:1020:1004::500/122\",\r\n \"2603:1020:1004::700/121\",\r\n - \ \"2603:1020:1004::780/122\",\r\n \"2603:1030:10:1::480/121\",\r\n - \ \"2603:1030:10:1::500/122\",\r\n \"2603:1030:10:1::700/121\",\r\n - \ \"2603:1030:10:1::780/122\",\r\n \"2603:1030:104:1::480/121\",\r\n - \ \"2603:1030:104:1::500/122\",\r\n \"2603:1030:104:1::700/121\",\r\n - \ \"2603:1030:104:1::780/122\",\r\n \"2603:1030:210:1::480/121\",\r\n - \ \"2603:1030:210:1::500/122\",\r\n \"2603:1030:210:1::700/121\",\r\n - \ \"2603:1030:210:1::780/122\",\r\n \"2603:1030:40b:1::480/121\",\r\n - \ \"2603:1030:40b:1::500/122\",\r\n \"2603:1030:40c:1::480/121\",\r\n - \ \"2603:1030:40c:1::500/122\",\r\n \"2603:1030:40c:1::700/121\",\r\n - \ \"2603:1030:40c:1::780/122\",\r\n \"2603:1030:504:1::480/121\",\r\n - \ \"2603:1030:504:1::500/122\",\r\n \"2603:1030:504:1::700/121\",\r\n - \ \"2603:1030:504:1::780/122\",\r\n \"2603:1030:807:1::480/121\",\r\n - \ \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::700/121\",\r\n - \ \"2603:1030:807:1::780/122\",\r\n \"2603:1030:c06:1::480/121\",\r\n - \ \"2603:1030:c06:1::500/122\",\r\n \"2603:1030:f05:1::480/121\",\r\n - \ \"2603:1030:f05:1::500/122\",\r\n \"2603:1030:f05:1::700/121\",\r\n - \ \"2603:1030:f05:1::780/122\",\r\n \"2603:1040:5::/121\",\r\n - \ \"2603:1040:5::80/122\",\r\n \"2603:1040:5:1::480/121\",\r\n - \ \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::700/121\",\r\n - \ \"2603:1040:5:1::780/122\",\r\n \"2603:1040:407:1::480/121\",\r\n - \ \"2603:1040:407:1::500/122\",\r\n \"2603:1040:407:1::700/121\",\r\n - \ \"2603:1040:407:1::780/122\",\r\n \"2603:1040:904:1::480/121\",\r\n - \ \"2603:1040:904:1::500/122\",\r\n \"2603:1040:904:1::700/121\",\r\n - \ \"2603:1040:904:1::780/122\",\r\n \"2603:1040:a06::/121\",\r\n - \ \"2603:1040:a06::80/122\",\r\n \"2603:1040:a06:1::480/121\",\r\n - \ \"2603:1040:a06:1::500/122\",\r\n \"2603:1040:a06:1::700/121\",\r\n - \ \"2603:1040:a06:1::780/122\",\r\n \"2603:1040:d04::480/121\",\r\n - \ \"2603:1040:d04::500/122\",\r\n \"2603:1040:d04::700/121\",\r\n - \ \"2603:1040:d04::780/122\",\r\n \"2603:1040:f05:1::480/121\",\r\n - \ \"2603:1040:f05:1::500/122\",\r\n \"2603:1040:f05:1::700/121\",\r\n - \ \"2603:1040:f05:1::780/122\",\r\n \"2603:1050:6:1::480/121\",\r\n - \ \"2603:1050:6:1::500/122\",\r\n \"2603:1050:6:1::700/121\",\r\n - \ \"2603:1050:6:1::780/122\",\r\n \"2603:1050:403::480/121\",\r\n - \ \"2603:1050:403::500/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.AustraliaEast\",\r\n \"id\": \"DataFactory.AustraliaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.70.74.144/28\",\r\n - \ \"20.37.193.0/25\",\r\n \"20.37.193.128/26\",\r\n \"20.37.198.224/29\",\r\n - \ \"40.79.163.80/28\",\r\n \"40.79.171.160/28\",\r\n \"2603:1010:6:1::480/121\",\r\n - \ \"2603:1010:6:1::500/122\",\r\n \"2603:1010:6:1::700/121\",\r\n - \ \"2603:1010:6:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.AustraliaSoutheast\",\r\n \"id\": - \"DataFactory.AustraliaSoutheast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiasoutheast\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.77.53.160/28\",\r\n \"20.42.225.0/25\",\r\n \"20.42.225.128/26\",\r\n - \ \"20.42.230.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"DataFactory.BrazilSouth\",\r\n \"id\": \"DataFactory.BrazilSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"191.233.205.160/28\",\r\n - \ \"191.234.137.32/29\",\r\n \"191.234.149.0/28\",\r\n \"191.234.157.0/28\",\r\n - \ \"191.235.224.128/25\",\r\n \"191.235.225.0/26\",\r\n \"2603:1050:6:1::480/121\",\r\n - \ \"2603:1050:6:1::500/122\",\r\n \"2603:1050:6:1::700/121\",\r\n - \ \"2603:1050:6:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.CanadaCentral\",\r\n \"id\": \"DataFactory.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.71.175.80/28\",\r\n - \ \"20.38.147.224/28\",\r\n \"52.228.80.128/25\",\r\n \"52.228.81.0/26\",\r\n - \ \"52.228.86.144/29\",\r\n \"52.246.155.224/28\",\r\n \"2603:1030:f05:1::480/121\",\r\n - \ \"2603:1030:f05:1::500/122\",\r\n \"2603:1030:f05:1::700/121\",\r\n - \ \"2603:1030:f05:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.CanadaEast\",\r\n \"id\": \"DataFactory.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.69.108.160/28\",\r\n - \ \"40.89.16.128/25\",\r\n \"40.89.17.0/26\",\r\n \"40.89.20.224/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.CentralIndia\",\r\n - \ \"id\": \"DataFactory.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.121.48/28\",\r\n \"40.80.51.160/28\",\r\n - \ \"52.140.104.128/25\",\r\n \"52.140.105.0/26\",\r\n \"52.140.108.208/29\",\r\n - \ \"2603:1040:a06::/121\",\r\n \"2603:1040:a06::80/122\",\r\n - \ \"2603:1040:a06:1::480/121\",\r\n \"2603:1040:a06:1::500/122\",\r\n - \ \"2603:1040:a06:1::700/121\",\r\n \"2603:1040:a06:1::780/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.CentralUS\",\r\n - \ \"id\": \"DataFactory.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.89.174.192/28\",\r\n \"20.37.154.0/23\",\r\n - \ \"20.37.156.0/26\",\r\n \"20.40.206.224/29\",\r\n \"20.44.10.64/28\",\r\n - \ \"52.182.141.16/28\",\r\n \"2603:1030:10:1::480/121\",\r\n - \ \"2603:1030:10:1::500/122\",\r\n \"2603:1030:10:1::700/121\",\r\n - \ \"2603:1030:10:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.EastAsia\",\r\n \"id\": \"DataFactory.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.75.39.112/28\",\r\n - \ \"20.189.104.128/25\",\r\n \"20.189.106.0/26\",\r\n \"20.189.109.232/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.EastUS\",\r\n - \ \"id\": \"DataFactory.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"20.42.2.0/23\",\r\n \"20.42.4.0/26\",\r\n \"20.42.64.0/28\",\r\n - \ \"20.49.111.0/29\",\r\n \"40.71.14.32/28\",\r\n \"40.78.229.96/28\",\r\n - \ \"2603:1030:210:1::480/121\",\r\n \"2603:1030:210:1::500/122\",\r\n - \ \"2603:1030:210:1::700/121\",\r\n \"2603:1030:210:1::780/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.EastUS2\",\r\n - \ \"id\": \"DataFactory.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"20.41.2.0/23\",\r\n \"20.41.4.0/26\",\r\n \"20.44.17.80/28\",\r\n - \ \"20.49.102.16/29\",\r\n \"40.70.148.160/28\",\r\n \"52.167.107.224/28\",\r\n - \ \"2603:1030:40c:1::480/121\",\r\n \"2603:1030:40c:1::500/122\",\r\n - \ \"2603:1030:40c:1::700/121\",\r\n \"2603:1030:40c:1::780/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.EastUS2EUAP\",\r\n - \ \"id\": \"DataFactory.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.8.96/27\",\r\n \"20.39.8.128/26\",\r\n - \ \"20.39.15.0/29\",\r\n \"40.74.149.64/28\",\r\n \"40.75.35.144/28\",\r\n - \ \"52.138.92.128/28\",\r\n \"2603:1030:40b:1::480/121\",\r\n - \ \"2603:1030:40b:1::500/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.FranceCentral\",\r\n \"id\": \"DataFactory.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"20.43.40.128/25\",\r\n - \ \"20.43.41.0/26\",\r\n \"20.43.44.208/29\",\r\n \"40.79.132.112/28\",\r\n - \ \"40.79.139.80/28\",\r\n \"40.79.146.240/28\",\r\n \"2603:1020:805:1::480/121\",\r\n - \ \"2603:1020:805:1::500/122\",\r\n \"2603:1020:805:1::700/121\",\r\n - \ \"2603:1020:805:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.GermanyWestCentral\",\r\n \"id\": - \"DataFactory.GermanyWestCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"51.116.245.112/28\",\r\n \"51.116.253.48/28\",\r\n - \ \"2603:1020:c04:1::480/121\",\r\n \"2603:1020:c04:1::500/122\",\r\n - \ \"2603:1020:c04:1::700/121\",\r\n \"2603:1020:c04:1::780/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.JapanEast\",\r\n - \ \"id\": \"DataFactory.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.78.109.192/28\",\r\n \"20.43.64.128/25\",\r\n - \ \"20.43.65.0/26\",\r\n \"20.43.70.120/29\",\r\n \"40.79.187.208/28\",\r\n - \ \"40.79.195.224/28\",\r\n \"2603:1040:407:1::480/121\",\r\n - \ \"2603:1040:407:1::500/122\",\r\n \"2603:1040:407:1::700/121\",\r\n - \ \"2603:1040:407:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.JapanWest\",\r\n \"id\": \"DataFactory.JapanWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.80.56.128/25\",\r\n - \ \"40.80.57.0/26\",\r\n \"40.80.62.24/29\",\r\n \"40.80.176.96/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.KoreaCentral\",\r\n - \ \"id\": \"DataFactory.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.64.128/25\",\r\n \"20.41.65.0/26\",\r\n - \ \"20.41.69.8/29\",\r\n \"20.44.27.240/28\",\r\n \"20.194.67.192/28\",\r\n - \ \"52.231.20.64/28\",\r\n \"2603:1040:f05:1::480/121\",\r\n - \ \"2603:1040:f05:1::500/122\",\r\n \"2603:1040:f05:1::700/121\",\r\n - \ \"2603:1040:f05:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.KoreaSouth\",\r\n \"id\": \"DataFactory.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.80.168.128/25\",\r\n - \ \"40.80.169.0/26\",\r\n \"40.80.172.112/29\",\r\n \"52.231.148.160/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.NorthCentralUS\",\r\n - \ \"id\": \"DataFactory.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"20.49.114.24/29\",\r\n \"40.80.185.0/24\",\r\n - \ \"40.80.186.0/25\",\r\n \"52.162.111.48/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"DataFactory.NorthEurope\",\r\n - \ \"id\": \"DataFactory.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.230.96/28\",\r\n \"13.74.108.224/28\",\r\n - \ \"20.38.80.192/26\",\r\n \"20.38.82.0/23\",\r\n \"20.50.68.56/29\",\r\n - \ \"52.138.229.32/28\",\r\n \"2603:1020:5:1::480/121\",\r\n - \ \"2603:1020:5:1::500/122\",\r\n \"2603:1020:5:1::700/121\",\r\n - \ \"2603:1020:5:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.NorwayEast\",\r\n \"id\": \"DataFactory.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"2603:1020:e04:1::480/121\",\r\n - \ \"2603:1020:e04:1::500/122\",\r\n \"2603:1020:e04:1::700/121\",\r\n - \ \"2603:1020:e04:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.SouthAfricaNorth\",\r\n \"id\": - \"DataFactory.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"102.133.124.104/29\",\r\n \"102.133.156.136/29\",\r\n - \ \"102.133.216.128/25\",\r\n \"102.133.217.0/26\",\r\n \"102.133.218.248/29\",\r\n - \ \"102.133.251.184/29\",\r\n \"2603:1000:104::/121\",\r\n - \ \"2603:1000:104::80/122\",\r\n \"2603:1000:104::1c0/122\",\r\n - \ \"2603:1000:104::280/121\",\r\n \"2603:1000:104:1::480/121\",\r\n - \ \"2603:1000:104:1::500/122\",\r\n \"2603:1000:104:1::700/121\",\r\n - \ \"2603:1000:104:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.SouthCentralUS\",\r\n \"id\": - \"DataFactory.SouthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.73.244.32/28\",\r\n \"13.73.253.96/29\",\r\n - \ \"13.104.248.64/27\",\r\n \"20.45.123.160/28\",\r\n \"40.119.9.0/25\",\r\n - \ \"40.119.9.128/26\",\r\n \"2603:1030:807:1::480/121\",\r\n - \ \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::700/121\",\r\n - \ \"2603:1030:807:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.SoutheastAsia\",\r\n \"id\": \"DataFactory.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.67.10.208/28\",\r\n - \ \"20.43.128.128/25\",\r\n \"20.43.130.0/26\",\r\n \"23.98.83.112/28\",\r\n - \ \"23.98.106.128/29\",\r\n \"40.78.236.176/28\",\r\n \"2603:1040:5::/121\",\r\n - \ \"2603:1040:5::80/122\",\r\n \"2603:1040:5:1::480/121\",\r\n - \ \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::700/121\",\r\n - \ \"2603:1040:5:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.SouthIndia\",\r\n \"id\": \"DataFactory.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"20.41.192.128/25\",\r\n - \ \"20.41.193.0/26\",\r\n \"20.41.197.112/29\",\r\n \"20.41.198.0/25\",\r\n - \ \"20.41.198.128/26\",\r\n \"20.192.184.96/28\",\r\n \"40.78.196.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.SwitzerlandNorth\",\r\n - \ \"id\": \"DataFactory.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.51.40/29\",\r\n \"51.107.52.0/25\",\r\n - \ \"51.107.52.128/26\",\r\n \"51.107.128.0/28\",\r\n \"2603:1020:a04:1::480/121\",\r\n - \ \"2603:1020:a04:1::500/122\",\r\n \"2603:1020:a04:1::700/121\",\r\n - \ \"2603:1020:a04:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.UAENorth\",\r\n \"id\": \"DataFactory.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.120.75.112/28\",\r\n - \ \"2603:1040:904:1::480/121\",\r\n \"2603:1040:904:1::500/122\",\r\n - \ \"2603:1040:904:1::700/121\",\r\n \"2603:1040:904:1::780/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.UKSouth\",\r\n - \ \"id\": \"DataFactory.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"51.104.9.32/28\",\r\n \"51.104.24.128/25\",\r\n - \ \"51.104.25.0/26\",\r\n \"51.104.29.216/29\",\r\n \"51.105.67.240/28\",\r\n - \ \"51.105.75.240/28\",\r\n \"2603:1020:705:1::480/121\",\r\n - \ \"2603:1020:705:1::500/122\",\r\n \"2603:1020:705:1::700/121\",\r\n - \ \"2603:1020:705:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.UKWest\",\r\n \"id\": \"DataFactory.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"51.137.160.128/25\",\r\n - \ \"51.137.161.0/26\",\r\n \"51.137.164.192/29\",\r\n \"51.140.212.112/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.WestCentralUS\",\r\n - \ \"id\": \"DataFactory.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.199.0/28\",\r\n \"52.150.136.192/26\",\r\n - \ \"52.150.137.128/25\",\r\n \"52.150.154.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"DataFactory.WestEurope\",\r\n - \ \"id\": \"DataFactory.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.69.67.192/28\",\r\n \"13.69.107.112/28\",\r\n - \ \"13.69.112.128/28\",\r\n \"40.74.24.192/26\",\r\n \"40.74.26.0/23\",\r\n - \ \"40.113.176.232/29\",\r\n \"52.236.187.112/28\",\r\n \"2603:1020:206:1::480/121\",\r\n - \ \"2603:1020:206:1::500/122\",\r\n \"2603:1020:206:1::700/121\",\r\n - \ \"2603:1020:206:1::780/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactory.WestUS\",\r\n \"id\": \"DataFactory.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.86.219.208/28\",\r\n - \ \"40.82.249.64/26\",\r\n \"40.82.250.0/23\",\r\n \"52.250.228.0/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.WestUS2\",\r\n - \ \"id\": \"DataFactory.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.66.143.128/28\",\r\n \"20.42.129.64/26\",\r\n - \ \"20.42.132.0/23\",\r\n \"40.64.132.232/29\",\r\n \"40.78.245.16/28\",\r\n - \ \"40.78.251.192/28\",\r\n \"2603:1030:c06:1::480/121\",\r\n - \ \"2603:1030:c06:1::500/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"DataFactoryManagement\",\r\n \"id\": \"DataFactoryManagement\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\": - [\r\n \"13.66.143.128/28\",\r\n \"13.67.10.208/28\",\r\n - \ \"13.69.67.192/28\",\r\n \"13.69.107.112/28\",\r\n \"13.69.112.128/28\",\r\n - \ \"13.69.230.96/28\",\r\n \"13.70.74.144/28\",\r\n \"13.71.175.80/28\",\r\n - \ \"13.71.199.0/28\",\r\n \"13.73.244.32/28\",\r\n \"13.73.253.96/29\",\r\n - \ \"13.74.108.224/28\",\r\n \"13.75.39.112/28\",\r\n \"13.77.53.160/28\",\r\n - \ \"13.78.109.192/28\",\r\n \"13.86.219.208/28\",\r\n \"13.89.174.192/28\",\r\n - \ \"13.104.248.64/27\",\r\n \"20.37.198.224/29\",\r\n \"20.38.147.224/28\",\r\n - \ \"20.39.15.0/29\",\r\n \"20.40.206.224/29\",\r\n \"20.41.69.8/29\",\r\n - \ \"20.41.197.112/29\",\r\n \"20.42.64.0/28\",\r\n \"20.42.230.136/29\",\r\n - \ \"20.43.44.208/29\",\r\n \"20.43.70.120/29\",\r\n \"20.43.121.48/28\",\r\n - \ \"20.44.10.64/28\",\r\n \"20.44.17.80/28\",\r\n \"20.44.27.240/28\",\r\n - \ \"20.45.123.160/28\",\r\n \"20.49.83.224/28\",\r\n \"20.49.102.16/29\",\r\n - \ \"20.49.111.0/29\",\r\n \"20.49.114.24/29\",\r\n \"20.50.68.56/29\",\r\n - \ \"20.150.173.16/28\",\r\n \"20.150.181.112/28\",\r\n \"20.189.109.232/29\",\r\n - \ \"20.192.184.96/28\",\r\n \"20.192.238.96/28\",\r\n \"20.194.67.192/28\",\r\n - \ \"23.98.83.112/28\",\r\n \"23.98.106.128/29\",\r\n \"40.64.132.232/29\",\r\n - \ \"40.69.108.160/28\",\r\n \"40.70.148.160/28\",\r\n \"40.71.14.32/28\",\r\n - \ \"40.74.149.64/28\",\r\n \"40.75.35.144/28\",\r\n \"40.78.196.128/28\",\r\n - \ \"40.78.229.96/28\",\r\n \"40.78.236.176/28\",\r\n \"40.78.245.16/28\",\r\n - \ \"40.78.251.192/28\",\r\n \"40.79.132.112/28\",\r\n \"40.79.139.80/28\",\r\n - \ \"40.79.146.240/28\",\r\n \"40.79.163.80/28\",\r\n \"40.79.171.160/28\",\r\n - \ \"40.79.187.208/28\",\r\n \"40.79.195.224/28\",\r\n \"40.80.51.160/28\",\r\n - \ \"40.80.62.24/29\",\r\n \"40.80.172.112/29\",\r\n \"40.80.176.96/28\",\r\n - \ \"40.89.20.224/29\",\r\n \"40.113.176.232/29\",\r\n \"40.120.75.112/28\",\r\n - \ \"51.104.9.32/28\",\r\n \"51.104.29.216/29\",\r\n \"51.105.67.240/28\",\r\n - \ \"51.105.75.240/28\",\r\n \"51.107.51.40/29\",\r\n \"51.107.128.0/28\",\r\n - \ \"51.116.245.112/28\",\r\n \"51.116.253.48/28\",\r\n \"51.137.164.192/29\",\r\n - \ \"51.140.212.112/28\",\r\n \"52.138.92.128/28\",\r\n \"52.138.229.32/28\",\r\n - \ \"52.140.108.208/29\",\r\n \"52.150.154.16/29\",\r\n \"52.162.111.48/28\",\r\n - \ \"52.167.107.224/28\",\r\n \"52.182.141.16/28\",\r\n \"52.228.86.144/29\",\r\n - \ \"52.231.20.64/28\",\r\n \"52.231.148.160/28\",\r\n \"52.236.187.112/28\",\r\n - \ \"52.246.155.224/28\",\r\n \"52.250.228.0/29\",\r\n \"102.133.124.104/29\",\r\n - \ \"102.133.156.136/29\",\r\n \"102.133.218.248/29\",\r\n - \ \"102.133.251.184/29\",\r\n \"191.233.54.224/28\",\r\n - \ \"191.233.205.160/28\",\r\n \"191.234.137.32/29\",\r\n - \ \"191.234.149.0/28\",\r\n \"191.234.157.0/28\",\r\n \"2603:1000:104::80/122\",\r\n - \ \"2603:1000:104::1c0/122\",\r\n \"2603:1000:104:1::500/122\",\r\n - \ \"2603:1000:104:1::780/122\",\r\n \"2603:1010:6:1::500/122\",\r\n - \ \"2603:1010:6:1::780/122\",\r\n \"2603:1020:5:1::500/122\",\r\n - \ \"2603:1020:5:1::780/122\",\r\n \"2603:1020:206:1::500/122\",\r\n - \ \"2603:1020:206:1::780/122\",\r\n \"2603:1020:705:1::500/122\",\r\n - \ \"2603:1020:705:1::780/122\",\r\n \"2603:1020:805:1::500/122\",\r\n - \ \"2603:1020:805:1::780/122\",\r\n \"2603:1020:a04:1::500/122\",\r\n - \ \"2603:1020:a04:1::780/122\",\r\n \"2603:1020:c04:1::500/122\",\r\n - \ \"2603:1020:c04:1::780/122\",\r\n \"2603:1020:e04:1::500/122\",\r\n - \ \"2603:1020:e04:1::780/122\",\r\n \"2603:1020:1004::500/122\",\r\n - \ \"2603:1020:1004::780/122\",\r\n \"2603:1030:10:1::500/122\",\r\n - \ \"2603:1030:10:1::780/122\",\r\n \"2603:1030:104:1::500/122\",\r\n - \ \"2603:1030:104:1::780/122\",\r\n \"2603:1030:210:1::500/122\",\r\n - \ \"2603:1030:210:1::780/122\",\r\n \"2603:1030:40b:1::500/122\",\r\n - \ \"2603:1030:40c:1::500/122\",\r\n \"2603:1030:40c:1::780/122\",\r\n - \ \"2603:1030:504:1::500/122\",\r\n \"2603:1030:504:1::780/122\",\r\n - \ \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::780/122\",\r\n - \ \"2603:1030:c06:1::500/122\",\r\n \"2603:1030:f05:1::500/122\",\r\n - \ \"2603:1030:f05:1::780/122\",\r\n \"2603:1040:5::80/122\",\r\n - \ \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::780/122\",\r\n - \ \"2603:1040:407:1::500/122\",\r\n \"2603:1040:407:1::780/122\",\r\n - \ \"2603:1040:904:1::500/122\",\r\n \"2603:1040:904:1::780/122\",\r\n - \ \"2603:1040:a06::80/122\",\r\n \"2603:1040:a06:1::500/122\",\r\n - \ \"2603:1040:a06:1::780/122\",\r\n \"2603:1040:d04::500/122\",\r\n - \ \"2603:1040:d04::780/122\",\r\n \"2603:1040:f05:1::500/122\",\r\n - \ \"2603:1040:f05:1::780/122\",\r\n \"2603:1050:6:1::500/122\",\r\n - \ \"2603:1050:6:1::780/122\",\r\n \"2603:1050:403::500/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.138.128/25\",\r\n \"13.69.226.128/25\",\r\n - \ \"13.71.171.0/24\",\r\n \"13.74.106.128/25\",\r\n \"13.75.35.0/24\",\r\n - \ \"13.77.51.0/24\",\r\n \"13.78.107.0/24\",\r\n \"40.78.242.0/25\",\r\n - \ \"40.79.138.192/26\",\r\n \"51.140.147.0/24\",\r\n \"65.52.252.128/27\",\r\n - \ \"102.133.251.96/27\",\r\n \"104.211.80.0/24\",\r\n \"191.233.202.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.AustraliaSoutheast\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.51.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.BrazilSouth\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.202.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.CanadaCentral\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.171.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.CentralIndia\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"104.211.80.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.EastAsia\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.35.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.FranceCentral\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.138.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.JapanEast\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.107.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.NorthEurope\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.226.128/25\",\r\n \"13.74.106.128/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.SouthAfricaNorth\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.251.96/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.UAENorth\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"65.52.252.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.UKSouth\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"51.140.147.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.WestUS2\",\r\n - \ \"id\": \"Dynamics365ForMarketingEmail.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.138.128/25\",\r\n \"40.78.242.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub\",\r\n - \ \"id\": \"EventHub\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.64.195.117/32\",\r\n \"13.65.209.24/32\",\r\n - \ \"13.66.138.64/28\",\r\n \"13.66.145.128/26\",\r\n \"13.66.228.204/32\",\r\n - \ \"13.66.230.42/32\",\r\n \"13.67.8.64/27\",\r\n \"13.68.20.101/32\",\r\n - \ \"13.68.21.169/32\",\r\n \"13.68.77.215/32\",\r\n \"13.69.64.0/26\",\r\n - \ \"13.69.106.0/26\",\r\n \"13.69.227.0/26\",\r\n \"13.69.253.135/32\",\r\n - \ \"13.69.255.140/32\",\r\n \"13.70.72.0/28\",\r\n \"13.70.79.16/28\",\r\n - \ \"13.71.30.214/32\",\r\n \"13.71.123.78/32\",\r\n \"13.71.154.11/32\",\r\n - \ \"13.71.170.16/28\",\r\n \"13.71.194.64/27\",\r\n \"13.72.254.134/32\",\r\n - \ \"13.74.107.0/26\",\r\n \"13.75.34.64/26\",\r\n \"13.76.179.223/32\",\r\n - \ \"13.76.216.217/32\",\r\n \"13.77.50.32/27\",\r\n \"13.78.106.64/28\",\r\n - \ \"13.78.149.209/32\",\r\n \"13.78.150.233/32\",\r\n \"13.78.191.44/32\",\r\n - \ \"13.84.145.196/32\",\r\n \"13.87.34.139/32\",\r\n \"13.87.34.243/32\",\r\n - \ \"13.87.56.32/27\",\r\n \"13.87.102.63/32\",\r\n \"13.87.102.68/32\",\r\n - \ \"13.87.122.32/27\",\r\n \"13.88.20.117/32\",\r\n \"13.88.26.28/32\",\r\n - \ \"13.89.58.37/32\",\r\n \"13.89.59.231/32\",\r\n \"13.89.170.128/26\",\r\n - \ \"13.90.83.7/32\",\r\n \"13.90.208.184/32\",\r\n \"13.91.61.11/32\",\r\n - \ \"13.92.124.151/32\",\r\n \"13.92.180.208/32\",\r\n \"13.92.190.184/32\",\r\n - \ \"13.93.226.138/32\",\r\n \"13.94.47.61/32\",\r\n \"20.36.46.142/32\",\r\n - \ \"20.36.74.130/32\",\r\n \"20.36.106.192/27\",\r\n \"20.36.114.32/27\",\r\n - \ \"20.37.74.0/27\",\r\n \"20.38.146.64/26\",\r\n \"20.42.131.16/28\",\r\n - \ \"20.42.131.64/26\",\r\n \"20.44.2.128/26\",\r\n \"20.44.26.64/26\",\r\n - \ \"20.45.122.64/26\",\r\n \"20.150.160.224/27\",\r\n \"20.150.170.160/27\",\r\n - \ \"20.150.178.64/26\",\r\n \"20.150.186.64/26\",\r\n \"20.192.98.64/26\",\r\n - \ \"20.192.161.64/27\",\r\n \"20.192.225.160/27\",\r\n \"20.192.234.32/27\",\r\n - \ \"20.193.202.32/27\",\r\n \"23.96.214.181/32\",\r\n \"23.96.253.236/32\",\r\n - \ \"23.97.67.90/32\",\r\n \"23.97.97.36/32\",\r\n \"23.97.103.3/32\",\r\n - \ \"23.97.226.21/32\",\r\n \"23.98.64.92/32\",\r\n \"23.98.65.24/32\",\r\n - \ \"23.98.82.64/27\",\r\n \"23.99.7.105/32\",\r\n \"23.99.54.235/32\",\r\n - \ \"23.99.60.253/32\",\r\n \"23.99.80.186/32\",\r\n \"23.99.118.48/32\",\r\n - \ \"23.99.128.69/32\",\r\n \"23.99.129.170/32\",\r\n \"23.99.192.254/32\",\r\n - \ \"23.99.196.56/32\",\r\n \"23.99.228.174/32\",\r\n \"23.100.14.185/32\",\r\n - \ \"23.100.100.84/32\",\r\n \"23.101.3.68/32\",\r\n \"23.101.8.229/32\",\r\n - \ \"23.102.0.186/32\",\r\n \"23.102.0.239/32\",\r\n \"23.102.53.113/32\",\r\n - \ \"23.102.128.15/32\",\r\n \"23.102.160.39/32\",\r\n \"23.102.161.227/32\",\r\n - \ \"23.102.163.4/32\",\r\n \"23.102.165.127/32\",\r\n \"23.102.167.73/32\",\r\n - \ \"23.102.180.26/32\",\r\n \"23.102.234.49/32\",\r\n \"40.67.58.128/26\",\r\n - \ \"40.68.35.230/32\",\r\n \"40.68.39.15/32\",\r\n \"40.68.93.145/32\",\r\n - \ \"40.68.205.113/32\",\r\n \"40.68.217.242/32\",\r\n \"40.69.29.216/32\",\r\n - \ \"40.69.106.32/27\",\r\n \"40.69.217.246/32\",\r\n \"40.70.78.154/32\",\r\n - \ \"40.70.146.0/26\",\r\n \"40.71.10.128/26\",\r\n \"40.71.100.98/32\",\r\n - \ \"40.74.100.0/27\",\r\n \"40.74.141.187/32\",\r\n \"40.74.146.16/28\",\r\n - \ \"40.75.34.0/28\",\r\n \"40.76.29.197/32\",\r\n \"40.76.40.11/32\",\r\n - \ \"40.76.194.119/32\",\r\n \"40.78.110.196/32\",\r\n \"40.78.194.32/27\",\r\n - \ \"40.78.202.32/27\",\r\n \"40.78.226.128/26\",\r\n \"40.78.234.0/27\",\r\n - \ \"40.78.242.128/28\",\r\n \"40.78.247.0/26\",\r\n \"40.78.250.64/28\",\r\n - \ \"40.78.253.128/26\",\r\n \"40.79.44.59/32\",\r\n \"40.79.74.86/32\",\r\n - \ \"40.79.130.16/28\",\r\n \"40.79.138.0/28\",\r\n \"40.79.146.0/28\",\r\n - \ \"40.79.155.0/26\",\r\n \"40.79.162.0/28\",\r\n \"40.79.170.32/28\",\r\n - \ \"40.79.178.32/27\",\r\n \"40.79.186.32/27\",\r\n \"40.79.194.192/26\",\r\n - \ \"40.80.50.64/26\",\r\n \"40.83.191.202/32\",\r\n \"40.83.222.100/32\",\r\n - \ \"40.84.150.241/32\",\r\n \"40.84.185.67/32\",\r\n \"40.85.226.62/32\",\r\n - \ \"40.85.229.32/32\",\r\n \"40.86.77.12/32\",\r\n \"40.86.102.100/32\",\r\n - \ \"40.86.176.23/32\",\r\n \"40.86.225.142/32\",\r\n \"40.86.230.119/32\",\r\n - \ \"40.112.185.115/32\",\r\n \"40.112.213.11/32\",\r\n \"40.112.242.0/25\",\r\n - \ \"40.115.79.2/32\",\r\n \"40.117.88.66/32\",\r\n \"40.120.75.64/27\",\r\n - \ \"40.121.84.50/32\",\r\n \"40.121.141.232/32\",\r\n \"40.121.148.193/32\",\r\n - \ \"40.122.173.108/32\",\r\n \"40.122.213.155/32\",\r\n \"40.127.83.123/32\",\r\n - \ \"40.127.132.254/32\",\r\n \"51.12.98.160/27\",\r\n \"51.12.202.160/27\",\r\n - \ \"51.12.226.64/26\",\r\n \"51.12.234.64/26\",\r\n \"51.105.66.64/26\",\r\n - \ \"51.105.74.64/26\",\r\n \"51.107.58.128/27\",\r\n \"51.107.154.128/27\",\r\n - \ \"51.116.58.128/27\",\r\n \"51.116.154.192/27\",\r\n \"51.116.242.64/26\",\r\n - \ \"51.116.245.192/27\",\r\n \"51.116.250.64/26\",\r\n \"51.120.98.128/27\",\r\n - \ \"51.120.106.64/26\",\r\n \"51.120.210.64/26\",\r\n \"51.120.218.160/27\",\r\n - \ \"51.140.80.99/32\",\r\n \"51.140.87.93/32\",\r\n \"51.140.125.8/32\",\r\n - \ \"51.140.146.32/28\",\r\n \"51.140.189.52/32\",\r\n \"51.140.189.108/32\",\r\n - \ \"51.140.210.32/27\",\r\n \"51.141.14.113/32\",\r\n \"51.141.14.168/32\",\r\n - \ \"51.141.50.179/32\",\r\n \"51.144.238.23/32\",\r\n \"52.136.136.62/32\",\r\n - \ \"52.138.90.0/28\",\r\n \"52.138.147.148/32\",\r\n \"52.138.226.0/26\",\r\n - \ \"52.143.136.55/32\",\r\n \"52.151.58.121/32\",\r\n \"52.161.19.160/32\",\r\n - \ \"52.161.24.64/32\",\r\n \"52.162.106.64/26\",\r\n \"52.165.34.144/32\",\r\n - \ \"52.165.179.109/32\",\r\n \"52.165.235.119/32\",\r\n \"52.165.237.8/32\",\r\n - \ \"52.167.106.0/26\",\r\n \"52.168.14.144/32\",\r\n \"52.168.66.180/32\",\r\n - \ \"52.168.146.69/32\",\r\n \"52.168.147.11/32\",\r\n \"52.169.18.8/32\",\r\n - \ \"52.172.221.245/32\",\r\n \"52.172.223.211/32\",\r\n \"52.173.199.106/32\",\r\n - \ \"52.174.243.57/32\",\r\n \"52.175.35.235/32\",\r\n \"52.176.47.198/32\",\r\n - \ \"52.178.78.61/32\",\r\n \"52.178.211.227/32\",\r\n \"52.179.6.240/32\",\r\n - \ \"52.179.8.35/32\",\r\n \"52.179.157.59/32\",\r\n \"52.180.180.228/32\",\r\n - \ \"52.180.182.75/32\",\r\n \"52.182.138.128/26\",\r\n \"52.183.46.73/32\",\r\n - \ \"52.183.86.102/32\",\r\n \"52.187.2.226/32\",\r\n \"52.187.59.188/32\",\r\n - \ \"52.187.61.82/32\",\r\n \"52.187.185.159/32\",\r\n \"52.191.213.188/32\",\r\n - \ \"52.225.184.224/32\",\r\n \"52.225.186.130/32\",\r\n \"52.226.36.235/32\",\r\n - \ \"52.231.18.16/28\",\r\n \"52.231.29.105/32\",\r\n \"52.231.32.85/32\",\r\n - \ \"52.231.32.94/32\",\r\n \"52.231.146.32/27\",\r\n \"52.231.200.144/32\",\r\n - \ \"52.231.200.153/32\",\r\n \"52.231.207.155/32\",\r\n \"52.232.27.189/32\",\r\n - \ \"52.233.30.41/32\",\r\n \"52.233.190.35/32\",\r\n \"52.233.192.247/32\",\r\n - \ \"52.236.186.0/26\",\r\n \"52.237.33.36/32\",\r\n \"52.237.33.104/32\",\r\n - \ \"52.237.143.176/32\",\r\n \"52.242.20.204/32\",\r\n \"52.243.36.161/32\",\r\n - \ \"52.246.154.64/26\",\r\n \"65.52.129.16/32\",\r\n \"65.52.250.32/27\",\r\n - \ \"102.133.26.128/26\",\r\n \"102.133.122.64/26\",\r\n \"102.133.154.128/26\",\r\n - \ \"102.133.250.64/26\",\r\n \"104.40.26.199/32\",\r\n \"104.40.29.113/32\",\r\n - \ \"104.40.68.250/32\",\r\n \"104.40.69.64/32\",\r\n \"104.40.150.139/32\",\r\n - \ \"104.40.179.185/32\",\r\n \"104.40.216.174/32\",\r\n \"104.41.63.213/32\",\r\n - \ \"104.41.201.10/32\",\r\n \"104.42.97.95/32\",\r\n \"104.43.18.219/32\",\r\n - \ \"104.43.168.200/32\",\r\n \"104.43.192.43/32\",\r\n \"104.43.192.222/32\",\r\n - \ \"104.44.129.14/32\",\r\n \"104.44.129.59/32\",\r\n \"104.45.135.34/32\",\r\n - \ \"104.45.147.24/32\",\r\n \"104.46.32.56/32\",\r\n \"104.46.32.58/32\",\r\n - \ \"104.46.98.9/32\",\r\n \"104.46.98.73/32\",\r\n \"104.46.99.176/32\",\r\n - \ \"104.208.16.0/26\",\r\n \"104.208.144.0/26\",\r\n \"104.208.237.147/32\",\r\n - \ \"104.209.186.70/32\",\r\n \"104.210.14.49/32\",\r\n \"104.210.106.31/32\",\r\n - \ \"104.210.146.250/32\",\r\n \"104.211.81.0/28\",\r\n \"104.211.98.185/32\",\r\n - \ \"104.211.102.58/32\",\r\n \"104.211.146.32/27\",\r\n \"104.211.160.121/32\",\r\n - \ \"104.211.160.144/32\",\r\n \"104.211.224.190/32\",\r\n - \ \"104.211.224.238/32\",\r\n \"104.214.18.128/27\",\r\n - \ \"104.214.70.229/32\",\r\n \"137.116.48.46/32\",\r\n \"137.116.77.157/32\",\r\n - \ \"137.116.91.178/32\",\r\n \"137.116.157.26/32\",\r\n \"137.116.158.30/32\",\r\n - \ \"137.117.85.236/32\",\r\n \"137.117.89.253/32\",\r\n \"137.117.91.152/32\",\r\n - \ \"137.135.102.226/32\",\r\n \"138.91.1.105/32\",\r\n \"138.91.17.38/32\",\r\n - \ \"138.91.17.85/32\",\r\n \"138.91.193.184/32\",\r\n \"168.61.92.197/32\",\r\n - \ \"168.61.148.205/32\",\r\n \"168.62.52.235/32\",\r\n \"168.62.234.250/32\",\r\n - \ \"168.62.237.3/32\",\r\n \"168.62.249.226/32\",\r\n \"168.63.141.27/32\",\r\n - \ \"191.233.9.64/27\",\r\n \"191.233.73.228/32\",\r\n \"191.233.203.0/28\",\r\n - \ \"191.234.146.64/26\",\r\n \"191.234.154.64/26\",\r\n \"191.236.32.73/32\",\r\n - \ \"191.236.32.191/32\",\r\n \"191.236.35.225/32\",\r\n \"191.236.128.253/32\",\r\n - \ \"191.236.129.107/32\",\r\n \"191.237.47.93/32\",\r\n \"191.237.129.158/32\",\r\n - \ \"191.238.99.131/32\",\r\n \"191.238.160.221/32\",\r\n - \ \"191.239.64.142/32\",\r\n \"191.239.64.144/32\",\r\n \"191.239.160.45/32\",\r\n - \ \"191.239.160.178/32\",\r\n \"207.46.153.127/32\",\r\n - \ \"207.46.154.16/32\",\r\n \"207.46.227.14/32\",\r\n \"2603:1000:104:1::240/122\",\r\n - \ \"2603:1010:6:1::240/122\",\r\n \"2603:1020:5:1::240/122\",\r\n - \ \"2603:1020:206:1::240/122\",\r\n \"2603:1020:705:1::240/122\",\r\n - \ \"2603:1020:805:1::240/122\",\r\n \"2603:1020:a04:1::240/122\",\r\n - \ \"2603:1020:c04:1::240/122\",\r\n \"2603:1020:e04:1::240/122\",\r\n - \ \"2603:1020:1004::240/122\",\r\n \"2603:1030:10:1::240/122\",\r\n - \ \"2603:1030:104:1::240/122\",\r\n \"2603:1030:210:1::240/122\",\r\n - \ \"2603:1030:40b:1::240/122\",\r\n \"2603:1030:40c:1::240/122\",\r\n - \ \"2603:1030:504:1::240/122\",\r\n \"2603:1030:807:1::240/122\",\r\n - \ \"2603:1030:c06:1::240/122\",\r\n \"2603:1030:f05:1::240/122\",\r\n - \ \"2603:1040:5:1::240/122\",\r\n \"2603:1040:407:1::240/122\",\r\n - \ \"2603:1040:904:1::240/122\",\r\n \"2603:1040:a06:1::240/122\",\r\n - \ \"2603:1040:d04::240/122\",\r\n \"2603:1040:f05:1::240/122\",\r\n - \ \"2603:1050:6:1::240/122\",\r\n \"2603:1050:403::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.AustraliaCentral\",\r\n - \ \"id\": \"EventHub.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.46.142/32\",\r\n \"20.36.106.192/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.AustraliaCentral2\",\r\n - \ \"id\": \"EventHub.AustraliaCentral2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.74.130/32\",\r\n \"20.36.114.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.AustraliaEast\",\r\n - \ \"id\": \"EventHub.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.70.72.0/28\",\r\n \"13.70.79.16/28\",\r\n \"13.72.254.134/32\",\r\n - \ \"40.79.162.0/28\",\r\n \"40.79.170.32/28\",\r\n \"104.210.106.31/32\",\r\n - \ \"191.239.64.142/32\",\r\n \"191.239.64.144/32\",\r\n \"2603:1010:6:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.AustraliaSoutheast\",\r\n - \ \"id\": \"EventHub.AustraliaSoutheast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.50.32/27\",\r\n \"40.115.79.2/32\",\r\n - \ \"40.127.83.123/32\",\r\n \"191.239.160.45/32\",\r\n \"191.239.160.178/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.BrazilSouth\",\r\n - \ \"id\": \"EventHub.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"23.97.97.36/32\",\r\n \"23.97.103.3/32\",\r\n \"104.41.63.213/32\",\r\n - \ \"191.233.203.0/28\",\r\n \"191.234.146.64/26\",\r\n \"191.234.154.64/26\",\r\n - \ \"2603:1050:6:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.CanadaCentral\",\r\n \"id\": \"EventHub.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.16/28\",\r\n - \ \"20.38.146.64/26\",\r\n \"40.85.226.62/32\",\r\n \"40.85.229.32/32\",\r\n - \ \"52.233.30.41/32\",\r\n \"52.237.33.36/32\",\r\n \"52.237.33.104/32\",\r\n - \ \"52.246.154.64/26\",\r\n \"2603:1030:f05:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.CanadaEast\",\r\n - \ \"id\": \"EventHub.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"40.69.106.32/27\",\r\n \"40.86.225.142/32\",\r\n - \ \"40.86.230.119/32\",\r\n \"52.242.20.204/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"EventHub.CentralIndia\",\r\n - \ \"id\": \"EventHub.CentralIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.71.30.214/32\",\r\n \"20.192.98.64/26\",\r\n - \ \"40.80.50.64/26\",\r\n \"52.172.221.245/32\",\r\n \"52.172.223.211/32\",\r\n - \ \"104.211.81.0/28\",\r\n \"104.211.98.185/32\",\r\n \"104.211.102.58/32\",\r\n - \ \"2603:1040:a06:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.CentralUS\",\r\n \"id\": \"EventHub.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.89.58.37/32\",\r\n - \ \"13.89.59.231/32\",\r\n \"13.89.170.128/26\",\r\n \"23.99.128.69/32\",\r\n - \ \"23.99.129.170/32\",\r\n \"23.99.192.254/32\",\r\n \"23.99.196.56/32\",\r\n - \ \"23.99.228.174/32\",\r\n \"40.86.77.12/32\",\r\n \"40.86.102.100/32\",\r\n - \ \"40.122.173.108/32\",\r\n \"40.122.213.155/32\",\r\n \"52.165.34.144/32\",\r\n - \ \"52.165.179.109/32\",\r\n \"52.165.235.119/32\",\r\n \"52.165.237.8/32\",\r\n - \ \"52.173.199.106/32\",\r\n \"52.176.47.198/32\",\r\n \"52.182.138.128/26\",\r\n - \ \"104.43.168.200/32\",\r\n \"104.43.192.43/32\",\r\n \"104.43.192.222/32\",\r\n - \ \"104.208.16.0/26\",\r\n \"168.61.148.205/32\",\r\n \"2603:1030:10:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.CentralUSEUAP\",\r\n - \ \"id\": \"EventHub.CentralUSEUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"40.78.202.32/27\",\r\n \"52.180.180.228/32\",\r\n - \ \"52.180.182.75/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.EastAsia\",\r\n \"id\": \"EventHub.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.75.34.64/26\",\r\n - \ \"13.94.47.61/32\",\r\n \"23.97.67.90/32\",\r\n \"23.99.118.48/32\",\r\n - \ \"23.101.3.68/32\",\r\n \"23.101.8.229/32\",\r\n \"23.102.234.49/32\",\r\n - \ \"52.175.35.235/32\",\r\n \"168.63.141.27/32\",\r\n \"207.46.153.127/32\",\r\n - \ \"207.46.154.16/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.EastUS\",\r\n \"id\": \"EventHub.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.90.83.7/32\",\r\n - \ \"13.90.208.184/32\",\r\n \"13.92.124.151/32\",\r\n \"13.92.180.208/32\",\r\n - \ \"13.92.190.184/32\",\r\n \"40.71.10.128/26\",\r\n \"40.71.100.98/32\",\r\n - \ \"40.76.29.197/32\",\r\n \"40.76.40.11/32\",\r\n \"40.76.194.119/32\",\r\n - \ \"40.78.226.128/26\",\r\n \"40.79.155.0/26\",\r\n \"40.117.88.66/32\",\r\n - \ \"40.121.84.50/32\",\r\n \"40.121.141.232/32\",\r\n \"40.121.148.193/32\",\r\n - \ \"52.168.14.144/32\",\r\n \"52.168.66.180/32\",\r\n \"52.168.146.69/32\",\r\n - \ \"52.168.147.11/32\",\r\n \"52.179.6.240/32\",\r\n \"52.179.8.35/32\",\r\n - \ \"52.191.213.188/32\",\r\n \"52.226.36.235/32\",\r\n \"104.45.135.34/32\",\r\n - \ \"104.45.147.24/32\",\r\n \"137.117.85.236/32\",\r\n \"137.117.89.253/32\",\r\n - \ \"137.117.91.152/32\",\r\n \"137.135.102.226/32\",\r\n - \ \"168.62.52.235/32\",\r\n \"191.236.32.73/32\",\r\n \"191.236.32.191/32\",\r\n - \ \"191.236.35.225/32\",\r\n \"191.237.47.93/32\",\r\n \"2603:1030:210:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.EastUS2\",\r\n - \ \"id\": \"EventHub.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.68.20.101/32\",\r\n \"13.68.21.169/32\",\r\n - \ \"13.68.77.215/32\",\r\n \"40.70.78.154/32\",\r\n \"40.70.146.0/26\",\r\n - \ \"40.79.44.59/32\",\r\n \"40.79.74.86/32\",\r\n \"52.167.106.0/26\",\r\n - \ \"52.179.157.59/32\",\r\n \"104.46.98.9/32\",\r\n \"104.46.98.73/32\",\r\n - \ \"104.46.99.176/32\",\r\n \"104.208.144.0/26\",\r\n \"104.208.237.147/32\",\r\n - \ \"104.209.186.70/32\",\r\n \"104.210.14.49/32\",\r\n \"137.116.48.46/32\",\r\n - \ \"137.116.77.157/32\",\r\n \"137.116.91.178/32\",\r\n \"191.237.129.158/32\",\r\n - \ \"2603:1030:40c:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.EastUS2EUAP\",\r\n \"id\": \"EventHub.EastUS2EUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.16/28\",\r\n - \ \"40.75.34.0/28\",\r\n \"52.138.90.0/28\",\r\n \"52.225.184.224/32\",\r\n - \ \"52.225.186.130/32\",\r\n \"2603:1030:40b:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.FranceCentral\",\r\n - \ \"id\": \"EventHub.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"40.79.130.16/28\",\r\n \"40.79.138.0/28\",\r\n \"40.79.146.0/28\",\r\n - \ \"52.143.136.55/32\",\r\n \"2603:1020:805:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.FranceSouth\",\r\n - \ \"id\": \"EventHub.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"40.79.178.32/27\",\r\n \"52.136.136.62/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.GermanyNorth\",\r\n - \ \"id\": \"EventHub.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"51.116.58.128/27\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.GermanyWestCentral\",\r\n \"id\": - \"EventHub.GermanyWestCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"51.116.154.192/27\",\r\n \"51.116.242.64/26\",\r\n - \ \"51.116.245.192/27\",\r\n \"51.116.250.64/26\",\r\n \"2603:1020:c04:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.JapanEast\",\r\n - \ \"id\": \"EventHub.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.71.154.11/32\",\r\n \"13.78.106.64/28\",\r\n - \ \"23.100.100.84/32\",\r\n \"40.79.186.32/27\",\r\n \"40.79.194.192/26\",\r\n - \ \"52.243.36.161/32\",\r\n \"138.91.1.105/32\",\r\n \"2603:1040:407:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.JapanWest\",\r\n - \ \"id\": \"EventHub.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.0/27\",\r\n \"40.74.141.187/32\",\r\n - \ \"138.91.17.38/32\",\r\n \"138.91.17.85/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"EventHub.KoreaCentral\",\r\n - \ \"id\": \"EventHub.KoreaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"20.44.26.64/26\",\r\n \"52.231.18.16/28\",\r\n \"52.231.29.105/32\",\r\n - \ \"52.231.32.85/32\",\r\n \"52.231.32.94/32\",\r\n \"2603:1040:f05:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.KoreaSouth\",\r\n - \ \"id\": \"EventHub.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"52.231.146.32/27\",\r\n \"52.231.200.144/32\",\r\n - \ \"52.231.200.153/32\",\r\n \"52.231.207.155/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"EventHub.NorthCentralUS\",\r\n - \ \"id\": \"EventHub.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"23.96.214.181/32\",\r\n \"23.96.253.236/32\",\r\n - \ \"52.162.106.64/26\",\r\n \"52.237.143.176/32\",\r\n \"168.62.234.250/32\",\r\n - \ \"168.62.237.3/32\",\r\n \"168.62.249.226/32\",\r\n \"191.236.128.253/32\",\r\n - \ \"191.236.129.107/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.NorthEurope\",\r\n \"id\": \"EventHub.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.69.227.0/26\",\r\n - \ \"13.69.253.135/32\",\r\n \"13.69.255.140/32\",\r\n \"13.74.107.0/26\",\r\n - \ \"23.102.0.186/32\",\r\n \"23.102.0.239/32\",\r\n \"23.102.53.113/32\",\r\n - \ \"40.69.29.216/32\",\r\n \"40.69.217.246/32\",\r\n \"40.127.132.254/32\",\r\n - \ \"52.138.147.148/32\",\r\n \"52.138.226.0/26\",\r\n \"52.169.18.8/32\",\r\n - \ \"52.178.211.227/32\",\r\n \"104.41.201.10/32\",\r\n \"168.61.92.197/32\",\r\n - \ \"191.238.99.131/32\",\r\n \"2603:1020:5:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.NorwayEast\",\r\n - \ \"id\": \"EventHub.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"51.120.98.128/27\",\r\n \"51.120.106.64/26\",\r\n - \ \"51.120.210.64/26\",\r\n \"2603:1020:e04:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.NorwayWest\",\r\n - \ \"id\": \"EventHub.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"51.120.218.160/27\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.SouthAfricaNorth\",\r\n \"id\": \"EventHub.SouthAfricaNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"102.133.122.64/26\",\r\n - \ \"102.133.154.128/26\",\r\n \"102.133.250.64/26\",\r\n - \ \"2603:1000:104:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.SouthAfricaWest\",\r\n \"id\": \"EventHub.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.128/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SouthCentralUS\",\r\n - \ \"id\": \"EventHub.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.209.24/32\",\r\n \"13.84.145.196/32\",\r\n - \ \"20.45.122.64/26\",\r\n \"23.102.128.15/32\",\r\n \"23.102.160.39/32\",\r\n - \ \"23.102.161.227/32\",\r\n \"23.102.163.4/32\",\r\n \"23.102.165.127/32\",\r\n - \ \"23.102.167.73/32\",\r\n \"23.102.180.26/32\",\r\n \"40.84.150.241/32\",\r\n - \ \"40.84.185.67/32\",\r\n \"104.44.129.14/32\",\r\n \"104.44.129.59/32\",\r\n - \ \"104.210.146.250/32\",\r\n \"104.214.18.128/27\",\r\n - \ \"104.214.70.229/32\",\r\n \"191.238.160.221/32\",\r\n - \ \"2603:1030:807:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.SoutheastAsia\",\r\n \"id\": \"EventHub.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.64/27\",\r\n - \ \"13.76.179.223/32\",\r\n \"13.76.216.217/32\",\r\n \"23.98.64.92/32\",\r\n - \ \"23.98.65.24/32\",\r\n \"23.98.82.64/27\",\r\n \"40.78.234.0/27\",\r\n - \ \"52.187.2.226/32\",\r\n \"52.187.59.188/32\",\r\n \"52.187.61.82/32\",\r\n - \ \"52.187.185.159/32\",\r\n \"104.43.18.219/32\",\r\n \"137.116.157.26/32\",\r\n - \ \"137.116.158.30/32\",\r\n \"207.46.227.14/32\",\r\n \"2603:1040:5:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SouthIndia\",\r\n - \ \"id\": \"EventHub.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.71.123.78/32\",\r\n \"40.78.194.32/27\",\r\n - \ \"104.211.224.190/32\",\r\n \"104.211.224.238/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SwitzerlandNorth\",\r\n - \ \"id\": \"EventHub.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.58.128/27\",\r\n \"2603:1020:a04:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SwitzerlandWest\",\r\n - \ \"id\": \"EventHub.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.154.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"EventHub.UAECentral\",\r\n - \ \"id\": \"EventHub.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"20.37.74.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.UAENorth\",\r\n \"id\": \"EventHub.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.120.75.64/27\",\r\n - \ \"65.52.250.32/27\",\r\n \"2603:1040:904:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.UKNorth\",\r\n - \ \"id\": \"EventHub.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.87.102.63/32\",\r\n - \ \"13.87.102.68/32\",\r\n \"13.87.122.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"EventHub.UKSouth\",\r\n \"id\": - \"EventHub.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"51.105.66.64/26\",\r\n \"51.105.74.64/26\",\r\n - \ \"51.140.80.99/32\",\r\n \"51.140.87.93/32\",\r\n \"51.140.125.8/32\",\r\n - \ \"51.140.146.32/28\",\r\n \"51.140.189.52/32\",\r\n \"51.140.189.108/32\",\r\n - \ \"2603:1020:705:1::240/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"EventHub.UKSouth2\",\r\n \"id\": \"EventHub.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.34.139/32\",\r\n \"13.87.34.243/32\",\r\n - \ \"13.87.56.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.UKWest\",\r\n \"id\": \"EventHub.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"51.140.210.32/27\",\r\n - \ \"51.141.14.113/32\",\r\n \"51.141.14.168/32\",\r\n \"51.141.50.179/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestCentralUS\",\r\n - \ \"id\": \"EventHub.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.71.194.64/27\",\r\n \"13.78.149.209/32\",\r\n - \ \"13.78.150.233/32\",\r\n \"13.78.191.44/32\",\r\n \"52.161.19.160/32\",\r\n - \ \"52.161.24.64/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.WestEurope\",\r\n \"id\": \"EventHub.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.0/26\",\r\n - \ \"13.69.106.0/26\",\r\n \"23.97.226.21/32\",\r\n \"23.100.14.185/32\",\r\n - \ \"40.68.35.230/32\",\r\n \"40.68.39.15/32\",\r\n \"40.68.93.145/32\",\r\n - \ \"40.68.205.113/32\",\r\n \"40.68.217.242/32\",\r\n \"51.144.238.23/32\",\r\n - \ \"52.174.243.57/32\",\r\n \"52.178.78.61/32\",\r\n \"52.232.27.189/32\",\r\n - \ \"52.233.190.35/32\",\r\n \"52.233.192.247/32\",\r\n \"52.236.186.0/26\",\r\n - \ \"65.52.129.16/32\",\r\n \"104.40.150.139/32\",\r\n \"104.40.179.185/32\",\r\n - \ \"104.40.216.174/32\",\r\n \"104.46.32.56/32\",\r\n \"104.46.32.58/32\",\r\n - \ \"191.233.73.228/32\",\r\n \"2603:1020:206:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestIndia\",\r\n - \ \"id\": \"EventHub.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"104.211.146.32/27\",\r\n \"104.211.160.121/32\",\r\n - \ \"104.211.160.144/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"EventHub.WestUS\",\r\n \"id\": \"EventHub.WestUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.64.195.117/32\",\r\n - \ \"13.88.20.117/32\",\r\n \"13.88.26.28/32\",\r\n \"13.91.61.11/32\",\r\n - \ \"13.93.226.138/32\",\r\n \"23.99.7.105/32\",\r\n \"23.99.54.235/32\",\r\n - \ \"23.99.60.253/32\",\r\n \"23.99.80.186/32\",\r\n \"40.78.110.196/32\",\r\n - \ \"40.83.191.202/32\",\r\n \"40.83.222.100/32\",\r\n \"40.86.176.23/32\",\r\n - \ \"40.112.185.115/32\",\r\n \"40.112.213.11/32\",\r\n \"40.112.242.0/25\",\r\n - \ \"104.40.26.199/32\",\r\n \"104.40.29.113/32\",\r\n \"104.40.68.250/32\",\r\n - \ \"104.40.69.64/32\",\r\n \"104.42.97.95/32\",\r\n \"138.91.193.184/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestUS2\",\r\n - \ \"id\": \"EventHub.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.64/28\",\r\n \"13.66.145.128/26\",\r\n - \ \"13.66.228.204/32\",\r\n \"13.66.230.42/32\",\r\n \"20.42.131.16/28\",\r\n - \ \"20.42.131.64/26\",\r\n \"40.78.242.128/28\",\r\n \"40.78.247.0/26\",\r\n - \ \"40.78.250.64/28\",\r\n \"40.78.253.128/26\",\r\n \"52.151.58.121/32\",\r\n - \ \"52.183.46.73/32\",\r\n \"52.183.86.102/32\",\r\n \"2603:1030:c06:1::240/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager\",\r\n - \ \"id\": \"GatewayManager\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.65.91.57/32\",\r\n - \ \"13.66.140.144/29\",\r\n \"13.67.9.128/29\",\r\n \"13.69.64.224/29\",\r\n - \ \"13.69.227.224/29\",\r\n \"13.70.72.208/29\",\r\n \"13.70.185.130/32\",\r\n - \ \"13.71.170.240/29\",\r\n \"13.71.194.232/29\",\r\n \"13.75.36.8/29\",\r\n - \ \"13.77.0.146/32\",\r\n \"13.77.50.88/29\",\r\n \"13.78.108.16/29\",\r\n - \ \"13.78.188.33/32\",\r\n \"13.85.74.21/32\",\r\n \"13.87.35.147/32\",\r\n - \ \"13.87.36.246/32\",\r\n \"13.87.56.104/29\",\r\n \"13.87.122.104/29\",\r\n - \ \"13.89.171.96/29\",\r\n \"13.91.249.235/32\",\r\n \"13.91.254.232/32\",\r\n - \ \"13.92.84.128/32\",\r\n \"13.93.112.146/32\",\r\n \"13.93.117.26/32\",\r\n - \ \"20.36.42.151/32\",\r\n \"20.36.42.152/32\",\r\n \"20.36.74.91/32\",\r\n - \ \"20.36.74.113/32\",\r\n \"20.36.106.72/29\",\r\n \"20.36.114.24/29\",\r\n - \ \"20.36.120.72/29\",\r\n \"20.37.53.66/32\",\r\n \"20.37.53.76/32\",\r\n - \ \"20.37.64.72/29\",\r\n \"20.37.74.88/29\",\r\n \"20.37.152.72/29\",\r\n - \ \"20.37.192.72/29\",\r\n \"20.37.224.72/29\",\r\n \"20.38.80.72/29\",\r\n - \ \"20.38.136.72/29\",\r\n \"20.39.1.56/32\",\r\n \"20.39.1.58/32\",\r\n - \ \"20.39.8.72/29\",\r\n \"20.41.0.72/29\",\r\n \"20.41.64.72/29\",\r\n - \ \"20.41.192.72/29\",\r\n \"20.42.0.72/29\",\r\n \"20.42.128.72/29\",\r\n - \ \"20.42.224.72/29\",\r\n \"20.43.40.72/29\",\r\n \"20.43.64.72/29\",\r\n - \ \"20.43.128.72/29\",\r\n \"20.44.3.16/29\",\r\n \"20.45.112.72/29\",\r\n - \ \"20.45.192.72/29\",\r\n \"20.150.160.64/29\",\r\n \"20.150.161.0/26\",\r\n - \ \"20.150.171.64/29\",\r\n \"20.189.104.72/29\",\r\n \"20.192.160.64/26\",\r\n - \ \"20.192.224.192/26\",\r\n \"23.100.231.72/32\",\r\n \"23.100.231.96/32\",\r\n - \ \"23.101.173.90/32\",\r\n \"40.67.48.72/29\",\r\n \"40.67.59.64/29\",\r\n - \ \"40.69.106.88/29\",\r\n \"40.70.146.224/29\",\r\n \"40.71.11.96/29\",\r\n - \ \"40.74.24.72/29\",\r\n \"40.74.100.168/29\",\r\n \"40.78.194.88/29\",\r\n - \ \"40.78.202.112/29\",\r\n \"40.79.130.224/29\",\r\n \"40.79.178.88/29\",\r\n - \ \"40.80.56.72/29\",\r\n \"40.80.168.72/29\",\r\n \"40.80.184.72/29\",\r\n - \ \"40.81.94.172/32\",\r\n \"40.81.94.182/32\",\r\n \"40.81.189.24/32\",\r\n - \ \"40.81.189.42/32\",\r\n \"40.82.236.2/32\",\r\n \"40.82.236.13/32\",\r\n - \ \"40.82.248.240/29\",\r\n \"40.89.16.72/29\",\r\n \"40.90.186.21/32\",\r\n - \ \"40.90.186.91/32\",\r\n \"40.112.242.168/29\",\r\n \"40.115.248.200/32\",\r\n - \ \"40.115.254.17/32\",\r\n \"40.119.8.64/29\",\r\n \"51.12.40.192/26\",\r\n - \ \"51.12.192.192/26\",\r\n \"51.104.24.72/29\",\r\n \"51.105.80.72/29\",\r\n - \ \"51.105.88.72/29\",\r\n \"51.107.48.72/29\",\r\n \"51.107.59.32/29\",\r\n - \ \"51.107.144.72/29\",\r\n \"51.107.155.32/29\",\r\n \"51.116.48.72/29\",\r\n - \ \"51.116.59.32/29\",\r\n \"51.116.144.72/29\",\r\n \"51.116.155.96/29\",\r\n - \ \"51.120.40.72/29\",\r\n \"51.120.98.168/29\",\r\n \"51.120.219.64/29\",\r\n - \ \"51.120.224.72/29\",\r\n \"51.137.160.72/29\",\r\n \"51.140.63.41/32\",\r\n - \ \"51.140.114.209/32\",\r\n \"51.140.148.16/29\",\r\n \"51.140.210.200/29\",\r\n - \ \"51.141.25.80/32\",\r\n \"51.141.29.178/32\",\r\n \"51.142.209.124/32\",\r\n - \ \"51.142.210.184/32\",\r\n \"51.143.192.72/29\",\r\n \"52.136.48.72/29\",\r\n - \ \"52.136.137.15/32\",\r\n \"52.136.137.16/32\",\r\n \"52.138.70.115/32\",\r\n - \ \"52.138.71.153/32\",\r\n \"52.138.90.40/29\",\r\n \"52.140.104.72/29\",\r\n - \ \"52.143.136.58/31\",\r\n \"52.149.24.100/32\",\r\n \"52.149.26.14/32\",\r\n - \ \"52.150.136.72/29\",\r\n \"52.159.19.113/32\",\r\n \"52.159.20.67/32\",\r\n - \ \"52.161.28.251/32\",\r\n \"52.162.106.168/29\",\r\n \"52.163.241.22/32\",\r\n - \ \"52.163.246.27/32\",\r\n \"52.165.221.72/32\",\r\n \"52.169.225.171/32\",\r\n - \ \"52.169.231.163/32\",\r\n \"52.172.28.183/32\",\r\n \"52.172.31.29/32\",\r\n - \ \"52.172.204.73/32\",\r\n \"52.172.222.13/32\",\r\n \"52.173.250.124/32\",\r\n - \ \"52.177.204.204/32\",\r\n \"52.177.207.219/32\",\r\n \"52.179.10.142/32\",\r\n - \ \"52.180.178.35/32\",\r\n \"52.180.178.191/32\",\r\n \"52.180.182.210/32\",\r\n - \ \"52.191.140.123/32\",\r\n \"52.191.170.38/32\",\r\n \"52.228.80.72/29\",\r\n - \ \"52.229.161.220/32\",\r\n \"52.229.166.101/32\",\r\n \"52.231.18.224/29\",\r\n - \ \"52.231.24.186/32\",\r\n \"52.231.35.84/32\",\r\n \"52.231.146.200/29\",\r\n - \ \"52.231.203.87/32\",\r\n \"52.231.204.175/32\",\r\n \"52.237.24.145/32\",\r\n - \ \"52.237.30.255/32\",\r\n \"52.237.208.51/32\",\r\n \"52.237.215.149/32\",\r\n - \ \"52.242.17.200/32\",\r\n \"52.242.28.83/32\",\r\n \"52.253.159.209/32\",\r\n - \ \"52.253.239.162/32\",\r\n \"65.52.250.24/29\",\r\n \"70.37.160.97/32\",\r\n - \ \"70.37.161.124/32\",\r\n \"102.133.27.16/29\",\r\n \"102.133.56.72/29\",\r\n - \ \"102.133.155.16/29\",\r\n \"102.133.216.72/29\",\r\n \"104.211.81.208/29\",\r\n - \ \"104.211.146.88/29\",\r\n \"104.211.188.0/32\",\r\n \"104.211.191.94/32\",\r\n - \ \"104.214.19.64/29\",\r\n \"104.215.50.115/32\",\r\n \"104.215.52.27/32\",\r\n - \ \"168.62.104.154/32\",\r\n \"168.62.208.162/32\",\r\n \"168.62.209.95/32\",\r\n - \ \"191.233.8.64/26\",\r\n \"191.233.203.208/29\",\r\n \"191.233.245.75/32\",\r\n - \ \"191.233.245.118/32\",\r\n \"191.234.182.29/32\",\r\n - \ \"191.235.81.58/32\",\r\n \"191.235.224.72/29\",\r\n \"2603:1000:104:1::40/122\",\r\n - \ \"2603:1010:6:1::40/122\",\r\n \"2603:1020:5:1::40/122\",\r\n - \ \"2603:1020:206:1::40/122\",\r\n \"2603:1020:705:1::40/122\",\r\n - \ \"2603:1020:805:1::40/122\",\r\n \"2603:1020:a04:1::40/122\",\r\n - \ \"2603:1020:c04:1::40/122\",\r\n \"2603:1020:e04:1::40/122\",\r\n - \ \"2603:1020:1004::40/122\",\r\n \"2603:1030:10:1::40/122\",\r\n - \ \"2603:1030:104:1::40/122\",\r\n \"2603:1030:210:1::40/122\",\r\n - \ \"2603:1030:40b:1::40/122\",\r\n \"2603:1030:40c:1::40/122\",\r\n - \ \"2603:1030:504:1::40/122\",\r\n \"2603:1030:807:1::40/122\",\r\n - \ \"2603:1030:c06:1::40/122\",\r\n \"2603:1030:f05:1::40/122\",\r\n - \ \"2603:1040:5:1::40/122\",\r\n \"2603:1040:407:1::40/122\",\r\n - \ \"2603:1040:904:1::40/122\",\r\n \"2603:1040:a06:1::40/122\",\r\n - \ \"2603:1040:d04::40/122\",\r\n \"2603:1040:f05:1::40/122\",\r\n - \ \"2603:1050:6:1::40/122\",\r\n \"2603:1050:403::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.AustraliaCentral\",\r\n - \ \"id\": \"GatewayManager.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.42.151/32\",\r\n \"20.36.42.152/32\",\r\n - \ \"20.36.106.72/29\",\r\n \"20.37.53.66/32\",\r\n \"20.37.53.76/32\",\r\n - \ \"20.37.224.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.AustraliaCentral2\",\r\n \"id\": \"GatewayManager.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.36.74.91/32\",\r\n - \ \"20.36.74.113/32\",\r\n \"20.36.114.24/29\",\r\n \"20.36.120.72/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.AustraliaEast\",\r\n - \ \"id\": \"GatewayManager.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.72.208/29\",\r\n \"20.37.192.72/29\",\r\n - \ \"52.237.208.51/32\",\r\n \"52.237.215.149/32\",\r\n \"2603:1010:6:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.AustraliaSoutheast\",\r\n - \ \"id\": \"GatewayManager.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.185.130/32\",\r\n \"13.77.0.146/32\",\r\n - \ \"13.77.50.88/29\",\r\n \"20.42.224.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.BrazilSouth\",\r\n - \ \"id\": \"GatewayManager.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.203.208/29\",\r\n \"191.233.245.75/32\",\r\n - \ \"191.233.245.118/32\",\r\n \"191.234.182.29/32\",\r\n - \ \"191.235.81.58/32\",\r\n \"191.235.224.72/29\",\r\n \"2603:1050:6:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CanadaCentral\",\r\n - \ \"id\": \"GatewayManager.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.170.240/29\",\r\n \"52.228.80.72/29\",\r\n - \ \"52.237.24.145/32\",\r\n \"52.237.30.255/32\",\r\n \"2603:1030:f05:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CanadaEast\",\r\n - \ \"id\": \"GatewayManager.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.106.88/29\",\r\n \"40.89.16.72/29\",\r\n - \ \"52.242.17.200/32\",\r\n \"52.242.28.83/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CentralIndia\",\r\n - \ \"id\": \"GatewayManager.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"52.140.104.72/29\",\r\n \"52.172.204.73/32\",\r\n - \ \"52.172.222.13/32\",\r\n \"104.211.81.208/29\",\r\n \"2603:1040:a06:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CentralUS\",\r\n - \ \"id\": \"GatewayManager.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.171.96/29\",\r\n \"20.37.152.72/29\",\r\n - \ \"52.165.221.72/32\",\r\n \"52.173.250.124/32\",\r\n \"2603:1030:10:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CentralUSEUAP\",\r\n - \ \"id\": \"GatewayManager.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.192.72/29\",\r\n \"40.78.202.112/29\",\r\n - \ \"52.180.178.35/32\",\r\n \"52.180.178.191/32\",\r\n \"52.180.182.210/32\",\r\n - \ \"52.253.159.209/32\",\r\n \"52.253.239.162/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.EastAsia\",\r\n - \ \"id\": \"GatewayManager.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.36.8/29\",\r\n \"20.189.104.72/29\",\r\n - \ \"52.229.161.220/32\",\r\n \"52.229.166.101/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.EastUS\",\r\n - \ \"id\": \"GatewayManager.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"13.92.84.128/32\",\r\n \"20.42.0.72/29\",\r\n \"40.71.11.96/29\",\r\n - \ \"52.179.10.142/32\",\r\n \"2603:1030:210:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.EastUS2\",\r\n - \ \"id\": \"GatewayManager.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"20.41.0.72/29\",\r\n \"40.70.146.224/29\",\r\n \"52.177.204.204/32\",\r\n - \ \"52.177.207.219/32\",\r\n \"2603:1030:40c:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.EastUS2EUAP\",\r\n - \ \"id\": \"GatewayManager.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.1.56/32\",\r\n \"20.39.1.58/32\",\r\n - \ \"20.39.8.72/29\",\r\n \"52.138.70.115/32\",\r\n \"52.138.71.153/32\",\r\n - \ \"52.138.90.40/29\",\r\n \"2603:1030:40b:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.FranceCentral\",\r\n - \ \"id\": \"GatewayManager.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.40.72/29\",\r\n \"40.79.130.224/29\",\r\n - \ \"52.143.136.58/31\",\r\n \"2603:1020:805:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.FranceSouth\",\r\n - \ \"id\": \"GatewayManager.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.178.88/29\",\r\n \"40.82.236.2/32\",\r\n - \ \"40.82.236.13/32\",\r\n \"51.105.88.72/29\",\r\n \"52.136.137.15/32\",\r\n - \ \"52.136.137.16/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.GermanyNorth\",\r\n \"id\": \"GatewayManager.GermanyNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanyn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.116.48.72/29\",\r\n - \ \"51.116.59.32/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.GermanyWestCentral\",\r\n \"id\": \"GatewayManager.GermanyWestCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.116.144.72/29\",\r\n - \ \"51.116.155.96/29\",\r\n \"2603:1020:c04:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.JapanEast\",\r\n - \ \"id\": \"GatewayManager.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.108.16/29\",\r\n \"20.43.64.72/29\",\r\n - \ \"40.115.248.200/32\",\r\n \"40.115.254.17/32\",\r\n \"2603:1040:407:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.JapanWest\",\r\n - \ \"id\": \"GatewayManager.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.100.168/29\",\r\n \"40.80.56.72/29\",\r\n - \ \"40.81.189.24/32\",\r\n \"40.81.189.42/32\",\r\n \"104.215.50.115/32\",\r\n - \ \"104.215.52.27/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.KoreaCentral\",\r\n \"id\": \"GatewayManager.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.41.64.72/29\",\r\n - \ \"52.231.18.224/29\",\r\n \"52.231.24.186/32\",\r\n \"52.231.35.84/32\",\r\n - \ \"2603:1040:f05:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.KoreaSouth\",\r\n \"id\": \"GatewayManager.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"40.80.168.72/29\",\r\n - \ \"52.231.146.200/29\",\r\n \"52.231.203.87/32\",\r\n \"52.231.204.175/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.NorthCentralUS\",\r\n - \ \"id\": \"GatewayManager.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"23.100.231.72/32\",\r\n \"23.100.231.96/32\",\r\n - \ \"23.101.173.90/32\",\r\n \"40.80.184.72/29\",\r\n \"52.162.106.168/29\",\r\n - \ \"168.62.104.154/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.NorthEurope\",\r\n \"id\": \"GatewayManager.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.69.227.224/29\",\r\n - \ \"20.38.80.72/29\",\r\n \"52.169.225.171/32\",\r\n \"52.169.231.163/32\",\r\n - \ \"2603:1020:5:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.NorwayEast\",\r\n \"id\": \"GatewayManager.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.120.40.72/29\",\r\n - \ \"51.120.98.168/29\",\r\n \"2603:1020:e04:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.NorwayWest\",\r\n - \ \"id\": \"GatewayManager.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"51.120.219.64/29\",\r\n \"51.120.224.72/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SouthAfricaNorth\",\r\n - \ \"id\": \"GatewayManager.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.155.16/29\",\r\n \"102.133.216.72/29\",\r\n - \ \"2603:1000:104:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.SouthAfricaWest\",\r\n \"id\": - \"GatewayManager.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"102.133.27.16/29\",\r\n \"102.133.56.72/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SouthCentralUS\",\r\n - \ \"id\": \"GatewayManager.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.91.57/32\",\r\n \"13.85.74.21/32\",\r\n - \ \"40.119.8.64/29\",\r\n \"70.37.160.97/32\",\r\n \"70.37.161.124/32\",\r\n - \ \"104.214.19.64/29\",\r\n \"2603:1030:807:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SoutheastAsia\",\r\n - \ \"id\": \"GatewayManager.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.9.128/29\",\r\n \"20.43.128.72/29\",\r\n - \ \"40.90.186.21/32\",\r\n \"40.90.186.91/32\",\r\n \"52.163.241.22/32\",\r\n - \ \"52.163.246.27/32\",\r\n \"2603:1040:5:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SouthIndia\",\r\n - \ \"id\": \"GatewayManager.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.192.72/29\",\r\n \"40.78.194.88/29\",\r\n - \ \"52.172.28.183/32\",\r\n \"52.172.31.29/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SwitzerlandNorth\",\r\n - \ \"id\": \"GatewayManager.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.72/29\",\r\n \"51.107.59.32/29\",\r\n - \ \"2603:1020:a04:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.SwitzerlandWest\",\r\n \"id\": - \"GatewayManager.SwitzerlandWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"51.107.144.72/29\",\r\n \"51.107.155.32/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UAECentral\",\r\n - \ \"id\": \"GatewayManager.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.72/29\",\r\n \"20.37.74.88/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UAENorth\",\r\n - \ \"id\": \"GatewayManager.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.72/29\",\r\n \"65.52.250.24/29\",\r\n - \ \"2603:1040:904:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.UKNorth\",\r\n \"id\": \"GatewayManager.UKNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.122.104/29\",\r\n \"51.105.80.72/29\",\r\n - \ \"51.142.209.124/32\",\r\n \"51.142.210.184/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UKSouth\",\r\n - \ \"id\": \"GatewayManager.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"51.104.24.72/29\",\r\n \"51.140.63.41/32\",\r\n - \ \"51.140.114.209/32\",\r\n \"51.140.148.16/29\",\r\n \"2603:1020:705:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UKSouth2\",\r\n - \ \"id\": \"GatewayManager.UKSouth2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"13.87.35.147/32\",\r\n \"13.87.36.246/32\",\r\n - \ \"13.87.56.104/29\",\r\n \"51.143.192.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UKWest\",\r\n - \ \"id\": \"GatewayManager.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"51.137.160.72/29\",\r\n \"51.140.210.200/29\",\r\n - \ \"51.141.25.80/32\",\r\n \"51.141.29.178/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.WestCentralUS\",\r\n - \ \"id\": \"GatewayManager.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.232/29\",\r\n \"13.78.188.33/32\",\r\n - \ \"52.150.136.72/29\",\r\n \"52.159.19.113/32\",\r\n \"52.159.20.67/32\",\r\n - \ \"52.161.28.251/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.WestEurope\",\r\n \"id\": \"GatewayManager.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.224/29\",\r\n - \ \"13.93.112.146/32\",\r\n \"13.93.117.26/32\",\r\n \"40.74.24.72/29\",\r\n - \ \"2603:1020:206:1::40/122\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"GatewayManager.WestIndia\",\r\n \"id\": \"GatewayManager.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"40.81.94.172/32\",\r\n - \ \"40.81.94.182/32\",\r\n \"52.136.48.72/29\",\r\n \"104.211.146.88/29\",\r\n - \ \"104.211.188.0/32\",\r\n \"104.211.191.94/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GatewayManager.WestUS\",\r\n - \ \"id\": \"GatewayManager.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": - [\r\n \"13.91.249.235/32\",\r\n \"13.91.254.232/32\",\r\n - \ \"40.82.248.240/29\",\r\n \"40.112.242.168/29\",\r\n \"168.62.208.162/32\",\r\n - \ \"168.62.209.95/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GatewayManager.WestUS2\",\r\n \"id\": \"GatewayManager.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.144/29\",\r\n - \ \"20.42.128.72/29\",\r\n \"52.149.24.100/32\",\r\n \"52.149.26.14/32\",\r\n - \ \"52.191.140.123/32\",\r\n \"52.191.170.38/32\",\r\n \"2603:1030:c06:1::40/122\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement\",\r\n - \ \"id\": \"GuestAndHybridManagement\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureAutomation\",\r\n \"addressPrefixes\": - [\r\n \"13.65.24.129/32\",\r\n \"13.66.138.94/31\",\r\n - \ \"13.66.141.224/29\",\r\n \"13.66.145.80/28\",\r\n \"13.67.8.110/31\",\r\n - \ \"13.67.10.72/29\",\r\n \"13.69.64.78/31\",\r\n \"13.69.67.48/29\",\r\n - \ \"13.69.107.64/29\",\r\n \"13.69.109.128/31\",\r\n \"13.69.109.176/28\",\r\n - \ \"13.69.227.78/31\",\r\n \"13.69.229.248/29\",\r\n \"13.70.72.30/31\",\r\n - \ \"13.70.74.80/29\",\r\n \"13.70.123.166/32\",\r\n \"13.71.170.46/31\",\r\n - \ \"13.71.173.208/29\",\r\n \"13.71.175.144/28\",\r\n \"13.71.194.118/31\",\r\n - \ \"13.71.196.128/29\",\r\n \"13.71.199.176/28\",\r\n \"13.73.242.40/29\",\r\n - \ \"13.73.242.210/31\",\r\n \"13.73.244.208/28\",\r\n \"13.74.107.92/31\",\r\n - \ \"13.74.108.136/29\",\r\n \"13.75.34.150/31\",\r\n \"13.75.39.104/29\",\r\n - \ \"13.77.1.26/32\",\r\n \"13.77.1.212/32\",\r\n \"13.77.50.70/31\",\r\n - \ \"13.77.53.56/29\",\r\n \"13.77.55.192/28\",\r\n \"13.78.59.184/32\",\r\n - \ \"13.78.106.94/31\",\r\n \"13.78.109.120/29\",\r\n \"13.78.111.208/28\",\r\n - \ \"13.86.219.200/29\",\r\n \"13.86.221.216/31\",\r\n \"13.86.223.64/28\",\r\n - \ \"13.87.56.86/31\",\r\n \"13.87.58.72/29\",\r\n \"13.87.122.86/31\",\r\n - \ \"13.87.124.72/29\",\r\n \"13.88.240.74/32\",\r\n \"13.88.244.195/32\",\r\n - \ \"13.89.170.206/31\",\r\n \"13.89.174.136/29\",\r\n \"13.89.178.96/28\",\r\n - \ \"13.94.240.75/32\",\r\n \"20.36.39.150/32\",\r\n \"20.36.106.70/31\",\r\n - \ \"20.36.108.128/29\",\r\n \"20.36.108.240/28\",\r\n \"20.36.114.22/31\",\r\n - \ \"20.36.117.32/29\",\r\n \"20.36.117.144/28\",\r\n \"20.37.74.226/31\",\r\n - \ \"20.37.76.120/29\",\r\n \"20.38.128.104/29\",\r\n \"20.38.128.168/31\",\r\n - \ \"20.38.132.0/28\",\r\n \"20.38.147.152/29\",\r\n \"20.38.149.128/31\",\r\n - \ \"20.42.64.32/31\",\r\n \"20.42.72.128/31\",\r\n \"20.42.72.144/28\",\r\n - \ \"20.43.120.248/29\",\r\n \"20.43.121.120/31\",\r\n \"20.43.123.48/28\",\r\n - \ \"20.44.2.6/31\",\r\n \"20.44.4.104/29\",\r\n \"20.44.8.200/29\",\r\n - \ \"20.44.10.120/31\",\r\n \"20.44.17.8/29\",\r\n \"20.44.17.216/31\",\r\n - \ \"20.44.19.16/28\",\r\n \"20.44.27.112/29\",\r\n \"20.44.29.48/31\",\r\n - \ \"20.44.29.96/28\",\r\n \"20.45.123.88/29\",\r\n \"20.45.123.232/31\",\r\n - \ \"20.49.82.24/29\",\r\n \"20.49.90.24/29\",\r\n \"20.150.171.216/29\",\r\n - \ \"20.150.172.224/31\",\r\n \"20.150.179.192/29\",\r\n \"20.150.181.24/31\",\r\n - \ \"20.150.181.176/28\",\r\n \"20.150.187.192/29\",\r\n \"20.150.189.24/31\",\r\n - \ \"20.192.99.192/29\",\r\n \"20.192.101.24/31\",\r\n \"20.192.184.64/28\",\r\n - \ \"20.192.234.176/28\",\r\n \"20.192.235.8/29\",\r\n \"20.192.238.120/31\",\r\n - \ \"20.193.202.176/28\",\r\n \"20.193.203.192/29\",\r\n \"20.194.66.24/29\",\r\n - \ \"23.96.225.107/32\",\r\n \"23.96.225.182/32\",\r\n \"23.98.83.64/29\",\r\n - \ \"23.98.86.56/31\",\r\n \"40.67.60.96/29\",\r\n \"40.67.60.108/31\",\r\n - \ \"40.69.106.70/31\",\r\n \"40.69.108.88/29\",\r\n \"40.69.110.240/28\",\r\n - \ \"40.70.146.78/31\",\r\n \"40.70.148.48/29\",\r\n \"40.71.10.206/31\",\r\n - \ \"40.71.13.240/29\",\r\n \"40.71.30.252/32\",\r\n \"40.74.146.82/31\",\r\n - \ \"40.74.149.32/29\",\r\n \"40.74.150.16/28\",\r\n \"40.75.35.128/29\",\r\n - \ \"40.75.35.216/31\",\r\n \"40.78.194.70/31\",\r\n \"40.78.196.88/29\",\r\n - \ \"40.78.202.130/31\",\r\n \"40.78.203.248/29\",\r\n \"40.78.229.40/29\",\r\n - \ \"40.78.236.128/29\",\r\n \"40.78.238.56/31\",\r\n \"40.78.239.32/28\",\r\n - \ \"40.78.242.172/31\",\r\n \"40.78.243.24/29\",\r\n \"40.78.250.108/31\",\r\n - \ \"40.78.250.216/29\",\r\n \"40.79.130.46/31\",\r\n \"40.79.132.40/29\",\r\n - \ \"40.79.138.44/31\",\r\n \"40.79.138.152/29\",\r\n \"40.79.139.208/28\",\r\n - \ \"40.79.146.44/31\",\r\n \"40.79.146.152/29\",\r\n \"40.79.156.40/29\",\r\n - \ \"40.79.163.8/29\",\r\n \"40.79.163.152/31\",\r\n \"40.79.170.248/29\",\r\n - \ \"40.79.171.224/31\",\r\n \"40.79.173.16/28\",\r\n \"40.79.178.70/31\",\r\n - \ \"40.79.180.56/29\",\r\n \"40.79.180.208/28\",\r\n \"40.79.187.160/29\",\r\n - \ \"40.79.189.56/31\",\r\n \"40.79.194.120/29\",\r\n \"40.79.197.32/31\",\r\n - \ \"40.80.51.88/29\",\r\n \"40.80.53.0/31\",\r\n \"40.80.176.48/29\",\r\n - \ \"40.80.180.0/31\",\r\n \"40.80.180.96/28\",\r\n \"40.85.168.201/32\",\r\n - \ \"40.89.129.151/32\",\r\n \"40.89.132.62/32\",\r\n \"40.89.137.16/32\",\r\n - \ \"40.89.157.7/32\",\r\n \"40.114.77.89/32\",\r\n \"40.114.85.4/32\",\r\n - \ \"40.118.103.191/32\",\r\n \"40.120.8.32/28\",\r\n \"40.120.64.48/28\",\r\n - \ \"40.120.75.48/29\",\r\n \"51.11.97.0/31\",\r\n \"51.11.97.64/28\",\r\n - \ \"51.12.99.208/29\",\r\n \"51.12.203.72/29\",\r\n \"51.12.227.192/29\",\r\n - \ \"51.12.235.192/29\",\r\n \"51.104.8.240/29\",\r\n \"51.104.9.96/31\",\r\n - \ \"51.105.67.168/29\",\r\n \"51.105.69.80/31\",\r\n \"51.105.75.152/29\",\r\n - \ \"51.105.77.48/31\",\r\n \"51.105.77.80/28\",\r\n \"51.107.60.80/29\",\r\n - \ \"51.107.60.92/31\",\r\n \"51.107.60.208/28\",\r\n \"51.107.156.72/29\",\r\n - \ \"51.107.156.132/31\",\r\n \"51.107.156.208/28\",\r\n \"51.116.60.80/29\",\r\n - \ \"51.116.60.224/28\",\r\n \"51.116.156.160/29\",\r\n \"51.116.158.56/31\",\r\n - \ \"51.116.158.80/28\",\r\n \"51.116.243.144/29\",\r\n \"51.116.243.216/31\",\r\n - \ \"51.116.251.32/29\",\r\n \"51.116.251.184/31\",\r\n \"51.120.100.80/29\",\r\n - \ \"51.120.100.92/31\",\r\n \"51.120.107.192/29\",\r\n \"51.120.109.24/31\",\r\n - \ \"51.120.109.48/28\",\r\n \"51.120.211.192/29\",\r\n \"51.120.213.24/31\",\r\n - \ \"51.120.220.80/29\",\r\n \"51.120.220.92/31\",\r\n \"51.120.220.176/28\",\r\n - \ \"51.140.6.15/32\",\r\n \"51.140.51.174/32\",\r\n \"51.140.212.104/29\",\r\n - \ \"52.138.90.52/31\",\r\n \"52.138.92.80/29\",\r\n \"52.138.227.136/29\",\r\n - \ \"52.138.229.64/31\",\r\n \"52.138.229.80/28\",\r\n \"52.147.97.0/31\",\r\n - \ \"52.151.62.99/32\",\r\n \"52.161.14.192/32\",\r\n \"52.161.28.108/32\",\r\n - \ \"52.162.110.240/29\",\r\n \"52.162.111.128/31\",\r\n \"52.163.228.23/32\",\r\n - \ \"52.167.107.72/29\",\r\n \"52.167.109.64/31\",\r\n \"52.169.105.82/32\",\r\n - \ \"52.172.153.216/32\",\r\n \"52.172.155.142/32\",\r\n \"52.178.223.62/32\",\r\n - \ \"52.180.166.238/32\",\r\n \"52.180.179.25/32\",\r\n \"52.182.139.56/29\",\r\n - \ \"52.182.141.12/31\",\r\n \"52.182.141.144/28\",\r\n \"52.183.5.195/32\",\r\n - \ \"52.231.18.46/31\",\r\n \"52.231.20.0/29\",\r\n \"52.231.64.18/32\",\r\n - \ \"52.231.69.100/32\",\r\n \"52.231.148.120/29\",\r\n \"52.231.148.208/28\",\r\n - \ \"52.236.186.240/29\",\r\n \"52.236.189.72/31\",\r\n \"52.240.241.64/28\",\r\n - \ \"52.246.155.152/29\",\r\n \"52.246.157.0/31\",\r\n \"65.52.250.6/31\",\r\n - \ \"65.52.252.120/29\",\r\n \"102.37.64.32/28\",\r\n \"102.133.26.6/31\",\r\n - \ \"102.133.28.144/29\",\r\n \"102.133.124.16/29\",\r\n \"102.133.156.112/29\",\r\n - \ \"102.133.251.176/29\",\r\n \"102.133.253.32/28\",\r\n - \ \"104.41.9.106/32\",\r\n \"104.41.178.182/32\",\r\n \"104.208.163.218/32\",\r\n - \ \"104.209.137.89/32\",\r\n \"104.210.80.208/32\",\r\n \"104.210.158.71/32\",\r\n - \ \"104.214.164.32/28\",\r\n \"104.215.254.56/32\",\r\n \"168.61.140.48/28\",\r\n - \ \"191.232.170.251/32\",\r\n \"191.233.51.144/29\",\r\n - \ \"191.233.203.30/31\",\r\n \"191.233.205.64/29\",\r\n \"191.234.147.192/29\",\r\n - \ \"191.234.149.48/28\",\r\n \"191.234.149.136/31\",\r\n - \ \"191.234.155.192/29\",\r\n \"191.234.157.40/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.BrazilSouth\",\r\n - \ \"id\": \"GuestAndHybridManagement.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"104.41.9.106/32\",\r\n \"191.232.170.251/32\",\r\n - \ \"191.233.203.30/31\",\r\n \"191.233.205.64/29\",\r\n \"191.234.147.192/29\",\r\n - \ \"191.234.149.48/28\",\r\n \"191.234.149.136/31\",\r\n - \ \"191.234.155.192/29\",\r\n \"191.234.157.40/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.CentralUS\",\r\n - \ \"id\": \"GuestAndHybridManagement.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.170.206/31\",\r\n \"13.89.174.136/29\",\r\n - \ \"13.89.178.96/28\",\r\n \"20.44.8.200/29\",\r\n \"20.44.10.120/31\",\r\n - \ \"52.182.139.56/29\",\r\n \"52.182.141.12/31\",\r\n \"52.182.141.144/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.KoreaCentral\",\r\n - \ \"id\": \"GuestAndHybridManagement.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.27.112/29\",\r\n \"20.44.29.48/31\",\r\n - \ \"20.44.29.96/28\",\r\n \"20.194.66.24/29\",\r\n \"52.231.18.46/31\",\r\n - \ \"52.231.20.0/29\",\r\n \"52.231.64.18/32\",\r\n \"52.231.69.100/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.NorwayEast\",\r\n - \ \"id\": \"GuestAndHybridManagement.NorwayEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.100.80/29\",\r\n \"51.120.100.92/31\",\r\n - \ \"51.120.107.192/29\",\r\n \"51.120.109.24/31\",\r\n \"51.120.109.48/28\",\r\n - \ \"51.120.211.192/29\",\r\n \"51.120.213.24/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.NorwayWest\",\r\n - \ \"id\": \"GuestAndHybridManagement.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.220.80/29\",\r\n \"51.120.220.92/31\",\r\n - \ \"51.120.220.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GuestAndHybridManagement.SouthIndia\",\r\n \"id\": - \"GuestAndHybridManagement.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureAutomation\",\r\n \"addressPrefixes\": - [\r\n \"20.192.184.64/28\",\r\n \"40.78.194.70/31\",\r\n - \ \"40.78.196.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GuestAndHybridManagement.SwitzerlandWest\",\r\n \"id\": - \"GuestAndHybridManagement.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.156.72/29\",\r\n \"51.107.156.132/31\",\r\n - \ \"51.107.156.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GuestAndHybridManagement.UAECentral\",\r\n \"id\": - \"GuestAndHybridManagement.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureAutomation\",\r\n \"addressPrefixes\": - [\r\n \"20.37.74.226/31\",\r\n \"20.37.76.120/29\",\r\n - \ \"40.120.8.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"GuestAndHybridManagement.UKWest\",\r\n \"id\": \"GuestAndHybridManagement.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"51.11.97.0/31\",\r\n - \ \"51.11.97.64/28\",\r\n \"51.140.212.104/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.WestIndia\",\r\n - \ \"id\": \"GuestAndHybridManagement.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAutomation\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.128.104/29\",\r\n \"20.38.128.168/31\",\r\n - \ \"20.38.132.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight\",\r\n \"id\": \"HDInsight\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.64.254.98/32\",\r\n \"13.66.141.144/29\",\r\n - \ \"13.67.9.152/29\",\r\n \"13.69.65.8/29\",\r\n \"13.69.229.72/29\",\r\n - \ \"13.70.73.96/29\",\r\n \"13.71.172.240/29\",\r\n \"13.71.196.48/29\",\r\n - \ \"13.73.240.8/29\",\r\n \"13.74.153.132/32\",\r\n \"13.75.38.112/29\",\r\n - \ \"13.75.152.195/32\",\r\n \"13.76.136.249/32\",\r\n \"13.76.245.160/32\",\r\n - \ \"13.77.2.56/32\",\r\n \"13.77.2.94/32\",\r\n \"13.77.52.8/29\",\r\n - \ \"13.78.89.60/32\",\r\n \"13.78.125.90/32\",\r\n \"13.82.225.233/32\",\r\n - \ \"13.86.218.240/29\",\r\n \"13.87.58.32/29\",\r\n \"13.87.124.32/29\",\r\n - \ \"13.89.171.120/29\",\r\n \"20.36.36.33/32\",\r\n \"20.36.36.196/32\",\r\n - \ \"20.37.76.96/29\",\r\n \"20.43.120.8/29\",\r\n \"20.44.4.64/29\",\r\n - \ \"20.44.16.8/29\",\r\n \"20.44.26.240/29\",\r\n \"20.150.172.232/29\",\r\n - \ \"20.192.235.248/29\",\r\n \"20.193.203.200/29\",\r\n \"23.99.5.239/32\",\r\n - \ \"23.101.196.19/32\",\r\n \"23.102.235.122/32\",\r\n \"40.67.60.64/29\",\r\n - \ \"40.69.107.8/29\",\r\n \"40.71.13.160/29\",\r\n \"40.71.175.99/32\",\r\n - \ \"40.74.101.192/29\",\r\n \"40.74.125.69/32\",\r\n \"40.74.146.88/29\",\r\n - \ \"40.78.195.8/29\",\r\n \"40.78.202.136/29\",\r\n \"40.79.130.248/29\",\r\n - \ \"40.79.180.16/29\",\r\n \"40.79.187.0/29\",\r\n \"40.89.65.220/32\",\r\n - \ \"40.89.68.134/32\",\r\n \"40.89.153.54/32\",\r\n \"40.89.156.151/32\",\r\n - \ \"51.104.8.96/29\",\r\n \"51.107.60.48/29\",\r\n \"51.107.156.56/29\",\r\n - \ \"51.116.60.48/29\",\r\n \"51.116.156.48/29\",\r\n \"51.120.100.48/29\",\r\n - \ \"51.120.220.48/29\",\r\n \"51.140.47.39/32\",\r\n \"51.140.52.16/32\",\r\n - \ \"51.140.211.24/29\",\r\n \"51.141.7.20/32\",\r\n \"51.141.13.110/32\",\r\n - \ \"52.161.10.167/32\",\r\n \"52.161.23.15/32\",\r\n \"52.162.110.160/29\",\r\n - \ \"52.164.210.96/32\",\r\n \"52.166.243.90/32\",\r\n \"52.172.152.49/32\",\r\n - \ \"52.172.153.209/32\",\r\n \"52.174.36.244/32\",\r\n \"52.175.38.134/32\",\r\n - \ \"52.175.211.210/32\",\r\n \"52.175.222.222/32\",\r\n \"52.180.183.49/32\",\r\n - \ \"52.180.183.58/32\",\r\n \"52.228.37.66/32\",\r\n \"52.228.45.222/32\",\r\n - \ \"52.229.123.172/32\",\r\n \"52.229.127.96/32\",\r\n \"52.231.36.209/32\",\r\n - \ \"52.231.39.142/32\",\r\n \"52.231.147.24/29\",\r\n \"52.231.203.16/32\",\r\n - \ \"52.231.205.214/32\",\r\n \"65.52.252.96/29\",\r\n \"102.133.28.80/29\",\r\n - \ \"102.133.124.0/29\",\r\n \"104.210.84.115/32\",\r\n \"104.211.216.210/32\",\r\n - \ \"104.211.223.67/32\",\r\n \"138.91.29.150/32\",\r\n \"138.91.141.162/32\",\r\n - \ \"157.55.213.99/32\",\r\n \"157.56.8.38/32\",\r\n \"168.61.48.131/32\",\r\n - \ \"168.61.49.99/32\",\r\n \"191.233.51.152/29\",\r\n \"191.233.204.240/29\",\r\n - \ \"191.235.84.104/32\",\r\n \"191.235.87.113/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.AustraliaCentral\",\r\n - \ \"id\": \"HDInsight.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.36.33/32\",\r\n \"20.36.36.196/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.AustraliaEast\",\r\n - \ \"id\": \"HDInsight.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.73.96/29\",\r\n \"13.75.152.195/32\",\r\n - \ \"104.210.84.115/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.AustraliaSoutheast\",\r\n \"id\": \"HDInsight.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.77.2.56/32\",\r\n - \ \"13.77.2.94/32\",\r\n \"13.77.52.8/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.BrazilSouth\",\r\n - \ \"id\": \"HDInsight.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"191.233.204.240/29\",\r\n \"191.235.84.104/32\",\r\n - \ \"191.235.87.113/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.CanadaCentral\",\r\n \"id\": \"HDInsight.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.71.172.240/29\",\r\n - \ \"52.228.37.66/32\",\r\n \"52.228.45.222/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.CanadaEast\",\r\n - \ \"id\": \"HDInsight.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"40.69.107.8/29\",\r\n \"52.229.123.172/32\",\r\n - \ \"52.229.127.96/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.CentralIndia\",\r\n \"id\": \"HDInsight.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.43.120.8/29\",\r\n - \ \"52.172.152.49/32\",\r\n \"52.172.153.209/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.CentralUS\",\r\n - \ \"id\": \"HDInsight.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.89.171.120/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"HDInsight.CentralUSEUAP\",\r\n \"id\": \"HDInsight.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.136/29\",\r\n - \ \"52.180.183.49/32\",\r\n \"52.180.183.58/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastAsia\",\r\n - \ \"id\": \"HDInsight.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.75.38.112/29\",\r\n \"23.102.235.122/32\",\r\n - \ \"52.175.38.134/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.EastUS\",\r\n \"id\": \"HDInsight.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.82.225.233/32\",\r\n - \ \"40.71.13.160/29\",\r\n \"40.71.175.99/32\",\r\n \"168.61.48.131/32\",\r\n - \ \"168.61.49.99/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.EastUS2\",\r\n \"id\": \"HDInsight.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.44.16.8/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastUS2EUAP\",\r\n - \ \"id\": \"HDInsight.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"40.74.146.88/29\",\r\n \"40.89.65.220/32\",\r\n - \ \"40.89.68.134/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.FranceCentral\",\r\n \"id\": \"HDInsight.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.79.130.248/29\",\r\n - \ \"40.89.153.54/32\",\r\n \"40.89.156.151/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.FranceSouth\",\r\n - \ \"id\": \"HDInsight.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"40.79.180.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.GermanyNorth\",\r\n \"id\": \"HDInsight.GermanyNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanyn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.116.60.48/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.GermanyWestCentral\",\r\n - \ \"id\": \"HDInsight.GermanyWestCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"51.116.156.48/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"HDInsight.JapanEast\",\r\n \"id\": \"HDInsight.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.78.89.60/32\",\r\n - \ \"13.78.125.90/32\",\r\n \"40.79.187.0/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.JapanWest\",\r\n - \ \"id\": \"HDInsight.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"40.74.101.192/29\",\r\n \"40.74.125.69/32\",\r\n - \ \"138.91.29.150/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.KoreaCentral\",\r\n \"id\": \"HDInsight.KoreaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.44.26.240/29\",\r\n - \ \"52.231.36.209/32\",\r\n \"52.231.39.142/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.KoreaSouth\",\r\n - \ \"id\": \"HDInsight.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"52.231.147.24/29\",\r\n \"52.231.203.16/32\",\r\n - \ \"52.231.205.214/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.NorthCentralUS\",\r\n \"id\": \"HDInsight.NorthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"52.162.110.160/29\",\r\n - \ \"157.55.213.99/32\",\r\n \"157.56.8.38/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorthEurope\",\r\n - \ \"id\": \"HDInsight.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.69.229.72/29\",\r\n \"13.74.153.132/32\",\r\n - \ \"52.164.210.96/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.NorwayEast\",\r\n \"id\": \"HDInsight.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.120.100.48/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorwayWest\",\r\n - \ \"id\": \"HDInsight.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"51.120.220.48/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"HDInsight.SouthAfricaNorth\",\r\n \"id\": - \"HDInsight.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"102.133.124.0/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"HDInsight.SouthAfricaWest\",\r\n \"id\": \"HDInsight.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"102.133.28.80/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SouthCentralUS\",\r\n - \ \"id\": \"HDInsight.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.240.8/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.SoutheastAsia\",\r\n - \ \"id\": \"HDInsight.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.9.152/29\",\r\n \"13.76.136.249/32\",\r\n - \ \"13.76.245.160/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.SouthIndia\",\r\n \"id\": \"HDInsight.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.78.195.8/29\",\r\n - \ \"104.211.216.210/32\",\r\n \"104.211.223.67/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.SwitzerlandNorth\",\r\n - \ \"id\": \"HDInsight.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"51.107.60.48/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.SwitzerlandWest\",\r\n \"id\": \"HDInsight.SwitzerlandWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.107.156.56/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UAECentral\",\r\n - \ \"id\": \"HDInsight.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"20.37.76.96/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.UAENorth\",\r\n \"id\": \"HDInsight.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"65.52.252.96/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKNorth\",\r\n - \ \"id\": \"HDInsight.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.87.124.32/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKSouth\",\r\n - \ \"id\": \"HDInsight.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"51.104.8.96/29\",\r\n \"51.140.47.39/32\",\r\n \"51.140.52.16/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKSouth2\",\r\n - \ \"id\": \"HDInsight.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.87.58.32/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKWest\",\r\n - \ \"id\": \"HDInsight.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"51.140.211.24/29\",\r\n \"51.141.7.20/32\",\r\n - \ \"51.141.13.110/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"HDInsight.WestCentralUS\",\r\n \"id\": \"HDInsight.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.71.196.48/29\",\r\n - \ \"52.161.10.167/32\",\r\n \"52.161.23.15/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestEurope\",\r\n - \ \"id\": \"HDInsight.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.69.65.8/29\",\r\n \"52.166.243.90/32\",\r\n \"52.174.36.244/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestUS\",\r\n - \ \"id\": \"HDInsight.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.64.254.98/32\",\r\n \"13.86.218.240/29\",\r\n - \ \"23.99.5.239/32\",\r\n \"23.101.196.19/32\",\r\n \"138.91.141.162/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestUS2\",\r\n - \ \"id\": \"HDInsight.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\": - [\r\n \"13.66.141.144/29\",\r\n \"52.175.211.210/32\",\r\n - \ \"52.175.222.222/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"LogicApps\",\r\n \"id\": \"LogicApps\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.39.247/32\",\r\n \"13.65.82.17/32\",\r\n - \ \"13.65.82.190/32\",\r\n \"13.65.86.56/32\",\r\n \"13.65.98.39/32\",\r\n - \ \"13.66.52.232/32\",\r\n \"13.66.128.68/32\",\r\n \"13.66.201.169/32\",\r\n - \ \"13.66.210.167/32\",\r\n \"13.66.224.169/32\",\r\n \"13.66.246.219/32\",\r\n - \ \"13.67.13.224/27\",\r\n \"13.67.91.135/32\",\r\n \"13.67.107.128/32\",\r\n - \ \"13.67.110.109/32\",\r\n \"13.67.236.76/32\",\r\n \"13.67.236.125/32\",\r\n - \ \"13.69.71.160/27\",\r\n \"13.69.109.144/28\",\r\n \"13.69.231.160/27\",\r\n - \ \"13.69.233.16/28\",\r\n \"13.70.78.192/27\",\r\n \"13.70.159.205/32\",\r\n - \ \"13.71.146.140/32\",\r\n \"13.71.158.3/32\",\r\n \"13.71.158.120/32\",\r\n - \ \"13.71.184.150/32\",\r\n \"13.71.186.1/32\",\r\n \"13.71.199.128/27\",\r\n - \ \"13.71.199.160/28\",\r\n \"13.73.4.207/32\",\r\n \"13.73.114.207/32\",\r\n - \ \"13.73.115.153/32\",\r\n \"13.73.244.144/28\",\r\n \"13.73.244.160/27\",\r\n - \ \"13.75.89.159/32\",\r\n \"13.75.94.173/32\",\r\n \"13.75.149.4/32\",\r\n - \ \"13.75.153.66/32\",\r\n \"13.76.4.194/32\",\r\n \"13.76.5.96/32\",\r\n - \ \"13.76.133.155/32\",\r\n \"13.77.3.139/32\",\r\n \"13.77.53.224/27\",\r\n - \ \"13.77.55.128/28\",\r\n \"13.77.56.167/32\",\r\n \"13.77.58.136/32\",\r\n - \ \"13.77.149.159/32\",\r\n \"13.77.152.21/32\",\r\n \"13.78.18.168/32\",\r\n - \ \"13.78.20.232/32\",\r\n \"13.78.21.155/32\",\r\n \"13.78.35.229/32\",\r\n - \ \"13.78.42.223/32\",\r\n \"13.78.43.164/32\",\r\n \"13.78.62.130/32\",\r\n - \ \"13.78.84.187/32\",\r\n \"13.78.111.160/27\",\r\n \"13.78.129.20/32\",\r\n - \ \"13.78.137.179/32\",\r\n \"13.78.137.247/32\",\r\n \"13.78.141.75/32\",\r\n - \ \"13.78.148.140/32\",\r\n \"13.78.151.161/32\",\r\n \"13.79.173.49/32\",\r\n - \ \"13.84.41.46/32\",\r\n \"13.84.43.45/32\",\r\n \"13.84.159.168/32\",\r\n - \ \"13.85.79.155/32\",\r\n \"13.86.221.240/28\",\r\n \"13.86.223.0/27\",\r\n - \ \"13.87.58.144/28\",\r\n \"13.87.58.160/27\",\r\n \"13.87.124.144/28\",\r\n - \ \"13.87.124.160/27\",\r\n \"13.88.249.209/32\",\r\n \"13.89.178.48/28\",\r\n - \ \"13.91.252.184/32\",\r\n \"13.92.98.111/32\",\r\n \"13.95.147.65/32\",\r\n - \ \"13.95.155.53/32\",\r\n \"13.106.118.32/27\",\r\n \"13.106.118.96/27\",\r\n - \ \"20.36.108.192/27\",\r\n \"20.36.108.224/28\",\r\n \"20.36.117.96/27\",\r\n - \ \"20.36.117.128/28\",\r\n \"20.37.76.208/28\",\r\n \"20.37.76.224/27\",\r\n - \ \"20.38.128.176/28\",\r\n \"20.38.128.192/27\",\r\n \"20.38.149.144/28\",\r\n - \ \"20.38.149.160/27\",\r\n \"20.42.64.48/28\",\r\n \"20.42.72.160/27\",\r\n - \ \"20.43.121.192/27\",\r\n \"20.43.121.224/28\",\r\n \"20.44.4.176/28\",\r\n - \ \"20.44.4.192/27\",\r\n \"20.44.17.224/27\",\r\n \"20.45.64.29/32\",\r\n - \ \"20.45.64.87/32\",\r\n \"20.45.67.134/31\",\r\n \"20.45.67.170/32\",\r\n - \ \"20.45.71.213/32\",\r\n \"20.45.72.54/32\",\r\n \"20.45.72.72/32\",\r\n - \ \"20.45.75.193/32\",\r\n \"20.45.75.200/32\",\r\n \"20.45.75.236/32\",\r\n - \ \"20.45.79.239/32\",\r\n \"20.150.172.240/28\",\r\n \"20.150.173.192/27\",\r\n - \ \"20.150.181.32/27\",\r\n \"20.188.33.169/32\",\r\n \"20.188.39.105/32\",\r\n - \ \"20.192.184.0/27\",\r\n \"20.192.238.128/27\",\r\n \"20.192.238.160/28\",\r\n - \ \"20.193.206.48/28\",\r\n \"20.193.206.128/27\",\r\n \"23.96.200.77/32\",\r\n - \ \"23.96.200.227/32\",\r\n \"23.96.203.46/32\",\r\n \"23.96.210.49/32\",\r\n - \ \"23.96.212.28/32\",\r\n \"23.96.253.219/32\",\r\n \"23.97.68.172/32\",\r\n - \ \"23.97.210.126/32\",\r\n \"23.97.211.179/32\",\r\n \"23.97.218.130/32\",\r\n - \ \"23.99.125.99/32\",\r\n \"23.100.29.190/32\",\r\n \"23.100.82.16/32\",\r\n - \ \"23.100.86.139/32\",\r\n \"23.100.87.24/32\",\r\n \"23.100.87.56/32\",\r\n - \ \"23.100.124.84/32\",\r\n \"23.100.127.172/32\",\r\n \"23.101.132.208/32\",\r\n - \ \"23.101.136.201/32\",\r\n \"23.101.139.153/32\",\r\n \"23.101.183.225/32\",\r\n - \ \"23.101.191.106/32\",\r\n \"23.102.70.174/32\",\r\n \"40.67.60.176/28\",\r\n - \ \"40.67.60.192/27\",\r\n \"40.68.209.23/32\",\r\n \"40.68.222.65/32\",\r\n - \ \"40.69.110.192/27\",\r\n \"40.69.110.224/28\",\r\n \"40.70.26.154/32\",\r\n - \ \"40.70.27.236/32\",\r\n \"40.70.27.253/32\",\r\n \"40.70.29.214/32\",\r\n - \ \"40.70.131.151/32\",\r\n \"40.74.64.207/32\",\r\n \"40.74.66.200/32\",\r\n - \ \"40.74.68.85/32\",\r\n \"40.74.74.21/32\",\r\n \"40.74.76.213/32\",\r\n - \ \"40.74.77.205/32\",\r\n \"40.74.81.13/32\",\r\n \"40.74.85.215/32\",\r\n - \ \"40.74.131.151/32\",\r\n \"40.74.132.29/32\",\r\n \"40.74.136.23/32\",\r\n - \ \"40.74.140.4/32\",\r\n \"40.74.140.162/32\",\r\n \"40.74.140.173/32\",\r\n - \ \"40.74.142.133/32\",\r\n \"40.74.143.215/32\",\r\n \"40.74.149.96/27\",\r\n - \ \"40.75.35.240/28\",\r\n \"40.77.31.87/32\",\r\n \"40.77.111.254/32\",\r\n - \ \"40.78.196.176/28\",\r\n \"40.78.204.208/28\",\r\n \"40.78.204.224/27\",\r\n - \ \"40.78.239.16/28\",\r\n \"40.78.245.144/28\",\r\n \"40.78.245.160/27\",\r\n - \ \"40.79.44.7/32\",\r\n \"40.79.139.144/28\",\r\n \"40.79.139.160/27\",\r\n - \ \"40.79.171.240/28\",\r\n \"40.79.180.160/27\",\r\n \"40.79.180.192/28\",\r\n - \ \"40.79.197.48/28\",\r\n \"40.80.180.16/28\",\r\n \"40.80.180.32/27\",\r\n - \ \"40.83.73.39/32\",\r\n \"40.83.75.165/32\",\r\n \"40.83.77.208/32\",\r\n - \ \"40.83.98.194/32\",\r\n \"40.83.100.69/32\",\r\n \"40.83.127.19/32\",\r\n - \ \"40.83.164.80/32\",\r\n \"40.84.25.234/32\",\r\n \"40.84.30.147/32\",\r\n - \ \"40.84.59.136/32\",\r\n \"40.84.138.132/32\",\r\n \"40.85.241.105/32\",\r\n - \ \"40.85.250.135/32\",\r\n \"40.85.250.212/32\",\r\n \"40.85.252.47/32\",\r\n - \ \"40.86.202.42/32\",\r\n \"40.86.203.228/32\",\r\n \"40.86.216.241/32\",\r\n - \ \"40.86.217.241/32\",\r\n \"40.86.226.149/32\",\r\n \"40.86.228.93/32\",\r\n - \ \"40.89.186.28/32\",\r\n \"40.89.186.30/32\",\r\n \"40.89.188.169/32\",\r\n - \ \"40.89.190.104/32\",\r\n \"40.89.191.161/32\",\r\n \"40.112.90.39/32\",\r\n - \ \"40.112.92.104/32\",\r\n \"40.112.95.216/32\",\r\n \"40.113.1.181/32\",\r\n - \ \"40.113.3.202/32\",\r\n \"40.113.4.18/32\",\r\n \"40.113.10.90/32\",\r\n - \ \"40.113.11.17/32\",\r\n \"40.113.12.95/32\",\r\n \"40.113.18.211/32\",\r\n - \ \"40.113.20.202/32\",\r\n \"40.113.22.12/32\",\r\n \"40.113.94.31/32\",\r\n - \ \"40.113.218.230/32\",\r\n \"40.114.8.21/32\",\r\n \"40.114.12.31/32\",\r\n - \ \"40.114.13.216/32\",\r\n \"40.114.14.143/32\",\r\n \"40.114.40.186/32\",\r\n - \ \"40.114.51.5/32\",\r\n \"40.114.82.191/32\",\r\n \"40.115.78.70/32\",\r\n - \ \"40.115.78.237/32\",\r\n \"40.117.99.79/32\",\r\n \"40.117.100.228/32\",\r\n - \ \"40.118.241.243/32\",\r\n \"40.118.244.241/32\",\r\n \"40.120.64.0/27\",\r\n - \ \"40.120.64.32/28\",\r\n \"40.121.91.41/32\",\r\n \"40.122.41.236/32\",\r\n - \ \"40.122.46.197/32\",\r\n \"40.122.170.198/32\",\r\n \"40.126.227.199/32\",\r\n - \ \"40.126.240.14/32\",\r\n \"40.126.249.73/32\",\r\n \"40.126.252.33/32\",\r\n - \ \"40.126.252.85/32\",\r\n \"40.126.252.107/32\",\r\n \"40.127.80.231/32\",\r\n - \ \"40.127.83.170/32\",\r\n \"40.127.84.38/32\",\r\n \"40.127.86.12/32\",\r\n - \ \"40.127.91.18/32\",\r\n \"40.127.93.92/32\",\r\n \"51.11.97.16/28\",\r\n - \ \"51.11.97.32/27\",\r\n \"51.12.100.112/28\",\r\n \"51.12.204.112/28\",\r\n - \ \"51.12.204.192/27\",\r\n \"51.12.229.32/27\",\r\n \"51.104.9.112/28\",\r\n - \ \"51.105.69.96/27\",\r\n \"51.107.60.160/27\",\r\n \"51.107.60.192/28\",\r\n - \ \"51.107.156.160/27\",\r\n \"51.107.156.192/28\",\r\n \"51.116.60.144/28\",\r\n - \ \"51.116.60.160/27\",\r\n \"51.116.158.64/28\",\r\n \"51.116.168.104/32\",\r\n - \ \"51.116.168.222/32\",\r\n \"51.116.171.49/32\",\r\n \"51.116.171.209/32\",\r\n - \ \"51.116.175.0/32\",\r\n \"51.116.175.17/32\",\r\n \"51.116.175.51/32\",\r\n - \ \"51.116.233.22/32\",\r\n \"51.116.233.33/32\",\r\n \"51.116.233.35/32\",\r\n - \ \"51.116.233.40/32\",\r\n \"51.116.233.87/32\",\r\n \"51.116.243.224/27\",\r\n - \ \"51.120.100.160/27\",\r\n \"51.120.109.32/28\",\r\n \"51.120.220.128/27\",\r\n - \ \"51.120.220.160/28\",\r\n \"51.140.28.225/32\",\r\n \"51.140.73.85/32\",\r\n - \ \"51.140.74.14/32\",\r\n \"51.140.78.44/32\",\r\n \"51.140.78.71/32\",\r\n - \ \"51.140.79.109/32\",\r\n \"51.140.84.39/32\",\r\n \"51.140.137.190/32\",\r\n - \ \"51.140.142.28/32\",\r\n \"51.140.153.135/32\",\r\n \"51.140.155.81/32\",\r\n - \ \"51.140.158.24/32\",\r\n \"51.141.45.238/32\",\r\n \"51.141.47.136/32\",\r\n - \ \"51.141.48.98/32\",\r\n \"51.141.51.145/32\",\r\n \"51.141.53.164/32\",\r\n - \ \"51.141.54.185/32\",\r\n \"51.141.112.112/32\",\r\n \"51.141.113.36/32\",\r\n - \ \"51.141.114.77/32\",\r\n \"51.141.118.119/32\",\r\n \"51.141.119.63/32\",\r\n - \ \"51.141.119.150/32\",\r\n \"51.144.176.185/32\",\r\n \"51.144.182.201/32\",\r\n - \ \"52.143.156.55/32\",\r\n \"52.143.158.203/32\",\r\n \"52.143.162.83/32\",\r\n - \ \"52.143.164.15/32\",\r\n \"52.143.164.80/32\",\r\n \"52.147.97.16/28\",\r\n - \ \"52.147.97.32/27\",\r\n \"52.160.90.237/32\",\r\n \"52.160.92.112/32\",\r\n - \ \"52.161.8.128/32\",\r\n \"52.161.9.108/32\",\r\n \"52.161.18.218/32\",\r\n - \ \"52.161.19.82/32\",\r\n \"52.161.26.172/32\",\r\n \"52.161.27.190/32\",\r\n - \ \"52.162.111.144/28\",\r\n \"52.162.111.160/27\",\r\n \"52.162.208.216/32\",\r\n - \ \"52.162.213.231/32\",\r\n \"52.163.93.214/32\",\r\n \"52.163.228.93/32\",\r\n - \ \"52.163.230.166/32\",\r\n \"52.167.109.80/28\",\r\n \"52.169.218.253/32\",\r\n - \ \"52.169.220.174/32\",\r\n \"52.172.9.47/32\",\r\n \"52.172.49.43/32\",\r\n - \ \"52.172.50.24/32\",\r\n \"52.172.51.140/32\",\r\n \"52.172.52.0/32\",\r\n - \ \"52.172.55.231/32\",\r\n \"52.172.154.168/32\",\r\n \"52.172.157.194/32\",\r\n - \ \"52.172.184.192/32\",\r\n \"52.172.185.79/32\",\r\n \"52.172.186.159/32\",\r\n - \ \"52.172.191.194/32\",\r\n \"52.174.49.6/32\",\r\n \"52.174.54.218/32\",\r\n - \ \"52.175.33.254/32\",\r\n \"52.175.198.132/32\",\r\n \"52.178.165.215/32\",\r\n - \ \"52.178.166.21/32\",\r\n \"52.182.141.160/27\",\r\n \"52.183.29.132/32\",\r\n - \ \"52.183.30.10/32\",\r\n \"52.183.30.169/32\",\r\n \"52.183.39.67/32\",\r\n - \ \"52.187.65.81/32\",\r\n \"52.187.65.155/32\",\r\n \"52.187.226.96/32\",\r\n - \ \"52.187.226.139/32\",\r\n \"52.187.227.245/32\",\r\n \"52.187.229.130/32\",\r\n - \ \"52.187.231.161/32\",\r\n \"52.187.231.184/32\",\r\n \"52.189.214.42/32\",\r\n - \ \"52.189.216.28/32\",\r\n \"52.189.220.75/32\",\r\n \"52.189.222.77/32\",\r\n - \ \"52.228.39.241/32\",\r\n \"52.228.39.244/32\",\r\n \"52.229.120.45/32\",\r\n - \ \"52.229.125.57/32\",\r\n \"52.229.126.25/32\",\r\n \"52.231.23.16/28\",\r\n - \ \"52.231.23.32/27\",\r\n \"52.232.128.155/32\",\r\n \"52.232.129.143/32\",\r\n - \ \"52.232.133.109/32\",\r\n \"52.233.29.79/32\",\r\n \"52.233.29.92/32\",\r\n - \ \"52.233.30.218/32\",\r\n \"65.52.8.225/32\",\r\n \"65.52.9.64/32\",\r\n - \ \"65.52.9.96/32\",\r\n \"65.52.10.183/32\",\r\n \"65.52.60.5/32\",\r\n - \ \"65.52.175.34/32\",\r\n \"65.52.185.96/32\",\r\n \"65.52.185.218/32\",\r\n - \ \"65.52.186.153/32\",\r\n \"65.52.186.190/32\",\r\n \"65.52.186.225/32\",\r\n - \ \"65.52.211.164/32\",\r\n \"70.37.50.6/32\",\r\n \"70.37.54.122/32\",\r\n - \ \"102.133.28.208/28\",\r\n \"102.133.28.224/27\",\r\n \"102.133.72.37/32\",\r\n - \ \"102.133.72.98/32\",\r\n \"102.133.72.113/32\",\r\n \"102.133.72.132/32\",\r\n - \ \"102.133.72.145/32\",\r\n \"102.133.72.173/32\",\r\n \"102.133.72.179/32\",\r\n - \ \"102.133.72.183/32\",\r\n \"102.133.72.184/32\",\r\n \"102.133.72.190/32\",\r\n - \ \"102.133.75.169/32\",\r\n \"102.133.75.191/32\",\r\n \"102.133.156.176/28\",\r\n - \ \"102.133.224.125/32\",\r\n \"102.133.226.199/32\",\r\n - \ \"102.133.227.103/32\",\r\n \"102.133.228.4/32\",\r\n \"102.133.228.6/32\",\r\n - \ \"102.133.228.9/32\",\r\n \"102.133.230.4/32\",\r\n \"102.133.230.82/32\",\r\n - \ \"102.133.231.9/32\",\r\n \"102.133.231.51/32\",\r\n \"102.133.231.117/32\",\r\n - \ \"102.133.231.188/32\",\r\n \"102.133.251.224/27\",\r\n - \ \"104.40.49.140/32\",\r\n \"104.40.54.74/32\",\r\n \"104.40.59.188/32\",\r\n - \ \"104.40.61.150/32\",\r\n \"104.40.62.178/32\",\r\n \"104.40.218.37/32\",\r\n - \ \"104.41.0.115/32\",\r\n \"104.41.33.103/32\",\r\n \"104.41.162.245/32\",\r\n - \ \"104.41.163.102/32\",\r\n \"104.41.168.76/32\",\r\n \"104.41.173.132/32\",\r\n - \ \"104.41.179.165/32\",\r\n \"104.41.181.59/32\",\r\n \"104.41.182.232/32\",\r\n - \ \"104.42.38.32/32\",\r\n \"104.42.49.145/32\",\r\n \"104.42.224.227/32\",\r\n - \ \"104.42.236.93/32\",\r\n \"104.43.166.135/32\",\r\n \"104.43.243.39/32\",\r\n - \ \"104.45.9.52/32\",\r\n \"104.45.153.81/32\",\r\n \"104.46.32.99/32\",\r\n - \ \"104.46.34.93/32\",\r\n \"104.46.34.208/32\",\r\n \"104.46.39.63/32\",\r\n - \ \"104.46.42.167/32\",\r\n \"104.46.98.208/32\",\r\n \"104.46.106.158/32\",\r\n - \ \"104.47.138.214/32\",\r\n \"104.208.25.27/32\",\r\n \"104.208.140.40/32\",\r\n - \ \"104.208.155.200/32\",\r\n \"104.208.158.174/32\",\r\n - \ \"104.209.131.77/32\",\r\n \"104.209.133.254/32\",\r\n - \ \"104.209.134.133/32\",\r\n \"104.210.89.222/32\",\r\n - \ \"104.210.89.244/32\",\r\n \"104.210.90.241/32\",\r\n \"104.210.91.55/32\",\r\n - \ \"104.210.144.48/32\",\r\n \"104.210.153.89/32\",\r\n \"104.211.73.195/32\",\r\n - \ \"104.211.74.145/32\",\r\n \"104.211.90.162/32\",\r\n \"104.211.90.169/32\",\r\n - \ \"104.211.101.108/32\",\r\n \"104.211.102.62/32\",\r\n - \ \"104.211.154.7/32\",\r\n \"104.211.154.59/32\",\r\n \"104.211.156.153/32\",\r\n - \ \"104.211.157.237/32\",\r\n \"104.211.158.123/32\",\r\n - \ \"104.211.158.127/32\",\r\n \"104.211.162.205/32\",\r\n - \ \"104.211.164.25/32\",\r\n \"104.211.164.80/32\",\r\n \"104.211.164.112/32\",\r\n - \ \"104.211.164.136/32\",\r\n \"104.211.165.81/32\",\r\n - \ \"104.211.225.152/32\",\r\n \"104.211.227.229/32\",\r\n - \ \"104.211.229.115/32\",\r\n \"104.211.230.126/32\",\r\n - \ \"104.211.230.129/32\",\r\n \"104.211.231.39/32\",\r\n - \ \"104.214.137.243/32\",\r\n \"104.214.161.64/27\",\r\n - \ \"104.214.161.96/28\",\r\n \"104.215.88.156/32\",\r\n \"104.215.89.144/32\",\r\n - \ \"104.215.90.86/32\",\r\n \"104.215.90.189/32\",\r\n \"104.215.90.203/32\",\r\n - \ \"104.215.93.125/32\",\r\n \"104.215.176.31/32\",\r\n \"104.215.176.81/32\",\r\n - \ \"104.215.177.5/32\",\r\n \"104.215.178.204/32\",\r\n \"104.215.179.133/32\",\r\n - \ \"104.215.180.203/32\",\r\n \"104.215.181.6/32\",\r\n \"111.221.85.72/32\",\r\n - \ \"111.221.85.74/32\",\r\n \"137.116.44.82/32\",\r\n \"137.116.80.70/32\",\r\n - \ \"137.116.85.245/32\",\r\n \"137.116.126.165/32\",\r\n - \ \"137.117.72.32/32\",\r\n \"137.135.106.54/32\",\r\n \"138.91.17.47/32\",\r\n - \ \"138.91.25.99/32\",\r\n \"138.91.26.45/32\",\r\n \"138.91.188.137/32\",\r\n - \ \"157.55.210.61/32\",\r\n \"157.55.212.238/32\",\r\n \"157.56.12.202/32\",\r\n - \ \"157.56.160.212/32\",\r\n \"157.56.162.53/32\",\r\n \"157.56.167.147/32\",\r\n - \ \"168.61.86.120/32\",\r\n \"168.61.152.201/32\",\r\n \"168.61.172.83/32\",\r\n - \ \"168.61.172.225/32\",\r\n \"168.61.173.172/32\",\r\n \"168.61.217.177/32\",\r\n - \ \"168.62.109.110/32\",\r\n \"168.62.219.52/32\",\r\n \"168.62.219.83/32\",\r\n - \ \"168.62.248.37/32\",\r\n \"168.62.249.81/32\",\r\n \"168.63.136.37/32\",\r\n - \ \"168.63.200.173/32\",\r\n \"191.232.32.19/32\",\r\n \"191.232.32.100/32\",\r\n - \ \"191.232.34.78/32\",\r\n \"191.232.34.249/32\",\r\n \"191.232.35.177/32\",\r\n - \ \"191.232.36.213/32\",\r\n \"191.233.54.240/28\",\r\n \"191.233.68.51/32\",\r\n - \ \"191.233.207.0/28\",\r\n \"191.233.207.32/27\",\r\n \"191.234.161.28/32\",\r\n - \ \"191.234.161.168/32\",\r\n \"191.234.162.131/32\",\r\n - \ \"191.234.162.178/32\",\r\n \"191.234.166.198/32\",\r\n - \ \"191.234.182.26/32\",\r\n \"191.235.82.221/32\",\r\n \"191.235.86.199/32\",\r\n - \ \"191.235.91.7/32\",\r\n \"191.235.94.220/32\",\r\n \"191.235.95.229/32\",\r\n - \ \"191.235.180.188/32\",\r\n \"191.237.255.116/32\",\r\n - \ \"191.238.41.107/32\",\r\n \"191.238.161.62/32\",\r\n \"191.238.163.65/32\",\r\n - \ \"191.239.67.132/32\",\r\n \"191.239.82.62/32\",\r\n \"191.239.161.74/32\",\r\n - \ \"191.239.177.86/32\",\r\n \"207.46.148.176/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaCentral\",\r\n - \ \"id\": \"LogicApps.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.108.192/27\",\r\n \"20.36.108.224/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaCentral2\",\r\n - \ \"id\": \"LogicApps.AustraliaCentral2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.117.96/27\",\r\n \"20.36.117.128/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaEast\",\r\n - \ \"id\": \"LogicApps.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.78.192/27\",\r\n \"13.75.149.4/32\",\r\n - \ \"13.75.153.66/32\",\r\n \"40.79.171.240/28\",\r\n \"40.126.227.199/32\",\r\n - \ \"40.126.240.14/32\",\r\n \"40.126.249.73/32\",\r\n \"40.126.252.33/32\",\r\n - \ \"40.126.252.85/32\",\r\n \"40.126.252.107/32\",\r\n \"52.187.226.96/32\",\r\n - \ \"52.187.226.139/32\",\r\n \"52.187.227.245/32\",\r\n \"52.187.229.130/32\",\r\n - \ \"52.187.231.161/32\",\r\n \"52.187.231.184/32\",\r\n \"104.210.89.222/32\",\r\n - \ \"104.210.89.244/32\",\r\n \"104.210.90.241/32\",\r\n \"104.210.91.55/32\",\r\n - \ \"191.239.67.132/32\",\r\n \"191.239.82.62/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaSoutheast\",\r\n - \ \"id\": \"LogicApps.AustraliaSoutheast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.159.205/32\",\r\n \"13.73.114.207/32\",\r\n - \ \"13.73.115.153/32\",\r\n \"13.77.3.139/32\",\r\n \"13.77.53.224/27\",\r\n - \ \"13.77.55.128/28\",\r\n \"13.77.56.167/32\",\r\n \"13.77.58.136/32\",\r\n - \ \"40.115.78.70/32\",\r\n \"40.115.78.237/32\",\r\n \"40.127.80.231/32\",\r\n - \ \"40.127.83.170/32\",\r\n \"40.127.84.38/32\",\r\n \"40.127.86.12/32\",\r\n - \ \"40.127.91.18/32\",\r\n \"40.127.93.92/32\",\r\n \"52.189.214.42/32\",\r\n - \ \"52.189.216.28/32\",\r\n \"52.189.220.75/32\",\r\n \"52.189.222.77/32\",\r\n - \ \"191.239.161.74/32\",\r\n \"191.239.177.86/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.BrazilSouth\",\r\n - \ \"id\": \"LogicApps.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"104.41.0.115/32\",\r\n \"104.41.33.103/32\",\r\n - \ \"191.232.32.19/32\",\r\n \"191.232.32.100/32\",\r\n \"191.232.34.78/32\",\r\n - \ \"191.232.34.249/32\",\r\n \"191.232.35.177/32\",\r\n \"191.232.36.213/32\",\r\n - \ \"191.233.207.0/28\",\r\n \"191.233.207.32/27\",\r\n \"191.234.161.28/32\",\r\n - \ \"191.234.161.168/32\",\r\n \"191.234.162.131/32\",\r\n - \ \"191.234.162.178/32\",\r\n \"191.234.166.198/32\",\r\n - \ \"191.234.182.26/32\",\r\n \"191.235.82.221/32\",\r\n \"191.235.86.199/32\",\r\n - \ \"191.235.91.7/32\",\r\n \"191.235.94.220/32\",\r\n \"191.235.95.229/32\",\r\n - \ \"191.237.255.116/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"LogicApps.CanadaCentral\",\r\n \"id\": \"LogicApps.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.71.184.150/32\",\r\n - \ \"13.71.186.1/32\",\r\n \"13.88.249.209/32\",\r\n \"13.106.118.32/27\",\r\n - \ \"13.106.118.96/27\",\r\n \"20.38.149.144/28\",\r\n \"20.38.149.160/27\",\r\n - \ \"40.85.241.105/32\",\r\n \"40.85.250.135/32\",\r\n \"40.85.250.212/32\",\r\n - \ \"40.85.252.47/32\",\r\n \"52.228.39.241/32\",\r\n \"52.228.39.244/32\",\r\n - \ \"52.233.29.79/32\",\r\n \"52.233.29.92/32\",\r\n \"52.233.30.218/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CanadaEast\",\r\n - \ \"id\": \"LogicApps.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"40.69.110.192/27\",\r\n \"40.69.110.224/28\",\r\n - \ \"40.86.202.42/32\",\r\n \"40.86.203.228/32\",\r\n \"40.86.216.241/32\",\r\n - \ \"40.86.217.241/32\",\r\n \"40.86.226.149/32\",\r\n \"40.86.228.93/32\",\r\n - \ \"52.229.120.45/32\",\r\n \"52.229.125.57/32\",\r\n \"52.229.126.25/32\",\r\n - \ \"52.232.128.155/32\",\r\n \"52.232.129.143/32\",\r\n \"52.232.133.109/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CentralIndia\",\r\n - \ \"id\": \"LogicApps.CentralIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"20.43.121.192/27\",\r\n \"20.43.121.224/28\",\r\n - \ \"52.172.154.168/32\",\r\n \"52.172.157.194/32\",\r\n \"52.172.184.192/32\",\r\n - \ \"52.172.185.79/32\",\r\n \"52.172.186.159/32\",\r\n \"52.172.191.194/32\",\r\n - \ \"104.211.73.195/32\",\r\n \"104.211.74.145/32\",\r\n \"104.211.90.162/32\",\r\n - \ \"104.211.90.169/32\",\r\n \"104.211.101.108/32\",\r\n - \ \"104.211.102.62/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"LogicApps.CentralUS\",\r\n \"id\": \"LogicApps.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.67.236.76/32\",\r\n - \ \"13.67.236.125/32\",\r\n \"13.89.178.48/28\",\r\n \"23.100.82.16/32\",\r\n - \ \"23.100.86.139/32\",\r\n \"23.100.87.24/32\",\r\n \"23.100.87.56/32\",\r\n - \ \"40.77.31.87/32\",\r\n \"40.77.111.254/32\",\r\n \"40.113.218.230/32\",\r\n - \ \"40.122.41.236/32\",\r\n \"40.122.46.197/32\",\r\n \"40.122.170.198/32\",\r\n - \ \"52.182.141.160/27\",\r\n \"104.43.166.135/32\",\r\n \"104.43.243.39/32\",\r\n - \ \"104.208.25.27/32\",\r\n \"168.61.152.201/32\",\r\n \"168.61.172.83/32\",\r\n - \ \"168.61.172.225/32\",\r\n \"168.61.173.172/32\",\r\n \"168.61.217.177/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CentralUSEUAP\",\r\n - \ \"id\": \"LogicApps.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.204.208/28\",\r\n \"40.78.204.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.EastAsia\",\r\n - \ \"id\": \"LogicApps.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.75.89.159/32\",\r\n \"13.75.94.173/32\",\r\n - \ \"23.97.68.172/32\",\r\n \"23.99.125.99/32\",\r\n \"40.83.73.39/32\",\r\n - \ \"40.83.75.165/32\",\r\n \"40.83.77.208/32\",\r\n \"40.83.98.194/32\",\r\n - \ \"40.83.100.69/32\",\r\n \"40.83.127.19/32\",\r\n \"52.175.33.254/32\",\r\n - \ \"65.52.175.34/32\",\r\n \"65.52.185.96/32\",\r\n \"65.52.185.218/32\",\r\n - \ \"65.52.186.153/32\",\r\n \"65.52.186.190/32\",\r\n \"65.52.186.225/32\",\r\n - \ \"104.214.161.64/27\",\r\n \"104.214.161.96/28\",\r\n \"168.63.136.37/32\",\r\n - \ \"168.63.200.173/32\",\r\n \"207.46.148.176/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.EastUS\",\r\n \"id\": - \"LogicApps.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.92.98.111/32\",\r\n \"20.42.64.48/28\",\r\n \"20.42.72.160/27\",\r\n - \ \"23.100.29.190/32\",\r\n \"23.101.132.208/32\",\r\n \"23.101.136.201/32\",\r\n - \ \"23.101.139.153/32\",\r\n \"40.114.8.21/32\",\r\n \"40.114.12.31/32\",\r\n - \ \"40.114.13.216/32\",\r\n \"40.114.14.143/32\",\r\n \"40.114.40.186/32\",\r\n - \ \"40.114.51.5/32\",\r\n \"40.114.82.191/32\",\r\n \"40.117.99.79/32\",\r\n - \ \"40.117.100.228/32\",\r\n \"40.121.91.41/32\",\r\n \"104.45.153.81/32\",\r\n - \ \"137.116.126.165/32\",\r\n \"137.117.72.32/32\",\r\n \"137.135.106.54/32\",\r\n - \ \"191.238.41.107/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"LogicApps.EastUS2\",\r\n \"id\": \"LogicApps.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"20.44.17.224/27\",\r\n - \ \"40.70.26.154/32\",\r\n \"40.70.27.236/32\",\r\n \"40.70.27.253/32\",\r\n - \ \"40.70.29.214/32\",\r\n \"40.70.131.151/32\",\r\n \"40.79.44.7/32\",\r\n - \ \"40.84.25.234/32\",\r\n \"40.84.30.147/32\",\r\n \"40.84.59.136/32\",\r\n - \ \"52.167.109.80/28\",\r\n \"104.46.98.208/32\",\r\n \"104.46.106.158/32\",\r\n - \ \"104.208.140.40/32\",\r\n \"104.208.155.200/32\",\r\n - \ \"104.208.158.174/32\",\r\n \"104.209.131.77/32\",\r\n - \ \"104.209.133.254/32\",\r\n \"104.209.134.133/32\",\r\n - \ \"137.116.44.82/32\",\r\n \"137.116.80.70/32\",\r\n \"137.116.85.245/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.EastUS2EUAP\",\r\n - \ \"id\": \"LogicApps.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"40.74.149.96/27\",\r\n \"40.75.35.240/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.FranceCentral\",\r\n - \ \"id\": \"LogicApps.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"20.188.33.169/32\",\r\n \"20.188.39.105/32\",\r\n - \ \"40.79.139.144/28\",\r\n \"40.79.139.160/27\",\r\n \"40.89.186.28/32\",\r\n - \ \"40.89.186.30/32\",\r\n \"40.89.188.169/32\",\r\n \"40.89.190.104/32\",\r\n - \ \"40.89.191.161/32\",\r\n \"52.143.156.55/32\",\r\n \"52.143.158.203/32\",\r\n - \ \"52.143.162.83/32\",\r\n \"52.143.164.15/32\",\r\n \"52.143.164.80/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.FranceSouth\",\r\n - \ \"id\": \"LogicApps.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"40.79.180.160/27\",\r\n \"40.79.180.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.GermanyNorth\",\r\n - \ \"id\": \"LogicApps.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"51.116.60.144/28\",\r\n \"51.116.60.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.GermanyWestCentral\",\r\n - \ \"id\": \"LogicApps.GermanyWestCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.158.64/28\",\r\n \"51.116.168.104/32\",\r\n - \ \"51.116.168.222/32\",\r\n \"51.116.171.49/32\",\r\n \"51.116.171.209/32\",\r\n - \ \"51.116.175.0/32\",\r\n \"51.116.175.17/32\",\r\n \"51.116.175.51/32\",\r\n - \ \"51.116.233.22/32\",\r\n \"51.116.233.33/32\",\r\n \"51.116.233.35/32\",\r\n - \ \"51.116.233.40/32\",\r\n \"51.116.233.87/32\",\r\n \"51.116.243.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.JapanEast\",\r\n - \ \"id\": \"LogicApps.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.71.146.140/32\",\r\n \"13.71.158.3/32\",\r\n - \ \"13.71.158.120/32\",\r\n \"13.73.4.207/32\",\r\n \"13.78.18.168/32\",\r\n - \ \"13.78.20.232/32\",\r\n \"13.78.21.155/32\",\r\n \"13.78.35.229/32\",\r\n - \ \"13.78.42.223/32\",\r\n \"13.78.43.164/32\",\r\n \"13.78.62.130/32\",\r\n - \ \"13.78.84.187/32\",\r\n \"13.78.111.160/27\",\r\n \"23.102.70.174/32\",\r\n - \ \"40.79.197.48/28\",\r\n \"104.41.162.245/32\",\r\n \"104.41.163.102/32\",\r\n - \ \"104.41.168.76/32\",\r\n \"104.41.173.132/32\",\r\n \"104.41.179.165/32\",\r\n - \ \"104.41.181.59/32\",\r\n \"104.41.182.232/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.JapanWest\",\r\n - \ \"id\": \"LogicApps.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"40.74.64.207/32\",\r\n \"40.74.66.200/32\",\r\n - \ \"40.74.68.85/32\",\r\n \"40.74.74.21/32\",\r\n \"40.74.76.213/32\",\r\n - \ \"40.74.77.205/32\",\r\n \"40.74.81.13/32\",\r\n \"40.74.85.215/32\",\r\n - \ \"40.74.131.151/32\",\r\n \"40.74.132.29/32\",\r\n \"40.74.136.23/32\",\r\n - \ \"40.74.140.4/32\",\r\n \"40.74.140.162/32\",\r\n \"40.74.140.173/32\",\r\n - \ \"40.74.142.133/32\",\r\n \"40.74.143.215/32\",\r\n \"40.80.180.16/28\",\r\n - \ \"40.80.180.32/27\",\r\n \"104.214.137.243/32\",\r\n \"138.91.17.47/32\",\r\n - \ \"138.91.25.99/32\",\r\n \"138.91.26.45/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.KoreaCentral\",\r\n - \ \"id\": \"LogicApps.KoreaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"52.231.23.16/28\",\r\n \"52.231.23.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.KoreaSouth\",\r\n - \ \"id\": \"LogicApps.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"52.147.97.16/28\",\r\n \"52.147.97.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorthCentralUS\",\r\n - \ \"id\": \"LogicApps.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"23.96.200.77/32\",\r\n \"23.96.200.227/32\",\r\n - \ \"23.96.203.46/32\",\r\n \"23.96.210.49/32\",\r\n \"23.96.212.28/32\",\r\n - \ \"23.96.253.219/32\",\r\n \"52.162.111.144/28\",\r\n \"52.162.111.160/27\",\r\n - \ \"52.162.208.216/32\",\r\n \"52.162.213.231/32\",\r\n \"65.52.8.225/32\",\r\n - \ \"65.52.9.64/32\",\r\n \"65.52.9.96/32\",\r\n \"65.52.10.183/32\",\r\n - \ \"65.52.60.5/32\",\r\n \"65.52.211.164/32\",\r\n \"157.55.210.61/32\",\r\n - \ \"157.55.212.238/32\",\r\n \"157.56.12.202/32\",\r\n \"168.62.109.110/32\",\r\n - \ \"168.62.248.37/32\",\r\n \"168.62.249.81/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorthEurope\",\r\n - \ \"id\": \"LogicApps.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.69.231.160/27\",\r\n \"13.69.233.16/28\",\r\n - \ \"13.79.173.49/32\",\r\n \"40.112.90.39/32\",\r\n \"40.112.92.104/32\",\r\n - \ \"40.112.95.216/32\",\r\n \"40.113.1.181/32\",\r\n \"40.113.3.202/32\",\r\n - \ \"40.113.4.18/32\",\r\n \"40.113.10.90/32\",\r\n \"40.113.11.17/32\",\r\n - \ \"40.113.12.95/32\",\r\n \"40.113.18.211/32\",\r\n \"40.113.20.202/32\",\r\n - \ \"40.113.22.12/32\",\r\n \"40.113.94.31/32\",\r\n \"52.169.218.253/32\",\r\n - \ \"52.169.220.174/32\",\r\n \"52.178.165.215/32\",\r\n \"52.178.166.21/32\",\r\n - \ \"168.61.86.120/32\",\r\n \"191.235.180.188/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorwayEast\",\r\n - \ \"id\": \"LogicApps.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"51.120.100.160/27\",\r\n \"51.120.109.32/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorwayWest\",\r\n - \ \"id\": \"LogicApps.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"51.120.220.128/27\",\r\n \"51.120.220.160/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SouthAfricaNorth\",\r\n - \ \"id\": \"LogicApps.SouthAfricaNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.156.176/28\",\r\n \"102.133.224.125/32\",\r\n - \ \"102.133.226.199/32\",\r\n \"102.133.227.103/32\",\r\n - \ \"102.133.228.4/32\",\r\n \"102.133.228.6/32\",\r\n \"102.133.228.9/32\",\r\n - \ \"102.133.230.4/32\",\r\n \"102.133.230.82/32\",\r\n \"102.133.231.9/32\",\r\n - \ \"102.133.231.51/32\",\r\n \"102.133.231.117/32\",\r\n - \ \"102.133.231.188/32\",\r\n \"102.133.251.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SouthAfricaWest\",\r\n - \ \"id\": \"LogicApps.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.28.208/28\",\r\n \"102.133.28.224/27\",\r\n - \ \"102.133.72.37/32\",\r\n \"102.133.72.98/32\",\r\n \"102.133.72.113/32\",\r\n - \ \"102.133.72.132/32\",\r\n \"102.133.72.145/32\",\r\n \"102.133.72.173/32\",\r\n - \ \"102.133.72.179/32\",\r\n \"102.133.72.183/32\",\r\n \"102.133.72.184/32\",\r\n - \ \"102.133.72.190/32\",\r\n \"102.133.75.169/32\",\r\n \"102.133.75.191/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SouthCentralUS\",\r\n - \ \"id\": \"LogicApps.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.65.39.247/32\",\r\n \"13.65.82.17/32\",\r\n - \ \"13.65.82.190/32\",\r\n \"13.65.86.56/32\",\r\n \"13.65.98.39/32\",\r\n - \ \"13.66.52.232/32\",\r\n \"13.73.244.144/28\",\r\n \"13.73.244.160/27\",\r\n - \ \"13.84.41.46/32\",\r\n \"13.84.43.45/32\",\r\n \"13.84.159.168/32\",\r\n - \ \"13.85.79.155/32\",\r\n \"23.100.124.84/32\",\r\n \"23.100.127.172/32\",\r\n - \ \"23.101.183.225/32\",\r\n \"23.101.191.106/32\",\r\n \"40.84.138.132/32\",\r\n - \ \"70.37.50.6/32\",\r\n \"70.37.54.122/32\",\r\n \"104.210.144.48/32\",\r\n - \ \"104.210.153.89/32\",\r\n \"104.215.88.156/32\",\r\n \"104.215.89.144/32\",\r\n - \ \"104.215.90.86/32\",\r\n \"104.215.90.189/32\",\r\n \"104.215.90.203/32\",\r\n - \ \"104.215.93.125/32\",\r\n \"191.238.161.62/32\",\r\n \"191.238.163.65/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SoutheastAsia\",\r\n - \ \"id\": \"LogicApps.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.13.224/27\",\r\n \"13.67.91.135/32\",\r\n - \ \"13.67.107.128/32\",\r\n \"13.67.110.109/32\",\r\n \"13.76.4.194/32\",\r\n - \ \"13.76.5.96/32\",\r\n \"13.76.133.155/32\",\r\n \"40.78.239.16/28\",\r\n - \ \"52.163.93.214/32\",\r\n \"52.163.228.93/32\",\r\n \"52.163.230.166/32\",\r\n - \ \"52.187.65.81/32\",\r\n \"52.187.65.155/32\",\r\n \"104.215.176.31/32\",\r\n - \ \"104.215.176.81/32\",\r\n \"104.215.177.5/32\",\r\n \"104.215.178.204/32\",\r\n - \ \"104.215.179.133/32\",\r\n \"104.215.180.203/32\",\r\n - \ \"104.215.181.6/32\",\r\n \"111.221.85.72/32\",\r\n \"111.221.85.74/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SouthIndia\",\r\n - \ \"id\": \"LogicApps.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"20.192.184.0/27\",\r\n \"40.78.196.176/28\",\r\n - \ \"52.172.9.47/32\",\r\n \"52.172.49.43/32\",\r\n \"52.172.50.24/32\",\r\n - \ \"52.172.51.140/32\",\r\n \"52.172.52.0/32\",\r\n \"52.172.55.231/32\",\r\n - \ \"104.211.225.152/32\",\r\n \"104.211.227.229/32\",\r\n - \ \"104.211.229.115/32\",\r\n \"104.211.230.126/32\",\r\n - \ \"104.211.230.129/32\",\r\n \"104.211.231.39/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.SwitzerlandNorth\",\r\n - \ \"id\": \"LogicApps.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.60.160/27\",\r\n \"51.107.60.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SwitzerlandWest\",\r\n - \ \"id\": \"LogicApps.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.156.160/27\",\r\n \"51.107.156.192/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UAECentral\",\r\n - \ \"id\": \"LogicApps.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"20.37.76.208/28\",\r\n \"20.37.76.224/27\",\r\n - \ \"20.45.64.29/32\",\r\n \"20.45.64.87/32\",\r\n \"20.45.67.134/31\",\r\n - \ \"20.45.67.170/32\",\r\n \"20.45.71.213/32\",\r\n \"20.45.72.54/32\",\r\n - \ \"20.45.72.72/32\",\r\n \"20.45.75.193/32\",\r\n \"20.45.75.200/32\",\r\n - \ \"20.45.75.236/32\",\r\n \"20.45.79.239/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.UAENorth\",\r\n - \ \"id\": \"LogicApps.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"40.120.64.0/27\",\r\n \"40.120.64.32/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKNorth\",\r\n \"id\": - \"LogicApps.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.87.124.144/28\",\r\n \"13.87.124.160/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKSouth\",\r\n - \ \"id\": \"LogicApps.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"51.104.9.112/28\",\r\n \"51.105.69.96/27\",\r\n - \ \"51.140.28.225/32\",\r\n \"51.140.73.85/32\",\r\n \"51.140.74.14/32\",\r\n - \ \"51.140.78.44/32\",\r\n \"51.140.78.71/32\",\r\n \"51.140.79.109/32\",\r\n - \ \"51.140.84.39/32\",\r\n \"51.140.137.190/32\",\r\n \"51.140.142.28/32\",\r\n - \ \"51.140.153.135/32\",\r\n \"51.140.155.81/32\",\r\n \"51.140.158.24/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKSouth2\",\r\n - \ \"id\": \"LogicApps.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.87.58.144/28\",\r\n \"13.87.58.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKWest\",\r\n \"id\": - \"LogicApps.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"51.11.97.16/28\",\r\n \"51.11.97.32/27\",\r\n \"51.141.45.238/32\",\r\n - \ \"51.141.47.136/32\",\r\n \"51.141.48.98/32\",\r\n \"51.141.51.145/32\",\r\n - \ \"51.141.53.164/32\",\r\n \"51.141.54.185/32\",\r\n \"51.141.112.112/32\",\r\n - \ \"51.141.113.36/32\",\r\n \"51.141.114.77/32\",\r\n \"51.141.118.119/32\",\r\n - \ \"51.141.119.63/32\",\r\n \"51.141.119.150/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestCentralUS\",\r\n - \ \"id\": \"LogicApps.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.199.128/27\",\r\n \"13.71.199.160/28\",\r\n - \ \"13.78.129.20/32\",\r\n \"13.78.137.179/32\",\r\n \"13.78.137.247/32\",\r\n - \ \"13.78.141.75/32\",\r\n \"13.78.148.140/32\",\r\n \"13.78.151.161/32\",\r\n - \ \"52.161.8.128/32\",\r\n \"52.161.9.108/32\",\r\n \"52.161.18.218/32\",\r\n - \ \"52.161.19.82/32\",\r\n \"52.161.26.172/32\",\r\n \"52.161.27.190/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestEurope\",\r\n - \ \"id\": \"LogicApps.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.69.71.160/27\",\r\n \"13.69.109.144/28\",\r\n - \ \"13.95.147.65/32\",\r\n \"13.95.155.53/32\",\r\n \"23.97.210.126/32\",\r\n - \ \"23.97.211.179/32\",\r\n \"23.97.218.130/32\",\r\n \"40.68.209.23/32\",\r\n - \ \"40.68.222.65/32\",\r\n \"51.144.176.185/32\",\r\n \"51.144.182.201/32\",\r\n - \ \"52.174.49.6/32\",\r\n \"52.174.54.218/32\",\r\n \"104.40.218.37/32\",\r\n - \ \"104.45.9.52/32\",\r\n \"104.46.32.99/32\",\r\n \"104.46.34.93/32\",\r\n - \ \"104.46.34.208/32\",\r\n \"104.46.39.63/32\",\r\n \"104.46.42.167/32\",\r\n - \ \"104.47.138.214/32\",\r\n \"191.233.68.51/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestIndia\",\r\n - \ \"id\": \"LogicApps.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"20.38.128.176/28\",\r\n \"20.38.128.192/27\",\r\n - \ \"104.211.154.7/32\",\r\n \"104.211.154.59/32\",\r\n \"104.211.156.153/32\",\r\n - \ \"104.211.157.237/32\",\r\n \"104.211.158.123/32\",\r\n - \ \"104.211.158.127/32\",\r\n \"104.211.162.205/32\",\r\n - \ \"104.211.164.25/32\",\r\n \"104.211.164.80/32\",\r\n \"104.211.164.112/32\",\r\n - \ \"104.211.164.136/32\",\r\n \"104.211.165.81/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestUS\",\r\n \"id\": - \"LogicApps.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.86.221.240/28\",\r\n \"13.86.223.0/27\",\r\n - \ \"13.91.252.184/32\",\r\n \"40.83.164.80/32\",\r\n \"40.118.241.243/32\",\r\n - \ \"40.118.244.241/32\",\r\n \"52.160.90.237/32\",\r\n \"52.160.92.112/32\",\r\n - \ \"104.40.49.140/32\",\r\n \"104.40.54.74/32\",\r\n \"104.40.59.188/32\",\r\n - \ \"104.40.61.150/32\",\r\n \"104.40.62.178/32\",\r\n \"104.42.38.32/32\",\r\n - \ \"104.42.49.145/32\",\r\n \"104.42.224.227/32\",\r\n \"104.42.236.93/32\",\r\n - \ \"138.91.188.137/32\",\r\n \"157.56.160.212/32\",\r\n \"157.56.162.53/32\",\r\n - \ \"157.56.167.147/32\",\r\n \"168.62.219.52/32\",\r\n \"168.62.219.83/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestUS2\",\r\n - \ \"id\": \"LogicApps.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.66.128.68/32\",\r\n \"13.66.201.169/32\",\r\n - \ \"13.66.210.167/32\",\r\n \"13.66.224.169/32\",\r\n \"13.66.246.219/32\",\r\n - \ \"13.77.149.159/32\",\r\n \"13.77.152.21/32\",\r\n \"40.78.245.144/28\",\r\n - \ \"40.78.245.160/27\",\r\n \"52.175.198.132/32\",\r\n \"52.183.29.132/32\",\r\n - \ \"52.183.30.10/32\",\r\n \"52.183.30.169/32\",\r\n \"52.183.39.67/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicAppsManagement\",\r\n - \ \"id\": \"LogicAppsManagement\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\": - [\r\n \"13.65.39.247/32\",\r\n \"13.65.98.39/32\",\r\n \"13.66.128.68/32\",\r\n - \ \"13.66.224.169/32\",\r\n \"13.67.236.76/32\",\r\n \"13.69.109.144/28\",\r\n - \ \"13.69.233.16/28\",\r\n \"13.71.146.140/32\",\r\n \"13.71.199.160/28\",\r\n - \ \"13.73.115.153/32\",\r\n \"13.73.244.144/28\",\r\n \"13.75.89.159/32\",\r\n - \ \"13.75.153.66/32\",\r\n \"13.77.55.128/28\",\r\n \"13.78.43.164/32\",\r\n - \ \"13.78.62.130/32\",\r\n \"13.78.84.187/32\",\r\n \"13.78.137.247/32\",\r\n - \ \"13.79.173.49/32\",\r\n \"13.84.41.46/32\",\r\n \"13.84.43.45/32\",\r\n - \ \"13.85.79.155/32\",\r\n \"13.86.221.240/28\",\r\n \"13.87.58.144/28\",\r\n - \ \"13.87.124.144/28\",\r\n \"13.88.249.209/32\",\r\n \"13.89.178.48/28\",\r\n - \ \"13.91.252.184/32\",\r\n \"13.95.155.53/32\",\r\n \"13.106.118.32/27\",\r\n - \ \"20.36.108.224/28\",\r\n \"20.36.117.128/28\",\r\n \"20.37.76.208/28\",\r\n - \ \"20.38.128.176/28\",\r\n \"20.38.149.144/28\",\r\n \"20.42.64.48/28\",\r\n - \ \"20.43.121.224/28\",\r\n \"20.44.4.176/28\",\r\n \"20.45.64.29/32\",\r\n - \ \"20.45.64.87/32\",\r\n \"20.45.71.213/32\",\r\n \"20.45.75.193/32\",\r\n - \ \"20.150.172.240/28\",\r\n \"20.192.238.160/28\",\r\n \"20.193.206.48/28\",\r\n - \ \"23.97.68.172/32\",\r\n \"40.67.60.176/28\",\r\n \"40.69.110.224/28\",\r\n - \ \"40.70.27.253/32\",\r\n \"40.74.66.200/32\",\r\n \"40.74.81.13/32\",\r\n - \ \"40.74.85.215/32\",\r\n \"40.74.140.173/32\",\r\n \"40.75.35.240/28\",\r\n - \ \"40.77.31.87/32\",\r\n \"40.77.111.254/32\",\r\n \"40.78.196.176/28\",\r\n - \ \"40.78.204.208/28\",\r\n \"40.78.239.16/28\",\r\n \"40.78.245.144/28\",\r\n - \ \"40.79.44.7/32\",\r\n \"40.79.139.144/28\",\r\n \"40.79.171.240/28\",\r\n - \ \"40.79.180.192/28\",\r\n \"40.79.197.48/28\",\r\n \"40.80.180.16/28\",\r\n - \ \"40.83.98.194/32\",\r\n \"40.84.25.234/32\",\r\n \"40.84.59.136/32\",\r\n - \ \"40.84.138.132/32\",\r\n \"40.85.241.105/32\",\r\n \"40.86.202.42/32\",\r\n - \ \"40.112.90.39/32\",\r\n \"40.115.78.70/32\",\r\n \"40.115.78.237/32\",\r\n - \ \"40.117.99.79/32\",\r\n \"40.117.100.228/32\",\r\n \"40.120.64.32/28\",\r\n - \ \"51.11.97.16/28\",\r\n \"51.12.100.112/28\",\r\n \"51.12.204.112/28\",\r\n - \ \"51.104.9.112/28\",\r\n \"51.107.60.192/28\",\r\n \"51.107.156.192/28\",\r\n - \ \"51.116.60.144/28\",\r\n \"51.116.158.64/28\",\r\n \"51.116.168.222/32\",\r\n - \ \"51.116.171.209/32\",\r\n \"51.116.175.0/32\",\r\n \"51.116.233.40/32\",\r\n - \ \"51.120.109.32/28\",\r\n \"51.120.220.160/28\",\r\n \"51.140.78.71/32\",\r\n - \ \"51.140.79.109/32\",\r\n \"51.140.84.39/32\",\r\n \"51.140.155.81/32\",\r\n - \ \"51.141.48.98/32\",\r\n \"51.141.51.145/32\",\r\n \"51.141.53.164/32\",\r\n - \ \"51.141.119.150/32\",\r\n \"51.144.176.185/32\",\r\n \"52.147.97.16/28\",\r\n - \ \"52.160.90.237/32\",\r\n \"52.161.8.128/32\",\r\n \"52.161.19.82/32\",\r\n - \ \"52.161.26.172/32\",\r\n \"52.162.111.144/28\",\r\n \"52.163.93.214/32\",\r\n - \ \"52.167.109.80/28\",\r\n \"52.169.218.253/32\",\r\n \"52.169.220.174/32\",\r\n - \ \"52.172.9.47/32\",\r\n \"52.172.49.43/32\",\r\n \"52.172.51.140/32\",\r\n - \ \"52.172.157.194/32\",\r\n \"52.172.184.192/32\",\r\n \"52.172.191.194/32\",\r\n - \ \"52.174.49.6/32\",\r\n \"52.174.54.218/32\",\r\n \"52.183.30.10/32\",\r\n - \ \"52.183.39.67/32\",\r\n \"52.187.65.81/32\",\r\n \"52.187.65.155/32\",\r\n - \ \"52.187.231.161/32\",\r\n \"52.189.216.28/32\",\r\n \"52.229.125.57/32\",\r\n - \ \"52.231.23.16/28\",\r\n \"52.232.129.143/32\",\r\n \"52.232.133.109/32\",\r\n - \ \"52.233.29.79/32\",\r\n \"52.233.30.218/32\",\r\n \"65.52.9.64/32\",\r\n - \ \"65.52.211.164/32\",\r\n \"102.133.28.208/28\",\r\n \"102.133.72.145/32\",\r\n - \ \"102.133.72.173/32\",\r\n \"102.133.72.184/32\",\r\n \"102.133.72.190/32\",\r\n - \ \"102.133.156.176/28\",\r\n \"102.133.224.125/32\",\r\n - \ \"102.133.226.199/32\",\r\n \"102.133.228.4/32\",\r\n \"102.133.228.9/32\",\r\n - \ \"104.43.243.39/32\",\r\n \"104.210.89.222/32\",\r\n \"104.210.89.244/32\",\r\n - \ \"104.210.153.89/32\",\r\n \"104.211.73.195/32\",\r\n \"104.211.157.237/32\",\r\n - \ \"104.211.164.25/32\",\r\n \"104.211.164.112/32\",\r\n - \ \"104.211.165.81/32\",\r\n \"104.211.225.152/32\",\r\n - \ \"104.214.161.96/28\",\r\n \"104.215.181.6/32\",\r\n \"137.116.126.165/32\",\r\n - \ \"137.135.106.54/32\",\r\n \"138.91.188.137/32\",\r\n \"157.56.12.202/32\",\r\n - \ \"157.56.160.212/32\",\r\n \"168.62.249.81/32\",\r\n \"168.63.200.173/32\",\r\n - \ \"191.233.54.240/28\",\r\n \"191.233.207.0/28\",\r\n \"191.234.166.198/32\",\r\n - \ \"191.235.86.199/32\",\r\n \"191.235.94.220/32\",\r\n \"191.235.95.229/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"FW\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.26.88/32\",\r\n \"13.64.28.87/32\",\r\n - \ \"13.64.29.32/32\",\r\n \"13.64.29.161/32\",\r\n \"13.64.30.76/32\",\r\n - \ \"13.64.30.117/32\",\r\n \"13.64.30.118/32\",\r\n \"13.64.31.116/32\",\r\n - \ \"13.64.196.27/32\",\r\n \"13.64.198.19/32\",\r\n \"13.64.198.97/32\",\r\n - \ \"13.64.199.41/32\",\r\n \"13.64.252.115/32\",\r\n \"13.66.134.18/32\",\r\n - \ \"13.66.142.80/28\",\r\n \"13.66.158.8/32\",\r\n \"13.66.168.209/32\",\r\n - \ \"13.66.173.192/32\",\r\n \"13.66.210.205/32\",\r\n \"13.67.10.192/28\",\r\n - \ \"13.67.48.221/32\",\r\n \"13.69.67.96/28\",\r\n \"13.69.107.96/28\",\r\n - \ \"13.69.190.115/32\",\r\n \"13.69.230.48/28\",\r\n \"13.70.74.160/27\",\r\n - \ \"13.71.175.0/27\",\r\n \"13.71.196.192/27\",\r\n \"13.73.242.224/27\",\r\n - \ \"13.74.108.176/28\",\r\n \"13.74.168.152/32\",\r\n \"13.75.39.128/27\",\r\n - \ \"13.76.43.73/32\",\r\n \"13.76.129.255/32\",\r\n \"13.77.53.96/27\",\r\n - \ \"13.77.80.28/32\",\r\n \"13.77.136.80/32\",\r\n \"13.77.148.229/32\",\r\n - \ \"13.77.160.162/32\",\r\n \"13.77.163.148/32\",\r\n \"13.77.165.61/32\",\r\n - \ \"13.80.7.94/32\",\r\n \"13.80.22.71/32\",\r\n \"13.80.125.22/32\",\r\n - \ \"13.81.123.49/32\",\r\n \"13.81.204.189/32\",\r\n \"13.81.212.71/32\",\r\n - \ \"13.86.176.189/32\",\r\n \"13.86.176.211/32\",\r\n \"13.86.219.224/27\",\r\n - \ \"13.86.235.202/32\",\r\n \"13.86.239.236/32\",\r\n \"13.88.224.38/32\",\r\n - \ \"13.88.224.211/32\",\r\n \"13.88.224.222/32\",\r\n \"13.88.226.74/32\",\r\n - \ \"13.88.227.7/32\",\r\n \"13.89.178.0/28\",\r\n \"13.91.61.249/32\",\r\n - \ \"13.91.91.243/32\",\r\n \"13.91.98.185/32\",\r\n \"13.93.32.114/32\",\r\n - \ \"13.93.113.192/32\",\r\n \"13.93.196.52/32\",\r\n \"13.93.216.68/32\",\r\n - \ \"13.93.233.42/32\",\r\n \"13.95.1.33/32\",\r\n \"13.95.29.177/32\",\r\n - \ \"13.95.30.46/32\",\r\n \"20.36.220.93/32\",\r\n \"20.36.222.59/32\",\r\n - \ \"20.36.222.60/32\",\r\n \"20.36.240.76/32\",\r\n \"20.36.244.208/32\",\r\n - \ \"20.36.245.0/32\",\r\n \"20.36.245.182/32\",\r\n \"20.36.245.235/32\",\r\n - \ \"20.36.246.188/32\",\r\n \"20.36.248.40/32\",\r\n \"20.40.106.50/31\",\r\n - \ \"20.40.107.84/32\",\r\n \"20.40.132.195/32\",\r\n \"20.40.134.79/32\",\r\n - \ \"20.40.134.94/32\",\r\n \"20.40.160.184/32\",\r\n \"20.40.161.119/32\",\r\n - \ \"20.40.161.131/32\",\r\n \"20.40.161.132/32\",\r\n \"20.40.161.135/32\",\r\n - \ \"20.40.161.140/30\",\r\n \"20.40.161.160/31\",\r\n \"20.40.162.86/32\",\r\n - \ \"20.40.162.200/32\",\r\n \"20.40.163.88/32\",\r\n \"20.40.163.96/31\",\r\n - \ \"20.40.163.130/32\",\r\n \"20.40.163.133/32\",\r\n \"20.40.163.178/31\",\r\n - \ \"20.42.29.162/32\",\r\n \"20.42.31.48/32\",\r\n \"20.42.31.251/32\",\r\n - \ \"20.44.8.208/28\",\r\n \"20.44.17.64/28\",\r\n \"20.44.72.173/32\",\r\n - \ \"20.44.72.217/32\",\r\n \"20.44.73.253/32\",\r\n \"20.45.3.127/32\",\r\n - \ \"20.184.57.4/32\",\r\n \"20.184.57.218/32\",\r\n \"20.184.58.46/32\",\r\n - \ \"20.184.58.110/32\",\r\n \"20.184.60.77/32\",\r\n \"20.184.61.67/32\",\r\n - \ \"20.184.61.253/32\",\r\n \"20.184.63.158/32\",\r\n \"20.184.63.216/32\",\r\n - \ \"20.184.63.232/32\",\r\n \"20.188.72.248/32\",\r\n \"23.97.54.160/32\",\r\n - \ \"23.97.55.165/32\",\r\n \"23.98.83.96/28\",\r\n \"23.100.67.153/32\",\r\n - \ \"40.65.169.46/32\",\r\n \"40.65.169.97/32\",\r\n \"40.65.169.196/32\",\r\n - \ \"40.65.169.236/32\",\r\n \"40.65.170.17/32\",\r\n \"40.65.170.26/32\",\r\n - \ \"40.65.170.80/30\",\r\n \"40.65.170.112/31\",\r\n \"40.65.170.123/32\",\r\n - \ \"40.65.170.125/32\",\r\n \"40.65.170.128/32\",\r\n \"40.65.170.133/32\",\r\n - \ \"40.65.170.137/32\",\r\n \"40.65.233.253/32\",\r\n \"40.65.235.54/32\",\r\n - \ \"40.66.56.158/32\",\r\n \"40.66.57.164/32\",\r\n \"40.66.57.203/32\",\r\n - \ \"40.66.59.41/32\",\r\n \"40.66.59.193/32\",\r\n \"40.66.59.195/32\",\r\n - \ \"40.66.59.196/32\",\r\n \"40.66.59.246/32\",\r\n \"40.66.60.101/32\",\r\n - \ \"40.66.60.118/32\",\r\n \"40.66.60.180/32\",\r\n \"40.66.60.185/32\",\r\n - \ \"40.66.60.200/32\",\r\n \"40.66.60.206/31\",\r\n \"40.66.60.208/31\",\r\n - \ \"40.66.60.210/32\",\r\n \"40.66.60.215/32\",\r\n \"40.66.60.216/31\",\r\n - \ \"40.66.60.219/32\",\r\n \"40.66.60.220/31\",\r\n \"40.66.60.222/32\",\r\n - \ \"40.66.60.224/31\",\r\n \"40.66.60.226/32\",\r\n \"40.66.60.232/32\",\r\n - \ \"40.66.61.61/32\",\r\n \"40.66.61.158/32\",\r\n \"40.66.61.193/32\",\r\n - \ \"40.66.61.226/32\",\r\n \"40.66.62.7/32\",\r\n \"40.66.62.9/32\",\r\n - \ \"40.66.62.78/32\",\r\n \"40.66.62.130/32\",\r\n \"40.66.62.154/32\",\r\n - \ \"40.66.62.225/32\",\r\n \"40.66.63.148/32\",\r\n \"40.66.63.255/32\",\r\n - \ \"40.67.152.91/32\",\r\n \"40.67.152.227/32\",\r\n \"40.67.154.160/32\",\r\n - \ \"40.67.155.146/32\",\r\n \"40.67.159.55/32\",\r\n \"40.67.216.253/32\",\r\n - \ \"40.67.219.133/32\",\r\n \"40.67.251.0/32\",\r\n \"40.67.254.233/32\",\r\n - \ \"40.68.245.184/32\",\r\n \"40.69.108.96/27\",\r\n \"40.70.0.255/32\",\r\n - \ \"40.70.29.49/32\",\r\n \"40.70.29.200/32\",\r\n \"40.70.148.112/28\",\r\n - \ \"40.70.184.90/32\",\r\n \"40.71.14.16/28\",\r\n \"40.74.1.235/32\",\r\n - \ \"40.74.6.204/32\",\r\n \"40.76.78.217/32\",\r\n \"40.78.23.204/32\",\r\n - \ \"40.78.56.129/32\",\r\n \"40.78.229.64/28\",\r\n \"40.78.236.160/28\",\r\n - \ \"40.78.245.0/28\",\r\n \"40.78.251.128/28\",\r\n \"40.79.132.96/28\",\r\n - \ \"40.79.139.16/28\",\r\n \"40.79.146.224/28\",\r\n \"40.79.156.112/28\",\r\n - \ \"40.79.180.64/27\",\r\n \"40.80.219.49/32\",\r\n \"40.80.220.215/32\",\r\n - \ \"40.80.220.246/32\",\r\n \"40.80.221.77/32\",\r\n \"40.80.222.91/32\",\r\n - \ \"40.80.222.197/32\",\r\n \"40.81.56.80/32\",\r\n \"40.81.57.138/32\",\r\n - \ \"40.81.57.141/32\",\r\n \"40.81.57.144/32\",\r\n \"40.81.57.157/32\",\r\n - \ \"40.81.57.164/32\",\r\n \"40.81.57.169/32\",\r\n \"40.81.58.180/32\",\r\n - \ \"40.81.58.184/32\",\r\n \"40.81.58.193/32\",\r\n \"40.81.59.4/32\",\r\n - \ \"40.81.59.90/32\",\r\n \"40.81.59.93/32\",\r\n \"40.81.62.162/32\",\r\n - \ \"40.81.62.179/32\",\r\n \"40.81.62.193/32\",\r\n \"40.81.62.199/32\",\r\n - \ \"40.81.62.206/32\",\r\n \"40.81.62.209/32\",\r\n \"40.81.62.212/32\",\r\n - \ \"40.81.62.220/30\",\r\n \"40.81.62.224/32\",\r\n \"40.81.62.255/32\",\r\n - \ \"40.81.63.1/32\",\r\n \"40.81.63.2/32\",\r\n \"40.81.63.4/31\",\r\n - \ \"40.81.63.7/32\",\r\n \"40.81.63.8/32\",\r\n \"40.81.63.235/32\",\r\n - \ \"40.81.63.245/32\",\r\n \"40.81.63.248/32\",\r\n \"40.81.120.13/32\",\r\n - \ \"40.81.120.24/31\",\r\n \"40.81.120.97/32\",\r\n \"40.81.120.187/32\",\r\n - \ \"40.81.120.191/32\",\r\n \"40.81.120.192/32\",\r\n \"40.81.121.66/32\",\r\n - \ \"40.81.121.76/32\",\r\n \"40.81.121.78/32\",\r\n \"40.81.121.107/32\",\r\n - \ \"40.81.121.108/32\",\r\n \"40.81.121.111/32\",\r\n \"40.81.121.127/32\",\r\n - \ \"40.81.121.135/32\",\r\n \"40.81.121.140/32\",\r\n \"40.81.121.175/32\",\r\n - \ \"40.81.122.4/32\",\r\n \"40.81.122.62/31\",\r\n \"40.81.122.76/32\",\r\n - \ \"40.81.122.203/32\",\r\n \"40.81.123.124/32\",\r\n \"40.81.123.157/32\",\r\n - \ \"40.81.124.185/32\",\r\n \"40.81.124.219/32\",\r\n \"40.81.127.25/32\",\r\n - \ \"40.81.127.139/32\",\r\n \"40.81.127.140/31\",\r\n \"40.81.127.229/32\",\r\n - \ \"40.81.127.230/32\",\r\n \"40.81.127.239/32\",\r\n \"40.81.152.126/32\",\r\n - \ \"40.81.152.171/32\",\r\n \"40.81.152.172/32\",\r\n \"40.81.156.153/32\",\r\n - \ \"40.81.156.154/31\",\r\n \"40.81.156.156/32\",\r\n \"40.81.159.35/32\",\r\n - \ \"40.81.159.77/32\",\r\n \"40.82.184.80/32\",\r\n \"40.82.185.36/32\",\r\n - \ \"40.82.185.117/32\",\r\n \"40.82.185.229/32\",\r\n \"40.82.186.166/32\",\r\n - \ \"40.82.186.168/31\",\r\n \"40.82.186.176/31\",\r\n \"40.82.186.180/32\",\r\n - \ \"40.82.186.182/32\",\r\n \"40.82.186.185/32\",\r\n \"40.82.186.214/32\",\r\n - \ \"40.82.186.231/32\",\r\n \"40.82.187.161/32\",\r\n \"40.82.187.162/31\",\r\n - \ \"40.82.187.164/32\",\r\n \"40.82.187.177/32\",\r\n \"40.82.187.178/31\",\r\n - \ \"40.82.187.199/32\",\r\n \"40.82.187.200/32\",\r\n \"40.82.187.202/32\",\r\n - \ \"40.82.187.204/30\",\r\n \"40.82.187.208/30\",\r\n \"40.82.187.212/31\",\r\n - \ \"40.82.187.218/32\",\r\n \"40.82.187.223/32\",\r\n \"40.82.190.163/32\",\r\n - \ \"40.82.191.58/32\",\r\n \"40.84.2.83/32\",\r\n \"40.84.4.93/32\",\r\n - \ \"40.84.4.119/32\",\r\n \"40.84.5.28/32\",\r\n \"40.84.49.16/32\",\r\n - \ \"40.89.136.227/32\",\r\n \"40.89.137.101/32\",\r\n \"40.89.142.184/32\",\r\n - \ \"40.89.143.43/32\",\r\n \"40.90.184.197/32\",\r\n \"40.90.185.64/32\",\r\n - \ \"40.90.191.153/32\",\r\n \"40.90.218.196/31\",\r\n \"40.90.218.198/32\",\r\n - \ \"40.90.218.203/32\",\r\n \"40.90.219.121/32\",\r\n \"40.90.219.184/32\",\r\n - \ \"40.90.220.37/32\",\r\n \"40.90.220.190/32\",\r\n \"40.90.220.196/32\",\r\n - \ \"40.90.222.64/32\",\r\n \"40.91.74.37/32\",\r\n \"40.91.78.105/32\",\r\n - \ \"40.91.114.40/29\",\r\n \"40.91.114.48/31\",\r\n \"40.91.122.25/32\",\r\n - \ \"40.91.122.38/32\",\r\n \"40.91.126.157/32\",\r\n \"40.91.127.44/32\",\r\n - \ \"40.91.198.19/32\",\r\n \"40.113.121.176/32\",\r\n \"40.114.112.147/32\",\r\n - \ \"40.114.217.8/32\",\r\n \"40.115.24.65/32\",\r\n \"40.115.25.50/32\",\r\n - \ \"40.115.71.111/32\",\r\n \"40.118.63.137/32\",\r\n \"40.118.97.232/32\",\r\n - \ \"40.118.211.172/32\",\r\n \"40.119.145.130/32\",\r\n \"40.119.147.102/32\",\r\n - \ \"40.119.154.72/32\",\r\n \"40.119.203.98/31\",\r\n \"40.119.203.158/31\",\r\n - \ \"40.119.203.208/31\",\r\n \"40.119.207.131/32\",\r\n \"40.119.207.144/32\",\r\n - \ \"40.119.207.164/32\",\r\n \"40.119.207.166/32\",\r\n \"40.119.207.174/32\",\r\n - \ \"40.119.207.182/32\",\r\n \"40.119.207.193/32\",\r\n \"40.119.207.200/32\",\r\n - \ \"40.119.215.167/32\",\r\n \"40.121.134.1/32\",\r\n \"40.124.53.69/32\",\r\n - \ \"51.11.26.92/32\",\r\n \"51.11.26.95/32\",\r\n \"51.104.9.16/28\",\r\n - \ \"51.105.37.244/32\",\r\n \"51.105.67.224/28\",\r\n \"51.105.75.176/28\",\r\n - \ \"51.105.124.64/32\",\r\n \"51.105.124.80/32\",\r\n \"51.105.161.5/32\",\r\n - \ \"51.105.163.8/32\",\r\n \"51.105.163.43/32\",\r\n \"51.105.164.8/32\",\r\n - \ \"51.105.164.234/32\",\r\n \"51.105.164.241/32\",\r\n \"51.105.165.31/32\",\r\n - \ \"51.105.165.37/32\",\r\n \"51.105.165.63/32\",\r\n \"51.105.165.116/32\",\r\n - \ \"51.105.166.102/31\",\r\n \"51.105.166.106/32\",\r\n \"51.105.179.157/32\",\r\n - \ \"51.137.136.13/32\",\r\n \"51.137.136.14/32\",\r\n \"51.137.136.34/32\",\r\n - \ \"51.137.137.69/32\",\r\n \"51.137.137.118/32\",\r\n \"51.137.137.121/32\",\r\n - \ \"51.137.137.200/32\",\r\n \"51.137.137.237/32\",\r\n \"51.140.1.10/32\",\r\n - \ \"51.140.8.108/32\",\r\n \"51.140.8.180/32\",\r\n \"51.140.35.95/32\",\r\n - \ \"51.140.52.106/32\",\r\n \"51.140.78.213/32\",\r\n \"51.140.105.124/32\",\r\n - \ \"51.140.125.227/32\",\r\n \"51.140.164.179/32\",\r\n \"51.140.191.146/32\",\r\n - \ \"51.140.212.128/27\",\r\n \"51.140.230.246/32\",\r\n \"51.140.231.138/32\",\r\n - \ \"51.141.2.189/32\",\r\n \"51.141.7.11/32\",\r\n \"51.143.58.207/32\",\r\n - \ \"51.143.111.58/32\",\r\n \"51.143.120.236/32\",\r\n \"51.143.120.242/32\",\r\n - \ \"51.143.122.59/32\",\r\n \"51.143.122.60/32\",\r\n \"51.144.56.60/32\",\r\n - \ \"51.145.108.227/32\",\r\n \"51.145.108.250/32\",\r\n \"51.145.181.195/32\",\r\n - \ \"51.145.181.214/32\",\r\n \"52.137.56.200/32\",\r\n \"52.137.89.147/32\",\r\n - \ \"52.138.227.160/28\",\r\n \"52.139.1.70/32\",\r\n \"52.139.1.156/32\",\r\n - \ \"52.139.1.158/31\",\r\n \"52.139.1.200/32\",\r\n \"52.139.1.218/32\",\r\n - \ \"52.139.2.0/32\",\r\n \"52.139.16.105/32\",\r\n \"52.139.18.234/32\",\r\n - \ \"52.139.18.236/32\",\r\n \"52.139.19.71/32\",\r\n \"52.139.19.187/32\",\r\n - \ \"52.139.19.215/32\",\r\n \"52.139.19.247/32\",\r\n \"52.139.20.31/32\",\r\n - \ \"52.139.20.118/32\",\r\n \"52.139.21.70/32\",\r\n \"52.139.245.1/32\",\r\n - \ \"52.139.245.21/32\",\r\n \"52.139.245.40/32\",\r\n \"52.139.245.48/32\",\r\n - \ \"52.139.251.219/32\",\r\n \"52.139.252.105/32\",\r\n \"52.142.112.145/32\",\r\n - \ \"52.142.112.146/32\",\r\n \"52.142.116.135/32\",\r\n \"52.142.116.174/32\",\r\n - \ \"52.142.116.250/32\",\r\n \"52.142.117.183/32\",\r\n \"52.142.118.130/32\",\r\n - \ \"52.142.121.6/32\",\r\n \"52.142.121.75/32\",\r\n \"52.142.124.23/32\",\r\n - \ \"52.142.127.127/32\",\r\n \"52.142.220.179/32\",\r\n \"52.142.232.120/32\",\r\n - \ \"52.143.73.88/32\",\r\n \"52.143.74.31/32\",\r\n \"52.148.115.188/32\",\r\n - \ \"52.148.115.194/32\",\r\n \"52.148.115.238/32\",\r\n \"52.148.116.37/32\",\r\n - \ \"52.148.161.45/32\",\r\n \"52.148.161.53/32\",\r\n \"52.151.237.243/32\",\r\n - \ \"52.151.238.5/32\",\r\n \"52.151.244.65/32\",\r\n \"52.151.247.27/32\",\r\n - \ \"52.153.240.107/32\",\r\n \"52.155.161.88/32\",\r\n \"52.155.161.91/32\",\r\n - \ \"52.155.164.131/32\",\r\n \"52.155.166.50/32\",\r\n \"52.155.167.231/32\",\r\n - \ \"52.155.168.45/32\",\r\n \"52.155.177.13/32\",\r\n \"52.155.178.247/32\",\r\n - \ \"52.155.179.84/32\",\r\n \"52.155.180.208/30\",\r\n \"52.155.181.180/30\",\r\n - \ \"52.155.182.48/31\",\r\n \"52.155.182.50/32\",\r\n \"52.155.182.138/32\",\r\n - \ \"52.155.182.141/32\",\r\n \"52.156.197.208/32\",\r\n \"52.156.197.254/32\",\r\n - \ \"52.156.198.196/32\",\r\n \"52.156.202.7/32\",\r\n \"52.156.203.22/32\",\r\n - \ \"52.156.203.198/31\",\r\n \"52.156.204.24/32\",\r\n \"52.156.204.51/32\",\r\n - \ \"52.156.204.99/32\",\r\n \"52.156.204.139/32\",\r\n \"52.156.205.137/32\",\r\n - \ \"52.156.205.182/32\",\r\n \"52.156.205.222/32\",\r\n \"52.156.205.226/32\",\r\n - \ \"52.156.206.43/32\",\r\n \"52.156.206.45/32\",\r\n \"52.156.206.46/31\",\r\n - \ \"52.157.19.228/32\",\r\n \"52.157.20.142/32\",\r\n \"52.157.218.219/32\",\r\n - \ \"52.157.218.232/32\",\r\n \"52.157.232.110/32\",\r\n \"52.157.232.147/32\",\r\n - \ \"52.157.233.49/32\",\r\n \"52.157.233.92/32\",\r\n \"52.157.233.133/32\",\r\n - \ \"52.157.233.205/32\",\r\n \"52.157.234.160/32\",\r\n \"52.157.234.222/32\",\r\n - \ \"52.157.235.27/32\",\r\n \"52.157.235.144/32\",\r\n \"52.157.236.195/32\",\r\n - \ \"52.157.237.107/32\",\r\n \"52.157.237.213/32\",\r\n \"52.157.237.255/32\",\r\n - \ \"52.157.238.58/32\",\r\n \"52.157.239.110/32\",\r\n \"52.157.239.132/32\",\r\n - \ \"52.158.28.235/32\",\r\n \"52.167.107.96/28\",\r\n \"52.169.192.237/32\",\r\n - \ \"52.174.56.180/32\",\r\n \"52.177.85.43/32\",\r\n \"52.178.44.248/32\",\r\n - \ \"52.178.89.44/32\",\r\n \"52.179.155.177/32\",\r\n \"52.179.194.73/32\",\r\n - \ \"52.179.198.41/32\",\r\n \"52.182.139.208/28\",\r\n \"52.183.24.254/32\",\r\n - \ \"52.183.30.204/32\",\r\n \"52.183.75.62/32\",\r\n \"52.184.165.82/32\",\r\n - \ \"52.188.217.236/32\",\r\n \"52.189.208.36/32\",\r\n \"52.189.213.36/32\",\r\n - \ \"52.189.213.124/32\",\r\n \"52.189.218.253/32\",\r\n \"52.190.26.220/32\",\r\n - \ \"52.190.31.62/32\",\r\n \"52.191.129.65/32\",\r\n \"52.191.237.188/32\",\r\n - \ \"52.191.238.65/32\",\r\n \"52.224.188.157/32\",\r\n \"52.224.188.168/32\",\r\n - \ \"52.224.190.225/32\",\r\n \"52.224.191.62/32\",\r\n \"52.224.201.216/32\",\r\n - \ \"52.224.201.223/32\",\r\n \"52.224.202.86/32\",\r\n \"52.224.202.91/32\",\r\n - \ \"52.225.225.218/32\",\r\n \"52.225.231.232/32\",\r\n \"52.232.224.227/32\",\r\n - \ \"52.232.225.84/32\",\r\n \"52.232.228.217/32\",\r\n \"52.232.245.96/32\",\r\n - \ \"52.236.187.80/28\",\r\n \"52.249.25.160/32\",\r\n \"52.249.25.165/32\",\r\n - \ \"65.52.138.123/32\",\r\n \"65.52.229.200/32\",\r\n \"104.40.28.202/32\",\r\n - \ \"104.40.129.120/32\",\r\n \"104.42.15.41/32\",\r\n \"104.42.34.58/32\",\r\n - \ \"104.42.38.254/32\",\r\n \"104.42.54.24/32\",\r\n \"104.42.75.120/32\",\r\n - \ \"104.42.211.215/32\",\r\n \"104.45.7.95/32\",\r\n \"104.45.65.169/32\",\r\n - \ \"104.45.168.103/32\",\r\n \"104.45.168.104/32\",\r\n \"104.45.168.106/32\",\r\n - \ \"104.45.168.108/32\",\r\n \"104.45.168.111/32\",\r\n \"104.45.168.114/32\",\r\n - \ \"104.45.170.70/32\",\r\n \"104.45.170.127/32\",\r\n \"104.45.170.161/32\",\r\n - \ \"104.45.170.173/32\",\r\n \"104.45.170.174/31\",\r\n \"104.45.170.176/32\",\r\n - \ \"104.45.170.178/32\",\r\n \"104.45.170.180/32\",\r\n \"104.45.170.182/31\",\r\n - \ \"104.45.170.184/31\",\r\n \"104.45.170.186/32\",\r\n \"104.45.170.188/32\",\r\n - \ \"104.45.170.191/32\",\r\n \"104.45.170.194/32\",\r\n \"104.45.170.196/32\",\r\n - \ \"104.46.116.211/32\",\r\n \"104.46.121.72/32\",\r\n \"104.46.122.189/32\",\r\n - \ \"104.208.216.221/32\",\r\n \"104.209.35.177/32\",\r\n - \ \"104.209.168.251/32\",\r\n \"104.210.0.32/32\",\r\n \"104.211.9.226/32\",\r\n - \ \"104.214.225.33/32\",\r\n \"137.116.52.31/32\",\r\n \"138.91.147.71/32\",\r\n - \ \"168.63.38.153/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.AustraliaEast\",\r\n \"id\": - \"MicrosoftCloudAppSecurity.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.74.160/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.AustraliaSoutheast\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.53.96/27\",\r\n \"20.40.160.184/32\",\r\n - \ \"20.40.161.119/32\",\r\n \"20.40.161.131/32\",\r\n \"20.40.161.132/32\",\r\n - \ \"20.40.161.135/32\",\r\n \"20.40.161.140/30\",\r\n \"20.40.161.160/31\",\r\n - \ \"20.40.162.86/32\",\r\n \"20.40.162.200/32\",\r\n \"20.40.163.88/32\",\r\n - \ \"20.40.163.96/31\",\r\n \"20.40.163.130/32\",\r\n \"20.40.163.133/32\",\r\n - \ \"20.40.163.178/31\",\r\n \"40.81.56.80/32\",\r\n \"40.81.57.138/32\",\r\n - \ \"40.81.57.141/32\",\r\n \"40.81.57.144/32\",\r\n \"40.81.57.157/32\",\r\n - \ \"40.81.57.164/32\",\r\n \"40.81.57.169/32\",\r\n \"40.81.58.180/32\",\r\n - \ \"40.81.58.184/32\",\r\n \"40.81.58.193/32\",\r\n \"40.81.59.4/32\",\r\n - \ \"40.81.59.90/32\",\r\n \"40.81.59.93/32\",\r\n \"40.81.62.162/32\",\r\n - \ \"40.81.62.179/32\",\r\n \"40.81.62.193/32\",\r\n \"40.81.62.199/32\",\r\n - \ \"40.81.62.206/32\",\r\n \"40.81.62.209/32\",\r\n \"40.81.62.212/32\",\r\n - \ \"40.81.62.220/30\",\r\n \"40.81.62.224/32\",\r\n \"40.81.62.255/32\",\r\n - \ \"40.81.63.1/32\",\r\n \"40.81.63.2/32\",\r\n \"40.81.63.4/31\",\r\n - \ \"40.81.63.7/32\",\r\n \"40.81.63.8/32\",\r\n \"40.81.63.235/32\",\r\n - \ \"40.81.63.245/32\",\r\n \"40.81.63.248/32\",\r\n \"40.115.71.111/32\",\r\n - \ \"52.189.208.36/32\",\r\n \"52.189.213.36/32\",\r\n \"52.189.213.124/32\",\r\n - \ \"52.189.218.253/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.CanadaCentral\",\r\n \"id\": - \"MicrosoftCloudAppSecurity.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.175.0/27\",\r\n \"13.88.224.38/32\",\r\n - \ \"13.88.224.211/32\",\r\n \"13.88.224.222/32\",\r\n \"13.88.226.74/32\",\r\n - \ \"13.88.227.7/32\",\r\n \"40.82.184.80/32\",\r\n \"40.82.185.36/32\",\r\n - \ \"40.82.185.117/32\",\r\n \"40.82.185.229/32\",\r\n \"40.82.186.166/32\",\r\n - \ \"40.82.186.168/31\",\r\n \"40.82.186.176/31\",\r\n \"40.82.186.180/32\",\r\n - \ \"40.82.186.182/32\",\r\n \"40.82.186.185/32\",\r\n \"40.82.186.214/32\",\r\n - \ \"40.82.186.231/32\",\r\n \"40.82.187.161/32\",\r\n \"40.82.187.162/31\",\r\n - \ \"40.82.187.164/32\",\r\n \"40.82.187.177/32\",\r\n \"40.82.187.178/31\",\r\n - \ \"40.82.187.199/32\",\r\n \"40.82.187.200/32\",\r\n \"40.82.187.202/32\",\r\n - \ \"40.82.187.204/30\",\r\n \"40.82.187.208/30\",\r\n \"40.82.187.212/31\",\r\n - \ \"40.82.187.218/32\",\r\n \"40.82.187.223/32\",\r\n \"40.82.190.163/32\",\r\n - \ \"40.82.191.58/32\",\r\n \"52.139.1.70/32\",\r\n \"52.139.1.156/32\",\r\n - \ \"52.139.1.158/31\",\r\n \"52.139.1.200/32\",\r\n \"52.139.1.218/32\",\r\n - \ \"52.139.2.0/32\",\r\n \"52.139.16.105/32\",\r\n \"52.139.18.234/32\",\r\n - \ \"52.139.18.236/32\",\r\n \"52.139.19.71/32\",\r\n \"52.139.19.187/32\",\r\n - \ \"52.139.19.215/32\",\r\n \"52.139.19.247/32\",\r\n \"52.139.20.31/32\",\r\n - \ \"52.139.20.118/32\",\r\n \"52.139.21.70/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.CanadaEast\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.108.96/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.CentralUS\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.178.0/28\",\r\n \"20.44.8.208/28\",\r\n - \ \"52.182.139.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.EastAsia\",\r\n \"id\": \"MicrosoftCloudAppSecurity.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.39.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.EastUS\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.EastUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.29.162/32\",\r\n \"20.42.31.48/32\",\r\n - \ \"20.42.31.251/32\",\r\n \"40.71.14.16/28\",\r\n \"40.76.78.217/32\",\r\n - \ \"40.78.229.64/28\",\r\n \"40.79.156.112/28\",\r\n \"40.114.112.147/32\",\r\n - \ \"40.121.134.1/32\",\r\n \"52.151.237.243/32\",\r\n \"52.151.238.5/32\",\r\n - \ \"52.151.244.65/32\",\r\n \"52.151.247.27/32\",\r\n \"52.188.217.236/32\",\r\n - \ \"52.190.26.220/32\",\r\n \"52.190.31.62/32\",\r\n \"52.191.237.188/32\",\r\n - \ \"52.191.238.65/32\",\r\n \"52.224.188.157/32\",\r\n \"52.224.188.168/32\",\r\n - \ \"52.224.190.225/32\",\r\n \"52.224.191.62/32\",\r\n \"52.224.201.216/32\",\r\n - \ \"52.224.201.223/32\",\r\n \"52.224.202.86/32\",\r\n \"52.224.202.91/32\",\r\n - \ \"104.45.168.103/32\",\r\n \"104.45.168.104/32\",\r\n \"104.45.168.106/32\",\r\n - \ \"104.45.168.108/32\",\r\n \"104.45.168.111/32\",\r\n \"104.45.168.114/32\",\r\n - \ \"104.45.170.70/32\",\r\n \"104.45.170.127/32\",\r\n \"104.45.170.161/32\",\r\n - \ \"104.45.170.173/32\",\r\n \"104.45.170.174/31\",\r\n \"104.45.170.176/32\",\r\n - \ \"104.45.170.178/32\",\r\n \"104.45.170.180/32\",\r\n \"104.45.170.182/31\",\r\n - \ \"104.45.170.184/31\",\r\n \"104.45.170.186/32\",\r\n \"104.45.170.188/32\",\r\n - \ \"104.45.170.191/32\",\r\n \"104.45.170.194/32\",\r\n \"104.45.170.196/32\",\r\n - \ \"104.211.9.226/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.EastUS2\",\r\n \"id\": \"MicrosoftCloudAppSecurity.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.80.28/32\",\r\n \"20.36.220.93/32\",\r\n - \ \"20.36.222.59/32\",\r\n \"20.36.222.60/32\",\r\n \"20.36.240.76/32\",\r\n - \ \"20.36.244.208/32\",\r\n \"20.36.245.0/32\",\r\n \"20.36.245.182/32\",\r\n - \ \"20.36.245.235/32\",\r\n \"20.36.246.188/32\",\r\n \"20.36.248.40/32\",\r\n - \ \"20.44.17.64/28\",\r\n \"20.44.72.173/32\",\r\n \"20.44.72.217/32\",\r\n - \ \"20.44.73.253/32\",\r\n \"23.100.67.153/32\",\r\n \"40.65.233.253/32\",\r\n - \ \"40.65.235.54/32\",\r\n \"40.67.152.91/32\",\r\n \"40.67.152.227/32\",\r\n - \ \"40.67.154.160/32\",\r\n \"40.67.155.146/32\",\r\n \"40.67.159.55/32\",\r\n - \ \"40.70.0.255/32\",\r\n \"40.70.29.49/32\",\r\n \"40.70.29.200/32\",\r\n - \ \"40.70.148.112/28\",\r\n \"40.70.184.90/32\",\r\n \"40.84.2.83/32\",\r\n - \ \"40.84.4.93/32\",\r\n \"40.84.4.119/32\",\r\n \"40.84.5.28/32\",\r\n - \ \"40.84.49.16/32\",\r\n \"52.167.107.96/28\",\r\n \"52.177.85.43/32\",\r\n - \ \"52.179.155.177/32\",\r\n \"52.179.194.73/32\",\r\n \"52.179.198.41/32\",\r\n - \ \"52.184.165.82/32\",\r\n \"52.225.225.218/32\",\r\n \"52.225.231.232/32\",\r\n - \ \"52.232.224.227/32\",\r\n \"52.232.225.84/32\",\r\n \"52.232.228.217/32\",\r\n - \ \"52.232.245.96/32\",\r\n \"104.46.116.211/32\",\r\n \"104.46.121.72/32\",\r\n - \ \"104.46.122.189/32\",\r\n \"104.208.216.221/32\",\r\n - \ \"104.209.168.251/32\",\r\n \"104.210.0.32/32\",\r\n \"137.116.52.31/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.FranceCentral\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"20.40.132.195/32\",\r\n \"20.40.134.79/32\",\r\n - \ \"20.40.134.94/32\",\r\n \"40.66.56.158/32\",\r\n \"40.66.57.164/32\",\r\n - \ \"40.66.57.203/32\",\r\n \"40.66.59.41/32\",\r\n \"40.66.59.193/32\",\r\n - \ \"40.66.59.195/32\",\r\n \"40.66.59.196/32\",\r\n \"40.66.59.246/32\",\r\n - \ \"40.66.60.101/32\",\r\n \"40.66.60.118/32\",\r\n \"40.66.60.180/32\",\r\n - \ \"40.66.60.185/32\",\r\n \"40.66.60.200/32\",\r\n \"40.66.60.206/31\",\r\n - \ \"40.66.60.208/31\",\r\n \"40.66.60.210/32\",\r\n \"40.66.60.215/32\",\r\n - \ \"40.66.60.216/31\",\r\n \"40.66.60.219/32\",\r\n \"40.66.60.220/31\",\r\n - \ \"40.66.60.222/32\",\r\n \"40.66.60.224/31\",\r\n \"40.66.60.226/32\",\r\n - \ \"40.66.60.232/32\",\r\n \"40.66.61.61/32\",\r\n \"40.66.61.158/32\",\r\n - \ \"40.66.61.193/32\",\r\n \"40.66.61.226/32\",\r\n \"40.66.62.7/32\",\r\n - \ \"40.66.62.9/32\",\r\n \"40.66.62.78/32\",\r\n \"40.66.62.130/32\",\r\n - \ \"40.66.62.154/32\",\r\n \"40.66.62.225/32\",\r\n \"40.66.63.148/32\",\r\n - \ \"40.66.63.255/32\",\r\n \"40.79.132.96/28\",\r\n \"40.79.139.16/28\",\r\n - \ \"40.79.146.224/28\",\r\n \"40.89.136.227/32\",\r\n \"40.89.137.101/32\",\r\n - \ \"40.89.142.184/32\",\r\n \"40.89.143.43/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.FranceSouth\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.180.64/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.NorthEurope\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.190.115/32\",\r\n \"13.69.230.48/28\",\r\n - \ \"13.74.108.176/28\",\r\n \"13.74.168.152/32\",\r\n \"40.67.251.0/32\",\r\n - \ \"40.67.254.233/32\",\r\n \"52.138.227.160/28\",\r\n \"52.142.112.145/32\",\r\n - \ \"52.142.112.146/32\",\r\n \"52.142.116.135/32\",\r\n \"52.142.116.174/32\",\r\n - \ \"52.142.116.250/32\",\r\n \"52.142.117.183/32\",\r\n \"52.142.118.130/32\",\r\n - \ \"52.142.121.6/32\",\r\n \"52.142.121.75/32\",\r\n \"52.142.124.23/32\",\r\n - \ \"52.142.127.127/32\",\r\n \"52.155.161.88/32\",\r\n \"52.155.161.91/32\",\r\n - \ \"52.155.164.131/32\",\r\n \"52.155.166.50/32\",\r\n \"52.155.167.231/32\",\r\n - \ \"52.155.168.45/32\",\r\n \"52.155.177.13/32\",\r\n \"52.155.178.247/32\",\r\n - \ \"52.155.179.84/32\",\r\n \"52.155.180.208/30\",\r\n \"52.155.181.180/30\",\r\n - \ \"52.155.182.48/31\",\r\n \"52.155.182.50/32\",\r\n \"52.155.182.138/32\",\r\n - \ \"52.155.182.141/32\",\r\n \"52.156.197.208/32\",\r\n \"52.156.197.254/32\",\r\n - \ \"52.156.198.196/32\",\r\n \"52.156.202.7/32\",\r\n \"52.156.203.22/32\",\r\n - \ \"52.156.203.198/31\",\r\n \"52.156.204.24/32\",\r\n \"52.156.204.51/32\",\r\n - \ \"52.156.204.99/32\",\r\n \"52.156.204.139/32\",\r\n \"52.156.205.137/32\",\r\n - \ \"52.156.205.182/32\",\r\n \"52.156.205.222/32\",\r\n \"52.156.205.226/32\",\r\n - \ \"52.156.206.43/32\",\r\n \"52.156.206.45/32\",\r\n \"52.156.206.46/31\",\r\n - \ \"52.158.28.235/32\",\r\n \"52.169.192.237/32\",\r\n \"65.52.229.200/32\",\r\n - \ \"168.63.38.153/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.SouthCentralUS\",\r\n \"id\": - \"MicrosoftCloudAppSecurity.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.242.224/27\",\r\n \"20.45.3.127/32\",\r\n - \ \"20.188.72.248/32\",\r\n \"40.80.219.49/32\",\r\n \"40.80.220.215/32\",\r\n - \ \"40.80.220.246/32\",\r\n \"40.80.221.77/32\",\r\n \"40.80.222.91/32\",\r\n - \ \"40.80.222.197/32\",\r\n \"40.124.53.69/32\",\r\n \"52.153.240.107/32\",\r\n - \ \"52.249.25.160/32\",\r\n \"52.249.25.165/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.SoutheastAsia\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.10.192/28\",\r\n \"13.67.48.221/32\",\r\n - \ \"13.76.43.73/32\",\r\n \"13.76.129.255/32\",\r\n \"20.184.57.4/32\",\r\n - \ \"20.184.57.218/32\",\r\n \"20.184.58.46/32\",\r\n \"20.184.58.110/32\",\r\n - \ \"20.184.60.77/32\",\r\n \"20.184.61.67/32\",\r\n \"20.184.61.253/32\",\r\n - \ \"20.184.63.158/32\",\r\n \"20.184.63.216/32\",\r\n \"20.184.63.232/32\",\r\n - \ \"23.97.54.160/32\",\r\n \"23.97.55.165/32\",\r\n \"23.98.83.96/28\",\r\n - \ \"40.65.169.46/32\",\r\n \"40.65.169.97/32\",\r\n \"40.65.169.196/32\",\r\n - \ \"40.65.169.236/32\",\r\n \"40.65.170.17/32\",\r\n \"40.65.170.26/32\",\r\n - \ \"40.65.170.80/30\",\r\n \"40.65.170.112/31\",\r\n \"40.65.170.123/32\",\r\n - \ \"40.65.170.125/32\",\r\n \"40.65.170.128/32\",\r\n \"40.65.170.133/32\",\r\n - \ \"40.65.170.137/32\",\r\n \"40.78.236.160/28\",\r\n \"40.90.184.197/32\",\r\n - \ \"40.90.185.64/32\",\r\n \"40.90.191.153/32\",\r\n \"40.119.203.98/31\",\r\n - \ \"40.119.203.158/31\",\r\n \"40.119.203.208/31\",\r\n \"40.119.207.131/32\",\r\n - \ \"40.119.207.144/32\",\r\n \"40.119.207.164/32\",\r\n \"40.119.207.166/32\",\r\n - \ \"40.119.207.174/32\",\r\n \"40.119.207.182/32\",\r\n \"40.119.207.193/32\",\r\n - \ \"40.119.207.200/32\",\r\n \"40.119.215.167/32\",\r\n \"52.139.245.1/32\",\r\n - \ \"52.139.245.21/32\",\r\n \"52.139.245.40/32\",\r\n \"52.139.245.48/32\",\r\n - \ \"52.139.251.219/32\",\r\n \"52.139.252.105/32\",\r\n \"52.148.115.188/32\",\r\n - \ \"52.148.115.194/32\",\r\n \"52.148.115.238/32\",\r\n \"52.148.116.37/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.UKSouth\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"40.81.152.126/32\",\r\n \"40.81.152.171/32\",\r\n - \ \"40.81.152.172/32\",\r\n \"40.81.156.153/32\",\r\n \"40.81.156.154/31\",\r\n - \ \"40.81.156.156/32\",\r\n \"40.81.159.35/32\",\r\n \"40.81.159.77/32\",\r\n - \ \"51.11.26.92/32\",\r\n \"51.11.26.95/32\",\r\n \"51.104.9.16/28\",\r\n - \ \"51.105.37.244/32\",\r\n \"51.105.67.224/28\",\r\n \"51.105.75.176/28\",\r\n - \ \"51.140.1.10/32\",\r\n \"51.140.8.108/32\",\r\n \"51.140.8.180/32\",\r\n - \ \"51.140.35.95/32\",\r\n \"51.140.52.106/32\",\r\n \"51.140.78.213/32\",\r\n - \ \"51.140.105.124/32\",\r\n \"51.140.125.227/32\",\r\n \"51.140.164.179/32\",\r\n - \ \"51.140.191.146/32\",\r\n \"51.145.108.227/32\",\r\n \"51.145.108.250/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.UKWest\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.UKWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"20.40.106.50/31\",\r\n \"20.40.107.84/32\",\r\n - \ \"40.81.120.13/32\",\r\n \"40.81.120.24/31\",\r\n \"40.81.120.97/32\",\r\n - \ \"40.81.120.187/32\",\r\n \"40.81.120.191/32\",\r\n \"40.81.120.192/32\",\r\n - \ \"40.81.121.66/32\",\r\n \"40.81.121.76/32\",\r\n \"40.81.121.78/32\",\r\n - \ \"40.81.121.107/32\",\r\n \"40.81.121.108/32\",\r\n \"40.81.121.111/32\",\r\n - \ \"40.81.121.127/32\",\r\n \"40.81.121.135/32\",\r\n \"40.81.121.140/32\",\r\n - \ \"40.81.121.175/32\",\r\n \"40.81.122.4/32\",\r\n \"40.81.122.62/31\",\r\n - \ \"40.81.122.76/32\",\r\n \"40.81.122.203/32\",\r\n \"40.81.123.124/32\",\r\n - \ \"40.81.123.157/32\",\r\n \"40.81.124.185/32\",\r\n \"40.81.124.219/32\",\r\n - \ \"40.81.127.25/32\",\r\n \"40.81.127.139/32\",\r\n \"40.81.127.140/31\",\r\n - \ \"40.81.127.229/32\",\r\n \"40.81.127.230/32\",\r\n \"40.81.127.239/32\",\r\n - \ \"51.137.136.13/32\",\r\n \"51.137.136.14/32\",\r\n \"51.137.136.34/32\",\r\n - \ \"51.137.137.69/32\",\r\n \"51.137.137.118/32\",\r\n \"51.137.137.121/32\",\r\n - \ \"51.137.137.200/32\",\r\n \"51.137.137.237/32\",\r\n \"51.140.212.128/27\",\r\n - \ \"51.140.230.246/32\",\r\n \"51.140.231.138/32\",\r\n \"51.141.2.189/32\",\r\n - \ \"51.141.7.11/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftCloudAppSecurity.WestCentralUS\",\r\n \"id\": - \"MicrosoftCloudAppSecurity.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.196.192/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestEurope\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.67.96/28\",\r\n \"13.69.107.96/28\",\r\n - \ \"13.80.7.94/32\",\r\n \"13.80.22.71/32\",\r\n \"13.80.125.22/32\",\r\n - \ \"13.81.123.49/32\",\r\n \"13.81.204.189/32\",\r\n \"13.81.212.71/32\",\r\n - \ \"13.93.32.114/32\",\r\n \"13.93.113.192/32\",\r\n \"13.95.1.33/32\",\r\n - \ \"13.95.29.177/32\",\r\n \"13.95.30.46/32\",\r\n \"40.67.216.253/32\",\r\n - \ \"40.67.219.133/32\",\r\n \"40.68.245.184/32\",\r\n \"40.74.1.235/32\",\r\n - \ \"40.74.6.204/32\",\r\n \"40.91.198.19/32\",\r\n \"40.113.121.176/32\",\r\n - \ \"40.114.217.8/32\",\r\n \"40.115.24.65/32\",\r\n \"40.115.25.50/32\",\r\n - \ \"40.118.63.137/32\",\r\n \"40.118.97.232/32\",\r\n \"40.119.145.130/32\",\r\n - \ \"40.119.147.102/32\",\r\n \"40.119.154.72/32\",\r\n \"51.105.124.64/32\",\r\n - \ \"51.105.124.80/32\",\r\n \"51.105.161.5/32\",\r\n \"51.105.163.8/32\",\r\n - \ \"51.105.163.43/32\",\r\n \"51.105.164.8/32\",\r\n \"51.105.164.234/32\",\r\n - \ \"51.105.164.241/32\",\r\n \"51.105.165.31/32\",\r\n \"51.105.165.37/32\",\r\n - \ \"51.105.165.63/32\",\r\n \"51.105.165.116/32\",\r\n \"51.105.166.102/31\",\r\n - \ \"51.105.166.106/32\",\r\n \"51.105.179.157/32\",\r\n \"51.144.56.60/32\",\r\n - \ \"51.145.181.195/32\",\r\n \"51.145.181.214/32\",\r\n \"52.137.56.200/32\",\r\n - \ \"52.142.220.179/32\",\r\n \"52.142.232.120/32\",\r\n \"52.157.218.219/32\",\r\n - \ \"52.157.218.232/32\",\r\n \"52.157.232.110/32\",\r\n \"52.157.232.147/32\",\r\n - \ \"52.157.233.49/32\",\r\n \"52.157.233.92/32\",\r\n \"52.157.233.133/32\",\r\n - \ \"52.157.233.205/32\",\r\n \"52.157.234.160/32\",\r\n \"52.157.234.222/32\",\r\n - \ \"52.157.235.27/32\",\r\n \"52.157.235.144/32\",\r\n \"52.157.236.195/32\",\r\n - \ \"52.157.237.107/32\",\r\n \"52.157.237.213/32\",\r\n \"52.157.237.255/32\",\r\n - \ \"52.157.238.58/32\",\r\n \"52.157.239.110/32\",\r\n \"52.157.239.132/32\",\r\n - \ \"52.174.56.180/32\",\r\n \"52.178.44.248/32\",\r\n \"52.178.89.44/32\",\r\n - \ \"52.236.187.80/28\",\r\n \"65.52.138.123/32\",\r\n \"104.40.129.120/32\",\r\n - \ \"104.45.7.95/32\",\r\n \"104.45.65.169/32\",\r\n \"104.214.225.33/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestUS\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.WestUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.64.26.88/32\",\r\n \"13.64.28.87/32\",\r\n - \ \"13.64.29.32/32\",\r\n \"13.64.29.161/32\",\r\n \"13.64.30.76/32\",\r\n - \ \"13.64.30.117/32\",\r\n \"13.64.30.118/32\",\r\n \"13.64.31.116/32\",\r\n - \ \"13.64.196.27/32\",\r\n \"13.64.198.19/32\",\r\n \"13.64.198.97/32\",\r\n - \ \"13.64.199.41/32\",\r\n \"13.64.252.115/32\",\r\n \"13.86.176.189/32\",\r\n - \ \"13.86.176.211/32\",\r\n \"13.86.219.224/27\",\r\n \"13.86.235.202/32\",\r\n - \ \"13.86.239.236/32\",\r\n \"13.91.61.249/32\",\r\n \"13.91.91.243/32\",\r\n - \ \"13.91.98.185/32\",\r\n \"13.93.196.52/32\",\r\n \"13.93.216.68/32\",\r\n - \ \"13.93.233.42/32\",\r\n \"40.78.23.204/32\",\r\n \"40.78.56.129/32\",\r\n - \ \"40.118.211.172/32\",\r\n \"52.157.19.228/32\",\r\n \"52.157.20.142/32\",\r\n - \ \"104.40.28.202/32\",\r\n \"104.42.15.41/32\",\r\n \"104.42.34.58/32\",\r\n - \ \"104.42.38.254/32\",\r\n \"104.42.54.24/32\",\r\n \"104.42.75.120/32\",\r\n - \ \"104.42.211.215/32\",\r\n \"104.209.35.177/32\",\r\n \"138.91.147.71/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestUS2\",\r\n - \ \"id\": \"MicrosoftCloudAppSecurity.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.134.18/32\",\r\n \"13.66.142.80/28\",\r\n - \ \"13.66.158.8/32\",\r\n \"13.66.168.209/32\",\r\n \"13.66.173.192/32\",\r\n - \ \"13.66.210.205/32\",\r\n \"13.77.136.80/32\",\r\n \"13.77.148.229/32\",\r\n - \ \"13.77.160.162/32\",\r\n \"13.77.163.148/32\",\r\n \"13.77.165.61/32\",\r\n - \ \"40.78.245.0/28\",\r\n \"40.78.251.128/28\",\r\n \"40.90.218.196/31\",\r\n - \ \"40.90.218.198/32\",\r\n \"40.90.218.203/32\",\r\n \"40.90.219.121/32\",\r\n - \ \"40.90.219.184/32\",\r\n \"40.90.220.37/32\",\r\n \"40.90.220.190/32\",\r\n - \ \"40.90.220.196/32\",\r\n \"40.90.222.64/32\",\r\n \"40.91.74.37/32\",\r\n - \ \"40.91.78.105/32\",\r\n \"40.91.114.40/29\",\r\n \"40.91.114.48/31\",\r\n - \ \"40.91.122.25/32\",\r\n \"40.91.122.38/32\",\r\n \"40.91.126.157/32\",\r\n - \ \"40.91.127.44/32\",\r\n \"51.143.58.207/32\",\r\n \"51.143.111.58/32\",\r\n - \ \"51.143.120.236/32\",\r\n \"51.143.120.242/32\",\r\n \"51.143.122.59/32\",\r\n - \ \"51.143.122.60/32\",\r\n \"52.137.89.147/32\",\r\n \"52.143.73.88/32\",\r\n - \ \"52.143.74.31/32\",\r\n \"52.148.161.45/32\",\r\n \"52.148.161.53/32\",\r\n - \ \"52.183.24.254/32\",\r\n \"52.183.30.204/32\",\r\n \"52.183.75.62/32\",\r\n - \ \"52.191.129.65/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry\",\r\n \"id\": \"MicrosoftContainerRegistry\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.64/29\",\r\n \"13.67.8.112/29\",\r\n \"13.69.64.80/29\",\r\n - \ \"13.69.106.72/29\",\r\n \"13.69.227.80/29\",\r\n \"13.70.72.128/29\",\r\n - \ \"13.71.170.48/29\",\r\n \"13.71.194.120/29\",\r\n \"13.74.107.72/29\",\r\n - \ \"13.75.34.152/29\",\r\n \"13.77.50.72/29\",\r\n \"13.78.106.192/29\",\r\n - \ \"13.87.56.88/29\",\r\n \"13.87.122.88/29\",\r\n \"13.89.170.208/29\",\r\n - \ \"20.37.74.64/29\",\r\n \"20.38.146.136/29\",\r\n \"20.44.2.16/29\",\r\n - \ \"20.44.26.136/29\",\r\n \"20.45.122.136/29\",\r\n \"20.49.82.8/29\",\r\n - \ \"20.49.90.8/29\",\r\n \"20.150.170.16/29\",\r\n \"20.150.178.136/29\",\r\n - \ \"20.150.186.136/29\",\r\n \"20.192.98.136/29\",\r\n \"20.192.234.16/29\",\r\n - \ \"20.193.202.8/29\",\r\n \"20.194.66.8/29\",\r\n \"23.98.82.104/29\",\r\n - \ \"40.67.58.16/29\",\r\n \"40.69.106.72/29\",\r\n \"40.70.146.80/29\",\r\n - \ \"40.71.10.208/29\",\r\n \"40.74.100.56/29\",\r\n \"40.74.146.40/29\",\r\n - \ \"40.75.34.24/29\",\r\n \"40.78.194.72/29\",\r\n \"40.78.202.64/29\",\r\n - \ \"40.78.226.200/29\",\r\n \"40.78.234.40/29\",\r\n \"40.78.242.152/29\",\r\n - \ \"40.78.250.88/29\",\r\n \"40.79.130.48/29\",\r\n \"40.79.138.24/29\",\r\n - \ \"40.79.146.24/29\",\r\n \"40.79.154.96/29\",\r\n \"40.79.162.24/29\",\r\n - \ \"40.79.170.8/29\",\r\n \"40.79.178.72/29\",\r\n \"40.79.186.0/29\",\r\n - \ \"40.79.194.88/29\",\r\n \"40.80.50.136/29\",\r\n \"40.112.242.152/29\",\r\n - \ \"40.120.74.8/29\",\r\n \"51.12.98.16/29\",\r\n \"51.12.202.16/29\",\r\n - \ \"51.12.226.136/29\",\r\n \"51.12.234.136/29\",\r\n \"51.105.66.136/29\",\r\n - \ \"51.105.74.136/29\",\r\n \"51.107.58.16/29\",\r\n \"51.107.154.16/29\",\r\n - \ \"51.116.58.16/29\",\r\n \"51.116.154.80/29\",\r\n \"51.116.242.136/29\",\r\n - \ \"51.116.250.136/29\",\r\n \"51.120.98.24/29\",\r\n \"51.120.106.136/29\",\r\n - \ \"51.120.210.136/29\",\r\n \"51.120.218.16/29\",\r\n \"51.140.146.192/29\",\r\n - \ \"51.140.210.88/29\",\r\n \"52.138.90.24/29\",\r\n \"52.138.226.72/29\",\r\n - \ \"52.162.106.152/29\",\r\n \"52.167.106.72/29\",\r\n \"52.182.138.200/29\",\r\n - \ \"52.231.18.48/29\",\r\n \"52.231.146.88/29\",\r\n \"52.236.186.72/29\",\r\n - \ \"52.246.154.136/29\",\r\n \"65.52.250.8/29\",\r\n \"102.133.26.16/29\",\r\n - \ \"102.133.122.136/29\",\r\n \"102.133.154.16/29\",\r\n - \ \"102.133.250.136/29\",\r\n \"104.208.16.72/29\",\r\n \"104.208.144.72/29\",\r\n - \ \"104.211.81.128/29\",\r\n \"104.211.146.72/29\",\r\n \"104.214.18.176/29\",\r\n - \ \"191.233.50.8/29\",\r\n \"191.233.203.128/29\",\r\n \"191.234.146.136/29\",\r\n - \ \"191.234.154.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.AustraliaEast\",\r\n \"id\": - \"MicrosoftContainerRegistry.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.72.128/29\",\r\n \"40.79.162.24/29\",\r\n - \ \"40.79.170.8/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.AustraliaSoutheast\",\r\n \"id\": - \"MicrosoftContainerRegistry.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.50.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.BrazilSouth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"191.233.203.128/29\",\r\n \"191.234.146.136/29\",\r\n - \ \"191.234.154.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.CanadaCentral\",\r\n \"id\": - \"MicrosoftContainerRegistry.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.170.48/29\",\r\n \"20.38.146.136/29\",\r\n - \ \"52.246.154.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.CanadaEast\",\r\n \"id\": - \"MicrosoftContainerRegistry.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.106.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.CentralIndia\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.192.98.136/29\",\r\n \"40.80.50.136/29\",\r\n - \ \"104.211.81.128/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.CentralUS\",\r\n \"id\": - \"MicrosoftContainerRegistry.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.170.208/29\",\r\n \"52.182.138.200/29\",\r\n - \ \"104.208.16.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.CentralUSEUAP\",\r\n \"id\": - \"MicrosoftContainerRegistry.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.202.64/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.EastAsia\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.75.34.152/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.EastUS\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.EastUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.71.10.208/29\",\r\n \"40.78.226.200/29\",\r\n - \ \"40.79.154.96/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.EastUS2\",\r\n \"id\": \"MicrosoftContainerRegistry.EastUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"40.70.146.80/29\",\r\n - \ \"52.167.106.72/29\",\r\n \"104.208.144.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.EastUS2EUAP\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.EastUS2EUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.146.40/29\",\r\n \"40.75.34.24/29\",\r\n - \ \"52.138.90.24/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.FranceCentral\",\r\n \"id\": - \"MicrosoftContainerRegistry.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.130.48/29\",\r\n \"40.79.138.24/29\",\r\n - \ \"40.79.146.24/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.FranceSouth\",\r\n \"id\": - \"MicrosoftContainerRegistry.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.178.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.GermanyNorth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.58.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.GermanyWestCentral\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.154.80/29\",\r\n \"51.116.242.136/29\",\r\n - \ \"51.116.250.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.JapanEast\",\r\n \"id\": - \"MicrosoftContainerRegistry.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.78.106.192/29\",\r\n \"40.79.186.0/29\",\r\n - \ \"40.79.194.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.JapanWest\",\r\n \"id\": - \"MicrosoftContainerRegistry.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.74.100.56/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.KoreaCentral\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.26.136/29\",\r\n \"20.194.66.8/29\",\r\n - \ \"52.231.18.48/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.KoreaSouth\",\r\n \"id\": - \"MicrosoftContainerRegistry.KoreaSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.146.88/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.NorthCentralUS\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"52.162.106.152/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.NorthEurope\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.227.80/29\",\r\n \"13.74.107.72/29\",\r\n - \ \"52.138.226.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.NorwayEast\",\r\n \"id\": - \"MicrosoftContainerRegistry.NorwayEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.98.24/29\",\r\n \"51.120.106.136/29\",\r\n - \ \"51.120.210.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.NorwayWest\",\r\n \"id\": - \"MicrosoftContainerRegistry.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.218.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.SouthAfricaNorth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.122.136/29\",\r\n \"102.133.154.16/29\",\r\n - \ \"102.133.250.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.SouthAfricaWest\",\r\n \"id\": - \"MicrosoftContainerRegistry.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.26.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.SouthCentralUS\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.122.136/29\",\r\n \"20.49.90.8/29\",\r\n - \ \"104.214.18.176/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.SoutheastAsia\",\r\n \"id\": - \"MicrosoftContainerRegistry.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.8.112/29\",\r\n \"23.98.82.104/29\",\r\n - \ \"40.78.234.40/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.SouthIndia\",\r\n \"id\": - \"MicrosoftContainerRegistry.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.78.194.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.SwitzerlandNorth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.58.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.SwitzerlandWest\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.154.16/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UAECentral\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.74.64/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UAENorth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.120.74.8/29\",\r\n \"65.52.250.8/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKNorth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.UKNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.122.88/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKSouth\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.66.136/29\",\r\n \"51.105.74.136/29\",\r\n - \ \"51.140.146.192/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.UKSouth2\",\r\n \"id\": - \"MicrosoftContainerRegistry.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"13.87.56.88/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKWest\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.UKWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"51.140.210.88/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.WestCentralUS\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.WestCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.120/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.WestEurope\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.64.80/29\",\r\n \"13.69.106.72/29\",\r\n - \ \"52.236.186.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"MicrosoftContainerRegistry.WestIndia\",\r\n \"id\": - \"MicrosoftContainerRegistry.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"104.211.146.72/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.WestUS\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.WestUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"40.112.242.152/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.WestUS2\",\r\n - \ \"id\": \"MicrosoftContainerRegistry.WestUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n - \ \"addressPrefixes\": [\r\n \"13.66.140.64/29\",\r\n \"40.78.242.152/29\",\r\n - \ \"40.78.250.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"PowerQueryOnline\",\r\n \"id\": \"PowerQueryOnline\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"20.36.120.120/31\",\r\n \"20.37.64.120/31\",\r\n - \ \"20.37.152.70/31\",\r\n \"20.37.192.70/31\",\r\n \"20.37.224.120/31\",\r\n - \ \"20.38.80.70/31\",\r\n \"20.38.136.68/31\",\r\n \"20.39.11.24/31\",\r\n - \ \"20.41.0.68/30\",\r\n \"20.41.64.70/31\",\r\n \"20.41.65.144/31\",\r\n - \ \"20.41.192.120/31\",\r\n \"20.42.4.200/30\",\r\n \"20.42.128.70/31\",\r\n - \ \"20.42.129.184/29\",\r\n \"20.42.224.120/31\",\r\n \"20.43.40.70/31\",\r\n - \ \"20.43.64.70/31\",\r\n \"20.43.128.70/31\",\r\n \"20.45.112.120/31\",\r\n - \ \"20.45.192.120/31\",\r\n \"20.150.160.108/31\",\r\n \"20.189.104.68/31\",\r\n - \ \"20.192.160.20/31\",\r\n \"20.192.225.32/31\",\r\n \"40.67.48.120/31\",\r\n - \ \"40.74.30.104/30\",\r\n \"40.80.56.120/31\",\r\n \"40.80.168.120/31\",\r\n - \ \"40.80.184.68/31\",\r\n \"40.82.253.72/29\",\r\n \"40.89.16.120/31\",\r\n - \ \"40.119.8.74/31\",\r\n \"51.104.24.70/31\",\r\n \"51.105.80.120/31\",\r\n - \ \"51.105.88.120/31\",\r\n \"51.107.48.70/31\",\r\n \"51.107.144.120/31\",\r\n - \ \"51.116.48.70/31\",\r\n \"51.116.144.70/31\",\r\n \"51.120.40.70/31\",\r\n - \ \"51.120.224.120/31\",\r\n \"51.137.160.68/31\",\r\n \"51.143.192.120/31\",\r\n - \ \"52.140.104.70/31\",\r\n \"52.150.139.72/30\",\r\n \"52.228.80.70/31\",\r\n - \ \"102.133.56.96/31\",\r\n \"102.133.216.70/31\",\r\n \"191.233.8.20/31\",\r\n - \ \"191.235.224.70/31\",\r\n \"2603:1000:104:1::200/123\",\r\n - \ \"2603:1010:6:1::200/123\",\r\n \"2603:1020:5:1::200/123\",\r\n - \ \"2603:1020:206:1::200/123\",\r\n \"2603:1020:705:1::200/123\",\r\n - \ \"2603:1020:805:1::200/123\",\r\n \"2603:1020:a04:1::200/123\",\r\n - \ \"2603:1020:c04:1::200/123\",\r\n \"2603:1020:e04:1::200/123\",\r\n - \ \"2603:1020:1004::200/123\",\r\n \"2603:1030:10:1::200/123\",\r\n - \ \"2603:1030:104:1::200/123\",\r\n \"2603:1030:210:1::200/123\",\r\n - \ \"2603:1030:40b:1::200/123\",\r\n \"2603:1030:40c:1::200/123\",\r\n - \ \"2603:1030:504:1::200/123\",\r\n \"2603:1030:807:1::200/123\",\r\n - \ \"2603:1030:c06:1::200/123\",\r\n \"2603:1030:f05:1::200/123\",\r\n - \ \"2603:1040:5:1::200/123\",\r\n \"2603:1040:407:1::200/123\",\r\n - \ \"2603:1040:904:1::200/123\",\r\n \"2603:1040:a06:1::200/123\",\r\n - \ \"2603:1040:d04::200/123\",\r\n \"2603:1040:f05:1::200/123\",\r\n - \ \"2603:1050:6:1::200/123\",\r\n \"2603:1050:403::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaCentral\",\r\n - \ \"id\": \"PowerQueryOnline.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.224.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaCentral2\",\r\n - \ \"id\": \"PowerQueryOnline.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.120.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaEast\",\r\n - \ \"id\": \"PowerQueryOnline.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.192.70/31\",\r\n \"2603:1010:6:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaSoutheast\",\r\n - \ \"id\": \"PowerQueryOnline.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.42.224.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.BrazilSouth\",\r\n - \ \"id\": \"PowerQueryOnline.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"191.235.224.70/31\",\r\n \"2603:1050:6:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CanadaCentral\",\r\n - \ \"id\": \"PowerQueryOnline.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"52.228.80.70/31\",\r\n \"2603:1030:f05:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CanadaEast\",\r\n - \ \"id\": \"PowerQueryOnline.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"40.89.16.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CentralIndia\",\r\n - \ \"id\": \"PowerQueryOnline.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"52.140.104.70/31\",\r\n \"2603:1040:a06:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CentralUS\",\r\n - \ \"id\": \"PowerQueryOnline.CentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.152.70/31\",\r\n \"2603:1030:10:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CentralUSEUAP\",\r\n - \ \"id\": \"PowerQueryOnline.CentralUSEUAP\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.192.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.EastAsia\",\r\n - \ \"id\": \"PowerQueryOnline.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.104.68/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.EastUS\",\r\n - \ \"id\": \"PowerQueryOnline.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"20.42.4.200/30\",\r\n \"2603:1030:210:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.EastUS2\",\r\n - \ \"id\": \"PowerQueryOnline.EastUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"20.41.0.68/30\",\r\n \"2603:1030:40c:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.EastUS2EUAP\",\r\n - \ \"id\": \"PowerQueryOnline.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.39.11.24/31\",\r\n \"2603:1030:40b:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.FranceCentral\",\r\n - \ \"id\": \"PowerQueryOnline.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.40.70/31\",\r\n \"2603:1020:805:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.FranceSouth\",\r\n - \ \"id\": \"PowerQueryOnline.FranceSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.88.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.GermanyNorth\",\r\n - \ \"id\": \"PowerQueryOnline.GermanyNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.48.70/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.GermanyWestCentral\",\r\n - \ \"id\": \"PowerQueryOnline.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.144.70/31\",\r\n \"2603:1020:c04:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.JapanEast\",\r\n - \ \"id\": \"PowerQueryOnline.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.64.70/31\",\r\n \"2603:1040:407:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.JapanWest\",\r\n - \ \"id\": \"PowerQueryOnline.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.56.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.KoreaCentral\",\r\n - \ \"id\": \"PowerQueryOnline.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.64.70/31\",\r\n \"20.41.65.144/31\",\r\n - \ \"2603:1040:f05:1::200/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.KoreaSouth\",\r\n \"id\": - \"PowerQueryOnline.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"40.80.168.120/31\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.NorthCentralUS\",\r\n \"id\": - \"PowerQueryOnline.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"40.80.184.68/31\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"PowerQueryOnline.NorthEurope\",\r\n \"id\": \"PowerQueryOnline.NorthEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"20.38.80.70/31\",\r\n - \ \"2603:1020:5:1::200/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.NorwayEast\",\r\n \"id\": - \"PowerQueryOnline.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"51.120.40.70/31\",\r\n \"2603:1020:e04:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.NorwayWest\",\r\n - \ \"id\": \"PowerQueryOnline.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"51.120.224.120/31\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.SouthAfricaNorth\",\r\n \"id\": - \"PowerQueryOnline.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"102.133.216.70/31\",\r\n \"2603:1000:104:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SouthAfricaWest\",\r\n - \ \"id\": \"PowerQueryOnline.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.56.96/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SouthCentralUS\",\r\n - \ \"id\": \"PowerQueryOnline.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"40.119.8.74/31\",\r\n \"2603:1030:807:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SoutheastAsia\",\r\n - \ \"id\": \"PowerQueryOnline.SoutheastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.128.70/31\",\r\n \"2603:1040:5:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SouthIndia\",\r\n - \ \"id\": \"PowerQueryOnline.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.192.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SwitzerlandNorth\",\r\n - \ \"id\": \"PowerQueryOnline.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.70/31\",\r\n \"2603:1020:a04:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SwitzerlandWest\",\r\n - \ \"id\": \"PowerQueryOnline.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.144.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UAECentral\",\r\n - \ \"id\": \"PowerQueryOnline.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.120/31\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UAENorth\",\r\n - \ \"id\": \"PowerQueryOnline.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.68/31\",\r\n \"2603:1040:904:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UKNorth\",\r\n - \ \"id\": \"PowerQueryOnline.UKNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"51.105.80.120/31\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.UKSouth\",\r\n \"id\": \"PowerQueryOnline.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"51.104.24.70/31\",\r\n - \ \"2603:1020:705:1::200/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.UKSouth2\",\r\n \"id\": \"PowerQueryOnline.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"51.143.192.120/31\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UKWest\",\r\n - \ \"id\": \"PowerQueryOnline.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"51.137.160.68/31\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.WestCentralUS\",\r\n \"id\": - \"PowerQueryOnline.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"52.150.139.72/30\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"PowerQueryOnline.WestEurope\",\r\n \"id\": - \"PowerQueryOnline.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"40.74.30.104/30\",\r\n \"2603:1020:206:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.WestUS\",\r\n - \ \"id\": \"PowerQueryOnline.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": - [\r\n \"40.82.253.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"PowerQueryOnline.WestUS2\",\r\n \"id\": \"PowerQueryOnline.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"20.42.128.70/31\",\r\n - \ \"20.42.129.184/29\",\r\n \"2603:1030:c06:1::200/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus\",\r\n - \ \"id\": \"ServiceBus\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.80/29\",\r\n \"13.67.8.96/29\",\r\n \"13.68.110.36/32\",\r\n - \ \"13.69.64.64/29\",\r\n \"13.69.106.64/29\",\r\n \"13.69.227.64/29\",\r\n - \ \"13.70.72.16/29\",\r\n \"13.70.186.33/32\",\r\n \"13.71.114.157/32\",\r\n - \ \"13.71.170.32/29\",\r\n \"13.71.194.96/28\",\r\n \"13.74.107.64/29\",\r\n - \ \"13.74.142.88/32\",\r\n \"13.75.34.128/28\",\r\n \"13.76.141.36/32\",\r\n - \ \"13.77.50.16/28\",\r\n \"13.78.94.187/32\",\r\n \"13.78.106.80/29\",\r\n - \ \"13.85.81.218/32\",\r\n \"13.87.35.8/32\",\r\n \"13.87.56.64/28\",\r\n - \ \"13.87.122.64/28\",\r\n \"13.88.10.93/32\",\r\n \"13.89.170.192/29\",\r\n - \ \"20.36.106.224/27\",\r\n \"20.36.114.128/27\",\r\n \"20.37.74.32/27\",\r\n - \ \"20.38.146.128/29\",\r\n \"20.44.2.8/29\",\r\n \"20.44.26.128/29\",\r\n - \ \"20.45.122.128/29\",\r\n \"20.150.160.216/29\",\r\n \"20.150.170.8/29\",\r\n - \ \"20.150.178.128/29\",\r\n \"20.150.186.128/29\",\r\n \"20.192.98.128/29\",\r\n - \ \"20.192.160.40/29\",\r\n \"20.192.225.56/29\",\r\n \"20.192.234.8/29\",\r\n - \ \"23.98.82.96/29\",\r\n \"40.65.108.146/32\",\r\n \"40.67.58.8/29\",\r\n - \ \"40.68.127.68/32\",\r\n \"40.69.106.16/28\",\r\n \"40.70.146.64/29\",\r\n - \ \"40.71.10.192/29\",\r\n \"40.74.100.32/28\",\r\n \"40.74.122.78/32\",\r\n - \ \"40.74.146.32/29\",\r\n \"40.75.34.16/29\",\r\n \"40.78.194.16/28\",\r\n - \ \"40.78.202.16/28\",\r\n \"40.78.226.192/29\",\r\n \"40.78.234.32/29\",\r\n - \ \"40.78.242.144/29\",\r\n \"40.78.250.80/29\",\r\n \"40.79.130.32/29\",\r\n - \ \"40.79.138.16/29\",\r\n \"40.79.146.16/29\",\r\n \"40.79.154.88/29\",\r\n - \ \"40.79.162.16/29\",\r\n \"40.79.170.16/29\",\r\n \"40.79.178.16/28\",\r\n - \ \"40.79.186.64/27\",\r\n \"40.79.194.80/29\",\r\n \"40.80.50.128/29\",\r\n - \ \"40.86.91.130/32\",\r\n \"40.112.242.128/28\",\r\n \"40.114.86.33/32\",\r\n - \ \"40.120.74.24/29\",\r\n \"51.12.98.8/29\",\r\n \"51.12.202.8/29\",\r\n - \ \"51.12.226.128/29\",\r\n \"51.12.234.128/29\",\r\n \"51.105.66.128/29\",\r\n - \ \"51.105.74.128/29\",\r\n \"51.107.58.8/29\",\r\n \"51.107.154.8/29\",\r\n - \ \"51.116.58.8/29\",\r\n \"51.116.154.72/29\",\r\n \"51.116.242.128/29\",\r\n - \ \"51.116.250.128/29\",\r\n \"51.120.98.16/29\",\r\n \"51.120.106.128/29\",\r\n - \ \"51.120.210.128/29\",\r\n \"51.120.218.8/29\",\r\n \"51.140.43.12/32\",\r\n - \ \"51.140.146.48/29\",\r\n \"51.140.210.64/28\",\r\n \"51.141.1.129/32\",\r\n - \ \"51.142.210.16/32\",\r\n \"52.138.71.95/32\",\r\n \"52.138.90.16/29\",\r\n - \ \"52.138.226.64/29\",\r\n \"52.161.17.198/32\",\r\n \"52.162.106.128/28\",\r\n - \ \"52.167.106.64/29\",\r\n \"52.168.29.86/32\",\r\n \"52.172.220.188/32\",\r\n - \ \"52.180.178.204/32\",\r\n \"52.182.138.192/29\",\r\n \"52.187.192.243/32\",\r\n - \ \"52.231.18.32/29\",\r\n \"52.231.146.64/28\",\r\n \"52.232.119.191/32\",\r\n - \ \"52.233.33.226/32\",\r\n \"52.236.186.64/29\",\r\n \"52.242.36.0/32\",\r\n - \ \"52.246.154.128/29\",\r\n \"65.52.219.186/32\",\r\n \"65.52.250.64/27\",\r\n - \ \"102.133.26.8/29\",\r\n \"102.133.122.128/29\",\r\n \"102.133.154.8/29\",\r\n - \ \"102.133.250.128/29\",\r\n \"104.40.15.128/32\",\r\n \"104.45.239.115/32\",\r\n - \ \"104.208.16.64/29\",\r\n \"104.208.144.64/29\",\r\n \"104.211.81.16/29\",\r\n - \ \"104.211.146.16/28\",\r\n \"104.211.190.88/32\",\r\n \"104.214.18.160/29\",\r\n - \ \"191.232.184.253/32\",\r\n \"191.233.8.40/29\",\r\n \"191.233.203.16/29\",\r\n - \ \"191.234.146.128/29\",\r\n \"191.234.154.128/29\",\r\n - \ \"191.235.170.182/32\",\r\n \"207.46.138.15/32\",\r\n \"2603:1000:104:1::220/123\",\r\n - \ \"2603:1010:6:1::220/123\",\r\n \"2603:1020:5:1::220/123\",\r\n - \ \"2603:1020:206:1::220/123\",\r\n \"2603:1020:705:1::220/123\",\r\n - \ \"2603:1020:805:1::220/123\",\r\n \"2603:1020:a04:1::220/123\",\r\n - \ \"2603:1020:c04:1::220/123\",\r\n \"2603:1020:e04:1::220/123\",\r\n - \ \"2603:1020:1004::220/123\",\r\n \"2603:1030:10:1::220/123\",\r\n - \ \"2603:1030:104:1::220/123\",\r\n \"2603:1030:210:1::220/123\",\r\n - \ \"2603:1030:40b:1::220/123\",\r\n \"2603:1030:40c:1::220/123\",\r\n - \ \"2603:1030:504:1::220/123\",\r\n \"2603:1030:807:1::220/123\",\r\n - \ \"2603:1030:c06:1::220/123\",\r\n \"2603:1030:f05:1::220/123\",\r\n - \ \"2603:1040:5:1::220/123\",\r\n \"2603:1040:407:1::220/123\",\r\n - \ \"2603:1040:904:1::220/123\",\r\n \"2603:1040:a06:1::220/123\",\r\n - \ \"2603:1040:d04::220/123\",\r\n \"2603:1040:f05:1::220/123\",\r\n - \ \"2603:1050:6:1::220/123\",\r\n \"2603:1050:403::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaCentral\",\r\n - \ \"id\": \"ServiceBus.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.106.224/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaCentral2\",\r\n - \ \"id\": \"ServiceBus.AustraliaCentral2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.114.128/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaEast\",\r\n - \ \"id\": \"ServiceBus.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.72.16/29\",\r\n \"40.79.162.16/29\",\r\n - \ \"40.79.170.16/29\",\r\n \"52.187.192.243/32\",\r\n \"2603:1010:6:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaSoutheast\",\r\n - \ \"id\": \"ServiceBus.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.186.33/32\",\r\n \"13.77.50.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.BrazilSouth\",\r\n - \ \"id\": \"ServiceBus.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"191.232.184.253/32\",\r\n \"191.233.203.16/29\",\r\n - \ \"191.234.146.128/29\",\r\n \"191.234.154.128/29\",\r\n - \ \"2603:1050:6:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.CanadaCentral\",\r\n \"id\": \"ServiceBus.CanadaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.32/29\",\r\n - \ \"20.38.146.128/29\",\r\n \"52.233.33.226/32\",\r\n \"52.246.154.128/29\",\r\n - \ \"2603:1030:f05:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.CanadaEast\",\r\n \"id\": \"ServiceBus.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.16/28\",\r\n - \ \"52.242.36.0/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.CentralIndia\",\r\n \"id\": \"ServiceBus.CentralIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"20.192.98.128/29\",\r\n - \ \"40.80.50.128/29\",\r\n \"52.172.220.188/32\",\r\n \"104.211.81.16/29\",\r\n - \ \"2603:1040:a06:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.CentralUS\",\r\n \"id\": \"ServiceBus.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.89.170.192/29\",\r\n - \ \"40.86.91.130/32\",\r\n \"52.182.138.192/29\",\r\n \"104.208.16.64/29\",\r\n - \ \"2603:1030:10:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.CentralUSEUAP\",\r\n \"id\": \"ServiceBus.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.16/28\",\r\n - \ \"52.180.178.204/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.EastAsia\",\r\n \"id\": \"ServiceBus.EastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.75.34.128/28\",\r\n - \ \"207.46.138.15/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.EastUS\",\r\n \"id\": \"ServiceBus.EastUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.71.10.192/29\",\r\n - \ \"40.78.226.192/29\",\r\n \"40.79.154.88/29\",\r\n \"40.114.86.33/32\",\r\n - \ \"52.168.29.86/32\",\r\n \"2603:1030:210:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.EastUS2\",\r\n - \ \"id\": \"ServiceBus.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.68.110.36/32\",\r\n \"40.70.146.64/29\",\r\n - \ \"52.167.106.64/29\",\r\n \"104.208.144.64/29\",\r\n \"2603:1030:40c:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.EastUS2EUAP\",\r\n - \ \"id\": \"ServiceBus.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"40.74.146.32/29\",\r\n \"40.75.34.16/29\",\r\n \"52.138.71.95/32\",\r\n - \ \"52.138.90.16/29\",\r\n \"2603:1030:40b:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.FranceCentral\",\r\n - \ \"id\": \"ServiceBus.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.130.32/29\",\r\n \"40.79.138.16/29\",\r\n - \ \"40.79.146.16/29\",\r\n \"2603:1020:805:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.FranceSouth\",\r\n - \ \"id\": \"ServiceBus.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"40.79.178.16/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.GermanyNorth\",\r\n \"id\": \"ServiceBus.GermanyNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanyn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.116.58.8/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.GermanyWestCentral\",\r\n - \ \"id\": \"ServiceBus.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.154.72/29\",\r\n \"51.116.242.128/29\",\r\n - \ \"51.116.250.128/29\",\r\n \"2603:1020:c04:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.JapanEast\",\r\n - \ \"id\": \"ServiceBus.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.78.94.187/32\",\r\n \"13.78.106.80/29\",\r\n - \ \"40.79.186.64/27\",\r\n \"40.79.194.80/29\",\r\n \"2603:1040:407:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.JapanWest\",\r\n - \ \"id\": \"ServiceBus.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.32/28\",\r\n \"40.74.122.78/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.KoreaCentral\",\r\n - \ \"id\": \"ServiceBus.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"20.44.26.128/29\",\r\n \"52.231.18.32/29\",\r\n - \ \"2603:1040:f05:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.KoreaSouth\",\r\n \"id\": \"ServiceBus.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"52.231.146.64/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.NorthCentralUS\",\r\n - \ \"id\": \"ServiceBus.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"52.162.106.128/28\",\r\n \"65.52.219.186/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.NorthEurope\",\r\n - \ \"id\": \"ServiceBus.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.69.227.64/29\",\r\n \"13.74.107.64/29\",\r\n - \ \"13.74.142.88/32\",\r\n \"52.138.226.64/29\",\r\n \"191.235.170.182/32\",\r\n - \ \"2603:1020:5:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.NorwayEast\",\r\n \"id\": \"ServiceBus.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.120.98.16/29\",\r\n - \ \"51.120.106.128/29\",\r\n \"51.120.210.128/29\",\r\n \"2603:1020:e04:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.NorwayWest\",\r\n - \ \"id\": \"ServiceBus.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.8/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthAfricaNorth\",\r\n - \ \"id\": \"ServiceBus.SouthAfricaNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.122.128/29\",\r\n \"102.133.154.8/29\",\r\n - \ \"102.133.250.128/29\",\r\n \"2603:1000:104:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthAfricaWest\",\r\n - \ \"id\": \"ServiceBus.SouthAfricaWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.26.8/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthCentralUS\",\r\n - \ \"id\": \"ServiceBus.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.85.81.218/32\",\r\n \"20.45.122.128/29\",\r\n - \ \"104.214.18.160/29\",\r\n \"2603:1030:807:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SoutheastAsia\",\r\n - \ \"id\": \"ServiceBus.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.67.8.96/29\",\r\n \"13.76.141.36/32\",\r\n - \ \"23.98.82.96/29\",\r\n \"40.78.234.32/29\",\r\n \"2603:1040:5:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthIndia\",\r\n - \ \"id\": \"ServiceBus.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.71.114.157/32\",\r\n \"40.78.194.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SwitzerlandNorth\",\r\n - \ \"id\": \"ServiceBus.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.58.8/29\",\r\n \"2603:1020:a04:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SwitzerlandWest\",\r\n - \ \"id\": \"ServiceBus.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.154.8/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UAECentral\",\r\n - \ \"id\": \"ServiceBus.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"20.37.74.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.UAENorth\",\r\n \"id\": \"ServiceBus.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.24/29\",\r\n - \ \"65.52.250.64/27\",\r\n \"2603:1040:904:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UKNorth\",\r\n - \ \"id\": \"ServiceBus.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.87.122.64/28\",\r\n - \ \"51.142.210.16/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceBus.UKSouth\",\r\n \"id\": \"ServiceBus.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.105.66.128/29\",\r\n - \ \"51.105.74.128/29\",\r\n \"51.140.43.12/32\",\r\n \"51.140.146.48/29\",\r\n - \ \"2603:1020:705:1::220/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"ServiceBus.UKSouth2\",\r\n \"id\": \"ServiceBus.UKSouth2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.35.8/32\",\r\n \"13.87.56.64/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UKWest\",\r\n - \ \"id\": \"ServiceBus.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"51.140.210.64/28\",\r\n \"51.141.1.129/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestCentralUS\",\r\n - \ \"id\": \"ServiceBus.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.194.96/28\",\r\n \"52.161.17.198/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestEurope\",\r\n - \ \"id\": \"ServiceBus.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.69.64.64/29\",\r\n \"13.69.106.64/29\",\r\n \"40.68.127.68/32\",\r\n - \ \"52.232.119.191/32\",\r\n \"52.236.186.64/29\",\r\n \"2603:1020:206:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestIndia\",\r\n - \ \"id\": \"ServiceBus.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"104.211.146.16/28\",\r\n \"104.211.190.88/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestUS\",\r\n - \ \"id\": \"ServiceBus.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.88.10.93/32\",\r\n \"40.112.242.128/28\",\r\n - \ \"104.40.15.128/32\",\r\n \"104.45.239.115/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestUS2\",\r\n - \ \"id\": \"ServiceBus.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": - [\r\n \"13.66.138.80/29\",\r\n \"40.65.108.146/32\",\r\n - \ \"40.78.242.144/29\",\r\n \"40.78.250.80/29\",\r\n \"2603:1030:c06:1::220/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric\",\r\n - \ \"id\": \"ServiceFabric\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.66.140.152/29\",\r\n \"13.66.167.194/32\",\r\n - \ \"13.66.226.151/32\",\r\n \"13.67.9.136/29\",\r\n \"13.69.64.232/29\",\r\n - \ \"13.69.109.136/30\",\r\n \"13.69.227.232/29\",\r\n \"13.70.72.216/29\",\r\n - \ \"13.70.78.172/30\",\r\n \"13.71.170.224/29\",\r\n \"13.71.170.248/29\",\r\n - \ \"13.71.195.48/29\",\r\n \"13.74.80.74/32\",\r\n \"13.74.111.144/30\",\r\n - \ \"13.75.36.80/29\",\r\n \"13.75.41.166/32\",\r\n \"13.75.42.35/32\",\r\n - \ \"13.77.52.0/29\",\r\n \"13.78.108.24/29\",\r\n \"13.78.147.125/32\",\r\n - \ \"13.80.117.236/32\",\r\n \"13.87.32.204/32\",\r\n \"13.87.56.240/29\",\r\n - \ \"13.87.98.166/32\",\r\n \"13.87.122.240/29\",\r\n \"13.89.171.104/29\",\r\n - \ \"13.91.7.211/32\",\r\n \"13.91.252.58/32\",\r\n \"13.92.124.124/32\",\r\n - \ \"20.36.40.70/32\",\r\n \"20.36.72.79/32\",\r\n \"20.36.107.16/29\",\r\n - \ \"20.36.114.192/29\",\r\n \"20.37.74.80/29\",\r\n \"20.38.149.192/30\",\r\n - \ \"20.42.64.40/30\",\r\n \"20.42.72.132/30\",\r\n \"20.44.3.24/29\",\r\n - \ \"20.44.10.124/30\",\r\n \"20.44.19.0/30\",\r\n \"20.44.29.52/30\",\r\n - \ \"20.45.79.240/32\",\r\n \"20.45.123.244/30\",\r\n \"20.49.82.4/30\",\r\n - \ \"20.49.90.4/30\",\r\n \"20.150.171.72/29\",\r\n \"20.150.181.160/30\",\r\n - \ \"20.150.189.28/30\",\r\n \"20.184.2.84/32\",\r\n \"20.192.101.28/30\",\r\n - \ \"20.192.235.0/29\",\r\n \"20.193.202.24/29\",\r\n \"20.194.66.4/30\",\r\n - \ \"23.96.200.228/32\",\r\n \"23.96.210.6/32\",\r\n \"23.96.214.100/32\",\r\n - \ \"23.98.86.60/30\",\r\n \"23.99.11.219/32\",\r\n \"23.100.199.230/32\",\r\n - \ \"40.67.59.72/29\",\r\n \"40.69.107.0/29\",\r\n \"40.69.166.6/32\",\r\n - \ \"40.70.146.232/29\",\r\n \"40.71.11.104/29\",\r\n \"40.74.100.240/29\",\r\n - \ \"40.74.146.56/29\",\r\n \"40.75.35.220/30\",\r\n \"40.76.203.148/32\",\r\n - \ \"40.76.205.181/32\",\r\n \"40.78.195.0/29\",\r\n \"40.78.202.120/29\",\r\n - \ \"40.78.238.60/30\",\r\n \"40.78.245.192/30\",\r\n \"40.78.253.64/30\",\r\n - \ \"40.79.114.102/32\",\r\n \"40.79.130.232/29\",\r\n \"40.79.139.192/30\",\r\n - \ \"40.79.148.80/30\",\r\n \"40.79.165.80/29\",\r\n \"40.79.171.228/30\",\r\n - \ \"40.79.173.0/30\",\r\n \"40.79.179.0/29\",\r\n \"40.79.189.60/30\",\r\n - \ \"40.79.197.36/30\",\r\n \"40.80.53.4/30\",\r\n \"40.84.62.189/32\",\r\n - \ \"40.84.133.64/32\",\r\n \"40.85.224.118/32\",\r\n \"40.86.230.174/32\",\r\n - \ \"40.89.168.15/32\",\r\n \"40.112.243.176/29\",\r\n \"40.113.23.157/32\",\r\n - \ \"40.113.88.37/32\",\r\n \"40.115.64.123/32\",\r\n \"40.115.113.228/32\",\r\n - \ \"40.120.74.4/30\",\r\n \"40.123.204.26/32\",\r\n \"51.12.99.64/29\",\r\n - \ \"51.12.203.64/29\",\r\n \"51.105.69.84/30\",\r\n \"51.105.77.52/30\",\r\n - \ \"51.107.59.40/29\",\r\n \"51.107.76.20/32\",\r\n \"51.107.155.40/29\",\r\n - \ \"51.107.239.250/32\",\r\n \"51.116.59.40/29\",\r\n \"51.116.155.104/29\",\r\n - \ \"51.116.208.26/32\",\r\n \"51.116.232.27/32\",\r\n \"51.116.245.160/30\",\r\n - \ \"51.116.253.128/30\",\r\n \"51.120.68.23/32\",\r\n \"51.120.98.240/29\",\r\n - \ \"51.120.164.23/32\",\r\n \"51.120.219.72/29\",\r\n \"51.140.148.24/29\",\r\n - \ \"51.140.184.27/32\",\r\n \"51.140.211.16/29\",\r\n \"51.141.8.30/32\",\r\n - \ \"52.136.136.27/32\",\r\n \"52.138.70.82/32\",\r\n \"52.138.92.168/30\",\r\n - \ \"52.138.143.55/32\",\r\n \"52.138.229.68/30\",\r\n \"52.143.136.15/32\",\r\n - \ \"52.143.184.15/32\",\r\n \"52.151.38.144/32\",\r\n \"52.158.236.247/32\",\r\n - \ \"52.162.107.176/29\",\r\n \"52.163.90.165/32\",\r\n \"52.163.94.113/32\",\r\n - \ \"52.165.37.188/32\",\r\n \"52.167.0.27/32\",\r\n \"52.167.109.68/30\",\r\n - \ \"52.167.227.220/32\",\r\n \"52.174.163.204/32\",\r\n \"52.174.164.254/32\",\r\n - \ \"52.178.30.193/32\",\r\n \"52.180.176.84/32\",\r\n \"52.182.141.56/30\",\r\n - \ \"52.182.172.232/32\",\r\n \"52.225.184.94/32\",\r\n \"52.225.185.159/32\",\r\n - \ \"52.230.8.61/32\",\r\n \"52.231.18.232/29\",\r\n \"52.231.32.81/32\",\r\n - \ \"52.231.147.16/29\",\r\n \"52.231.200.124/32\",\r\n \"52.236.161.75/32\",\r\n - \ \"52.236.189.76/30\",\r\n \"52.246.157.8/30\",\r\n \"65.52.250.224/29\",\r\n - \ \"102.37.48.12/32\",\r\n \"102.133.27.24/29\",\r\n \"102.133.72.31/32\",\r\n - \ \"102.133.155.24/29\",\r\n \"102.133.160.28/32\",\r\n \"102.133.235.169/32\",\r\n - \ \"102.133.251.216/30\",\r\n \"104.41.9.53/32\",\r\n \"104.41.187.29/32\",\r\n - \ \"104.42.181.121/32\",\r\n \"104.43.213.84/32\",\r\n \"104.45.19.250/32\",\r\n - \ \"104.46.225.57/32\",\r\n \"104.210.107.69/32\",\r\n \"104.211.81.216/29\",\r\n - \ \"104.211.103.201/32\",\r\n \"104.211.146.240/29\",\r\n - \ \"104.211.164.163/32\",\r\n \"104.211.228.68/32\",\r\n - \ \"104.214.19.72/29\",\r\n \"104.215.78.146/32\",\r\n \"137.116.252.9/32\",\r\n - \ \"137.135.33.49/32\",\r\n \"191.233.50.24/29\",\r\n \"191.233.203.216/29\",\r\n - \ \"191.234.149.32/30\",\r\n \"191.234.157.128/30\",\r\n - \ \"207.46.234.62/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.AustraliaCentral\",\r\n \"id\": \"ServiceFabric.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.40.70/32\",\r\n \"20.36.107.16/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.AustraliaCentral2\",\r\n - \ \"id\": \"ServiceFabric.AustraliaCentral2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"20.36.72.79/32\",\r\n \"20.36.114.192/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.AustraliaEast\",\r\n - \ \"id\": \"ServiceFabric.AustraliaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.70.72.216/29\",\r\n \"13.70.78.172/30\",\r\n - \ \"40.79.165.80/29\",\r\n \"40.79.171.228/30\",\r\n \"40.79.173.0/30\",\r\n - \ \"104.210.107.69/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.AustraliaSoutheast\",\r\n \"id\": \"ServiceFabric.AustraliaSoutheast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.52.0/29\",\r\n \"40.115.64.123/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.BrazilSouth\",\r\n - \ \"id\": \"ServiceFabric.BrazilSouth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"104.41.9.53/32\",\r\n \"191.233.203.216/29\",\r\n - \ \"191.234.149.32/30\",\r\n \"191.234.157.128/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CanadaCentral\",\r\n - \ \"id\": \"ServiceFabric.CanadaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.71.170.224/29\",\r\n \"13.71.170.248/29\",\r\n - \ \"20.38.149.192/30\",\r\n \"40.85.224.118/32\",\r\n \"52.246.157.8/30\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CanadaEast\",\r\n - \ \"id\": \"ServiceFabric.CanadaEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.69.107.0/29\",\r\n \"40.86.230.174/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CentralIndia\",\r\n - \ \"id\": \"ServiceFabric.CentralIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"20.192.101.28/30\",\r\n \"40.80.53.4/30\",\r\n \"104.211.81.216/29\",\r\n - \ \"104.211.103.201/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.CentralUS\",\r\n \"id\": \"ServiceFabric.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"13.89.171.104/29\",\r\n \"20.44.10.124/30\",\r\n - \ \"40.69.166.6/32\",\r\n \"52.165.37.188/32\",\r\n \"52.182.141.56/30\",\r\n - \ \"52.182.172.232/32\",\r\n \"104.43.213.84/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CentralUSEUAP\",\r\n - \ \"id\": \"ServiceFabric.CentralUSEUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.78.202.120/29\",\r\n \"52.180.176.84/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.EastAsia\",\r\n - \ \"id\": \"ServiceFabric.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.75.36.80/29\",\r\n - \ \"13.75.41.166/32\",\r\n \"13.75.42.35/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.EastUS\",\r\n - \ \"id\": \"ServiceFabric.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.92.124.124/32\",\r\n - \ \"20.42.64.40/30\",\r\n \"20.42.72.132/30\",\r\n \"40.71.11.104/29\",\r\n - \ \"40.76.203.148/32\",\r\n \"40.76.205.181/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.EastUS2\",\r\n - \ \"id\": \"ServiceFabric.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"20.44.19.0/30\",\r\n - \ \"40.70.146.232/29\",\r\n \"40.84.62.189/32\",\r\n \"52.167.0.27/32\",\r\n - \ \"52.167.109.68/30\",\r\n \"52.167.227.220/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.EastUS2EUAP\",\r\n - \ \"id\": \"ServiceFabric.EastUS2EUAP\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.74.146.56/29\",\r\n \"40.75.35.220/30\",\r\n - \ \"40.79.114.102/32\",\r\n \"52.138.70.82/32\",\r\n \"52.138.92.168/30\",\r\n - \ \"52.225.184.94/32\",\r\n \"52.225.185.159/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.FranceCentral\",\r\n - \ \"id\": \"ServiceFabric.FranceCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.79.130.232/29\",\r\n \"40.79.139.192/30\",\r\n - \ \"40.79.148.80/30\",\r\n \"40.89.168.15/32\",\r\n \"52.143.136.15/32\",\r\n - \ \"52.143.184.15/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.FranceSouth\",\r\n \"id\": \"ServiceFabric.FranceSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"40.79.179.0/29\",\r\n \"52.136.136.27/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.GermanyNorth\",\r\n - \ \"id\": \"ServiceFabric.GermanyNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"51.116.59.40/29\",\r\n \"51.116.208.26/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.GermanyWestCentral\",\r\n - \ \"id\": \"ServiceFabric.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"51.116.155.104/29\",\r\n \"51.116.232.27/32\",\r\n - \ \"51.116.245.160/30\",\r\n \"51.116.253.128/30\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.JapanEast\",\r\n - \ \"id\": \"ServiceFabric.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.78.108.24/29\",\r\n \"40.79.189.60/30\",\r\n - \ \"40.79.197.36/30\",\r\n \"104.41.187.29/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.JapanWest\",\r\n - \ \"id\": \"ServiceFabric.JapanWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.74.100.240/29\",\r\n \"104.46.225.57/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.KoreaCentral\",\r\n - \ \"id\": \"ServiceFabric.KoreaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"20.44.29.52/30\",\r\n \"20.194.66.4/30\",\r\n \"52.231.18.232/29\",\r\n - \ \"52.231.32.81/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.KoreaSouth\",\r\n \"id\": \"ServiceFabric.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.147.16/29\",\r\n \"52.231.200.124/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.NorthCentralUS\",\r\n - \ \"id\": \"ServiceFabric.NorthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"23.96.200.228/32\",\r\n \"23.96.210.6/32\",\r\n - \ \"23.96.214.100/32\",\r\n \"52.162.107.176/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.NorthEurope\",\r\n - \ \"id\": \"ServiceFabric.NorthEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.69.227.232/29\",\r\n \"13.74.80.74/32\",\r\n - \ \"13.74.111.144/30\",\r\n \"40.113.23.157/32\",\r\n \"40.113.88.37/32\",\r\n - \ \"40.115.113.228/32\",\r\n \"52.138.143.55/32\",\r\n \"52.138.229.68/30\",\r\n - \ \"137.116.252.9/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.NorwayEast\",\r\n \"id\": \"ServiceFabric.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.68.23/32\",\r\n \"51.120.98.240/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.NorwayWest\",\r\n - \ \"id\": \"ServiceFabric.NorwayWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"51.120.164.23/32\",\r\n \"51.120.219.72/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SouthAfricaNorth\",\r\n - \ \"id\": \"ServiceFabric.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"102.37.48.12/32\",\r\n \"102.133.155.24/29\",\r\n - \ \"102.133.160.28/32\",\r\n \"102.133.235.169/32\",\r\n - \ \"102.133.251.216/30\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.SouthAfricaWest\",\r\n \"id\": \"ServiceFabric.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.27.24/29\",\r\n \"102.133.72.31/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SouthCentralUS\",\r\n - \ \"id\": \"ServiceFabric.SouthCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"20.45.123.244/30\",\r\n \"20.49.90.4/30\",\r\n \"40.84.133.64/32\",\r\n - \ \"104.214.19.72/29\",\r\n \"104.215.78.146/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SoutheastAsia\",\r\n - \ \"id\": \"ServiceFabric.SoutheastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.67.9.136/29\",\r\n \"20.184.2.84/32\",\r\n \"23.98.86.60/30\",\r\n - \ \"40.78.238.60/30\",\r\n \"52.163.90.165/32\",\r\n \"52.163.94.113/32\",\r\n - \ \"52.230.8.61/32\",\r\n \"207.46.234.62/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SouthIndia\",\r\n - \ \"id\": \"ServiceFabric.SouthIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"40.78.195.0/29\",\r\n \"104.211.228.68/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SwitzerlandNorth\",\r\n - \ \"id\": \"ServiceFabric.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"51.107.59.40/29\",\r\n \"51.107.76.20/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SwitzerlandWest\",\r\n - \ \"id\": \"ServiceFabric.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"51.107.155.40/29\",\r\n \"51.107.239.250/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UAECentral\",\r\n - \ \"id\": \"ServiceFabric.UAECentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"20.37.74.80/29\",\r\n \"20.45.79.240/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UAENorth\",\r\n - \ \"id\": \"ServiceFabric.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.4/30\",\r\n - \ \"40.123.204.26/32\",\r\n \"65.52.250.224/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UKNorth\",\r\n - \ \"id\": \"ServiceFabric.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.87.98.166/32\",\r\n - \ \"13.87.122.240/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.UKSouth\",\r\n \"id\": \"ServiceFabric.UKSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.69.84/30\",\r\n \"51.105.77.52/30\",\r\n - \ \"51.140.148.24/29\",\r\n \"51.140.184.27/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UKSouth2\",\r\n - \ \"id\": \"ServiceFabric.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.87.32.204/32\",\r\n - \ \"13.87.56.240/29\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.UKWest\",\r\n \"id\": \"ServiceFabric.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"51.140.211.16/29\",\r\n \"51.141.8.30/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestCentralUS\",\r\n - \ \"id\": \"ServiceFabric.WestCentralUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.71.195.48/29\",\r\n \"13.78.147.125/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestEurope\",\r\n - \ \"id\": \"ServiceFabric.WestEurope\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n - \ ],\r\n \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": - [\r\n \"13.69.64.232/29\",\r\n \"13.69.109.136/30\",\r\n - \ \"13.80.117.236/32\",\r\n \"52.174.163.204/32\",\r\n \"52.174.164.254/32\",\r\n - \ \"52.178.30.193/32\",\r\n \"52.236.161.75/32\",\r\n \"52.236.189.76/30\",\r\n - \ \"104.45.19.250/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"ServiceFabric.WestIndia\",\r\n \"id\": \"ServiceFabric.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n - \ \"addressPrefixes\": [\r\n \"104.211.146.240/29\",\r\n \"104.211.164.163/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestUS\",\r\n - \ \"id\": \"ServiceFabric.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.91.7.211/32\",\r\n - \ \"13.91.252.58/32\",\r\n \"23.99.11.219/32\",\r\n \"40.112.243.176/29\",\r\n - \ \"104.42.181.121/32\",\r\n \"137.135.33.49/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestUS2\",\r\n - \ \"id\": \"ServiceFabric.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.152/29\",\r\n - \ \"13.66.167.194/32\",\r\n \"13.66.226.151/32\",\r\n \"40.78.245.192/30\",\r\n - \ \"40.78.253.64/30\",\r\n \"52.151.38.144/32\",\r\n \"52.158.236.247/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql\",\r\n \"id\": - \"Sql\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.65.31.249/32\",\r\n \"13.65.39.207/32\",\r\n - \ \"13.65.85.183/32\",\r\n \"13.65.200.105/32\",\r\n \"13.65.209.243/32\",\r\n - \ \"13.65.253.67/32\",\r\n \"13.66.60.72/32\",\r\n \"13.66.60.111/32\",\r\n - \ \"13.66.62.124/32\",\r\n \"13.66.136.0/26\",\r\n \"13.66.137.0/26\",\r\n - \ \"13.66.226.202/32\",\r\n \"13.66.229.222/32\",\r\n \"13.66.230.18/31\",\r\n - \ \"13.66.230.60/32\",\r\n \"13.66.230.64/32\",\r\n \"13.66.230.103/32\",\r\n - \ \"13.67.16.0/26\",\r\n \"13.67.17.0/26\",\r\n \"13.67.48.255/32\",\r\n - \ \"13.67.56.134/32\",\r\n \"13.67.59.217/32\",\r\n \"13.67.215.62/32\",\r\n - \ \"13.68.22.44/32\",\r\n \"13.68.30.216/32\",\r\n \"13.68.87.133/32\",\r\n - \ \"13.69.104.0/26\",\r\n \"13.69.104.192/26\",\r\n \"13.69.105.0/26\",\r\n - \ \"13.69.105.192/26\",\r\n \"13.69.224.0/26\",\r\n \"13.69.224.192/26\",\r\n - \ \"13.69.225.0/26\",\r\n \"13.69.225.192/26\",\r\n \"13.70.112.0/27\",\r\n - \ \"13.70.113.0/27\",\r\n \"13.70.148.251/32\",\r\n \"13.70.155.163/32\",\r\n - \ \"13.71.168.0/27\",\r\n \"13.71.169.0/27\",\r\n \"13.71.192.0/27\",\r\n - \ \"13.71.193.0/27\",\r\n \"13.73.109.251/32\",\r\n \"13.74.104.64/26\",\r\n - \ \"13.74.104.128/26\",\r\n \"13.74.105.0/26\",\r\n \"13.74.105.128/26\",\r\n - \ \"13.75.32.0/26\",\r\n \"13.75.33.0/26\",\r\n \"13.75.105.141/32\",\r\n - \ \"13.75.106.191/32\",\r\n \"13.75.108.188/32\",\r\n \"13.75.149.87/32\",\r\n - \ \"13.76.90.3/32\",\r\n \"13.76.247.54/32\",\r\n \"13.77.7.78/32\",\r\n - \ \"13.77.48.0/27\",\r\n \"13.77.49.0/27\",\r\n \"13.78.61.196/32\",\r\n - \ \"13.78.104.0/27\",\r\n \"13.78.105.0/27\",\r\n \"13.78.121.203/32\",\r\n - \ \"13.78.144.57/32\",\r\n \"13.78.145.25/32\",\r\n \"13.78.148.71/32\",\r\n - \ \"13.78.151.189/32\",\r\n \"13.78.151.207/32\",\r\n \"13.78.178.116/32\",\r\n - \ \"13.78.178.151/32\",\r\n \"13.78.248.32/27\",\r\n \"13.84.223.76/32\",\r\n - \ \"13.85.65.48/32\",\r\n \"13.85.68.115/32\",\r\n \"13.85.69.107/32\",\r\n - \ \"13.86.216.0/25\",\r\n \"13.86.216.128/26\",\r\n \"13.86.216.192/27\",\r\n - \ \"13.86.217.0/25\",\r\n \"13.86.217.128/26\",\r\n \"13.86.217.192/27\",\r\n - \ \"13.87.16.64/27\",\r\n \"13.87.17.0/27\",\r\n \"13.87.33.234/32\",\r\n - \ \"13.87.34.7/32\",\r\n \"13.87.34.19/32\",\r\n \"13.87.38.138/32\",\r\n - \ \"13.87.97.210/32\",\r\n \"13.87.97.228/32\",\r\n \"13.87.97.237/32\",\r\n - \ \"13.87.120.0/27\",\r\n \"13.87.121.0/27\",\r\n \"13.88.14.200/32\",\r\n - \ \"13.88.29.70/32\",\r\n \"13.88.249.189/32\",\r\n \"13.88.254.42/32\",\r\n - \ \"13.89.36.110/32\",\r\n \"13.89.37.61/32\",\r\n \"13.89.57.50/32\",\r\n - \ \"13.89.57.115/32\",\r\n \"13.89.168.0/26\",\r\n \"13.89.169.0/26\",\r\n - \ \"13.91.4.219/32\",\r\n \"13.91.6.136/32\",\r\n \"13.91.41.153/32\",\r\n - \ \"13.91.44.56/32\",\r\n \"13.91.46.83/32\",\r\n \"13.91.47.72/32\",\r\n - \ \"13.93.165.251/32\",\r\n \"13.93.237.158/32\",\r\n \"20.36.104.0/27\",\r\n - \ \"20.36.105.0/27\",\r\n \"20.36.112.0/27\",\r\n \"20.36.113.0/27\",\r\n - \ \"20.37.72.64/27\",\r\n \"20.37.73.64/27\",\r\n \"20.38.144.0/27\",\r\n - \ \"20.38.145.0/27\",\r\n \"20.44.0.0/27\",\r\n \"20.44.1.0/27\",\r\n - \ \"20.44.24.0/27\",\r\n \"20.44.25.0/27\",\r\n \"20.45.120.0/27\",\r\n - \ \"20.45.121.0/27\",\r\n \"20.49.80.0/27\",\r\n \"20.49.81.0/27\",\r\n - \ \"20.49.88.0/27\",\r\n \"20.49.89.0/27\",\r\n \"20.150.168.0/27\",\r\n - \ \"20.150.169.0/27\",\r\n \"20.150.176.0/27\",\r\n \"20.150.177.0/27\",\r\n - \ \"20.150.184.0/27\",\r\n \"20.150.185.0/27\",\r\n \"20.192.96.0/27\",\r\n - \ \"20.192.97.0/27\",\r\n \"20.192.232.0/27\",\r\n \"20.192.233.0/27\",\r\n - \ \"20.193.200.0/27\",\r\n \"20.193.201.0/27\",\r\n \"20.194.64.0/27\",\r\n - \ \"20.194.65.0/27\",\r\n \"23.96.89.109/32\",\r\n \"23.96.106.191/32\",\r\n - \ \"23.96.178.199/32\",\r\n \"23.96.202.229/32\",\r\n \"23.96.204.249/32\",\r\n - \ \"23.96.205.215/32\",\r\n \"23.96.214.69/32\",\r\n \"23.96.243.243/32\",\r\n - \ \"23.96.247.75/32\",\r\n \"23.96.249.37/32\",\r\n \"23.96.250.178/32\",\r\n - \ \"23.97.68.51/32\",\r\n \"23.97.74.21/32\",\r\n \"23.97.78.163/32\",\r\n - \ \"23.97.167.46/32\",\r\n \"23.97.169.19/32\",\r\n \"23.97.219.82/32\",\r\n - \ \"23.97.221.176/32\",\r\n \"23.98.55.75/32\",\r\n \"23.98.80.0/26\",\r\n - \ \"23.98.81.0/26\",\r\n \"23.98.162.75/32\",\r\n \"23.98.162.76/31\",\r\n - \ \"23.98.162.78/32\",\r\n \"23.98.170.75/32\",\r\n \"23.98.170.76/31\",\r\n - \ \"23.99.4.210/32\",\r\n \"23.99.4.248/32\",\r\n \"23.99.10.185/32\",\r\n - \ \"23.99.34.75/32\",\r\n \"23.99.34.76/31\",\r\n \"23.99.34.78/32\",\r\n - \ \"23.99.37.235/32\",\r\n \"23.99.37.236/32\",\r\n \"23.99.57.14/32\",\r\n - \ \"23.99.80.243/32\",\r\n \"23.99.89.212/32\",\r\n \"23.99.90.75/32\",\r\n - \ \"23.99.91.130/32\",\r\n \"23.99.102.124/32\",\r\n \"23.99.118.196/32\",\r\n - \ \"23.99.160.139/32\",\r\n \"23.99.160.140/31\",\r\n \"23.99.160.142/32\",\r\n - \ \"23.99.205.183/32\",\r\n \"23.100.117.95/32\",\r\n \"23.100.119.70/32\",\r\n - \ \"23.101.18.228/32\",\r\n \"23.101.64.10/32\",\r\n \"23.101.165.167/32\",\r\n - \ \"23.101.167.45/32\",\r\n \"23.101.170.98/32\",\r\n \"23.102.16.130/32\",\r\n - \ \"23.102.23.219/32\",\r\n \"23.102.25.199/32\",\r\n \"23.102.52.155/32\",\r\n - \ \"23.102.57.142/32\",\r\n \"23.102.62.171/32\",\r\n \"23.102.69.95/32\",\r\n - \ \"23.102.71.13/32\",\r\n \"23.102.74.190/32\",\r\n \"23.102.172.251/32\",\r\n - \ \"23.102.173.220/32\",\r\n \"23.102.174.146/32\",\r\n \"23.102.179.187/32\",\r\n - \ \"23.102.206.35/32\",\r\n \"23.102.206.36/31\",\r\n \"40.67.56.0/27\",\r\n - \ \"40.67.57.0/27\",\r\n \"40.68.37.158/32\",\r\n \"40.68.215.206/32\",\r\n - \ \"40.68.220.16/32\",\r\n \"40.69.104.0/27\",\r\n \"40.69.105.0/27\",\r\n - \ \"40.69.132.90/32\",\r\n \"40.69.143.202/32\",\r\n \"40.69.169.120/32\",\r\n - \ \"40.69.189.48/32\",\r\n \"40.70.144.0/26\",\r\n \"40.70.145.0/26\",\r\n - \ \"40.71.8.0/26\",\r\n \"40.71.8.192/26\",\r\n \"40.71.9.0/26\",\r\n - \ \"40.71.9.192/26\",\r\n \"40.71.196.33/32\",\r\n \"40.71.211.227/32\",\r\n - \ \"40.71.226.18/32\",\r\n \"40.74.51.145/32\",\r\n \"40.74.53.36/32\",\r\n - \ \"40.74.60.91/32\",\r\n \"40.74.96.0/27\",\r\n \"40.74.97.0/27\",\r\n - \ \"40.74.114.22/32\",\r\n \"40.74.115.153/32\",\r\n \"40.74.135.185/32\",\r\n - \ \"40.74.144.0/27\",\r\n \"40.74.145.0/27\",\r\n \"40.74.254.156/32\",\r\n - \ \"40.75.32.0/27\",\r\n \"40.75.33.0/27\",\r\n \"40.76.2.172/32\",\r\n - \ \"40.76.26.90/32\",\r\n \"40.76.42.44/32\",\r\n \"40.76.65.222/32\",\r\n - \ \"40.76.66.9/32\",\r\n \"40.76.193.221/32\",\r\n \"40.76.209.171/32\",\r\n - \ \"40.76.219.185/32\",\r\n \"40.77.30.201/32\",\r\n \"40.78.16.122/32\",\r\n - \ \"40.78.23.252/32\",\r\n \"40.78.31.250/32\",\r\n \"40.78.57.109/32\",\r\n - \ \"40.78.101.91/32\",\r\n \"40.78.110.18/32\",\r\n \"40.78.111.189/32\",\r\n - \ \"40.78.192.0/27\",\r\n \"40.78.193.0/27\",\r\n \"40.78.224.0/26\",\r\n - \ \"40.78.224.128/26\",\r\n \"40.78.225.0/26\",\r\n \"40.78.225.128/26\",\r\n - \ \"40.78.232.0/26\",\r\n \"40.78.233.0/26\",\r\n \"40.78.240.0/26\",\r\n - \ \"40.78.241.0/26\",\r\n \"40.78.248.0/26\",\r\n \"40.78.249.0/26\",\r\n - \ \"40.79.84.180/32\",\r\n \"40.79.128.0/27\",\r\n \"40.79.129.0/27\",\r\n - \ \"40.79.136.0/27\",\r\n \"40.79.137.0/27\",\r\n \"40.79.144.0/27\",\r\n - \ \"40.79.145.0/27\",\r\n \"40.79.152.0/26\",\r\n \"40.79.152.192/26\",\r\n - \ \"40.79.153.0/26\",\r\n \"40.79.153.192/26\",\r\n \"40.79.160.0/27\",\r\n - \ \"40.79.161.0/27\",\r\n \"40.79.168.0/27\",\r\n \"40.79.169.0/27\",\r\n - \ \"40.79.176.0/27\",\r\n \"40.79.177.0/27\",\r\n \"40.79.184.0/27\",\r\n - \ \"40.79.185.0/27\",\r\n \"40.79.192.0/27\",\r\n \"40.79.193.0/27\",\r\n - \ \"40.80.48.0/27\",\r\n \"40.80.49.0/27\",\r\n \"40.83.178.165/32\",\r\n - \ \"40.83.186.249/32\",\r\n \"40.84.5.64/32\",\r\n \"40.84.54.249/32\",\r\n - \ \"40.84.153.95/32\",\r\n \"40.84.155.210/32\",\r\n \"40.84.156.165/32\",\r\n - \ \"40.84.191.1/32\",\r\n \"40.84.193.16/32\",\r\n \"40.84.195.189/32\",\r\n - \ \"40.84.231.203/32\",\r\n \"40.85.102.50/32\",\r\n \"40.85.224.249/32\",\r\n - \ \"40.85.225.5/32\",\r\n \"40.86.75.134/32\",\r\n \"40.86.226.166/32\",\r\n - \ \"40.86.226.230/32\",\r\n \"40.112.139.250/32\",\r\n \"40.112.240.0/27\",\r\n - \ \"40.112.246.0/27\",\r\n \"40.113.14.53/32\",\r\n \"40.113.16.190/32\",\r\n - \ \"40.113.17.148/32\",\r\n \"40.113.20.38/32\",\r\n \"40.113.93.91/32\",\r\n - \ \"40.113.200.119/32\",\r\n \"40.114.40.118/32\",\r\n \"40.114.43.106/32\",\r\n - \ \"40.114.45.195/32\",\r\n \"40.114.46.128/32\",\r\n \"40.114.46.212/32\",\r\n - \ \"40.114.81.142/32\",\r\n \"40.114.240.125/32\",\r\n \"40.114.240.162/32\",\r\n - \ \"40.115.37.61/32\",\r\n \"40.115.51.118/32\",\r\n \"40.115.52.141/32\",\r\n - \ \"40.115.53.255/32\",\r\n \"40.115.61.208/32\",\r\n \"40.117.42.73/32\",\r\n - \ \"40.117.44.71/32\",\r\n \"40.117.90.115/32\",\r\n \"40.117.97.189/32\",\r\n - \ \"40.118.12.208/32\",\r\n \"40.118.129.167/32\",\r\n \"40.118.170.1/32\",\r\n - \ \"40.118.209.206/32\",\r\n \"40.118.244.227/32\",\r\n \"40.118.249.123/32\",\r\n - \ \"40.118.250.19/32\",\r\n \"40.120.72.0/27\",\r\n \"40.120.73.0/27\",\r\n - \ \"40.121.143.204/32\",\r\n \"40.121.149.49/32\",\r\n \"40.121.154.241/32\",\r\n - \ \"40.121.158.30/32\",\r\n \"40.122.205.105/32\",\r\n \"40.122.215.111/32\",\r\n - \ \"40.124.8.76/32\",\r\n \"40.126.228.153/32\",\r\n \"40.126.230.223/32\",\r\n - \ \"40.126.232.113/32\",\r\n \"40.126.233.152/32\",\r\n \"40.126.250.24/32\",\r\n - \ \"40.127.82.69/32\",\r\n \"40.127.83.164/32\",\r\n \"40.127.128.10/32\",\r\n - \ \"40.127.135.67/32\",\r\n \"40.127.137.209/32\",\r\n \"40.127.141.194/32\",\r\n - \ \"40.127.177.139/32\",\r\n \"40.127.190.50/32\",\r\n \"51.12.96.0/27\",\r\n - \ \"51.12.97.0/27\",\r\n \"51.12.200.0/27\",\r\n \"51.12.201.0/27\",\r\n - \ \"51.12.224.0/27\",\r\n \"51.12.225.0/27\",\r\n \"51.12.232.0/27\",\r\n - \ \"51.12.233.0/27\",\r\n \"51.105.64.0/27\",\r\n \"51.105.65.0/27\",\r\n - \ \"51.105.72.0/27\",\r\n \"51.105.73.0/27\",\r\n \"51.107.56.0/27\",\r\n - \ \"51.107.57.0/27\",\r\n \"51.107.152.0/27\",\r\n \"51.107.153.0/27\",\r\n - \ \"51.116.56.0/27\",\r\n \"51.116.57.0/27\",\r\n \"51.116.152.0/27\",\r\n - \ \"51.116.153.0/27\",\r\n \"51.116.240.0/27\",\r\n \"51.116.241.0/27\",\r\n - \ \"51.116.248.0/27\",\r\n \"51.116.249.0/27\",\r\n \"51.120.96.0/27\",\r\n - \ \"51.120.97.0/27\",\r\n \"51.120.104.0/27\",\r\n \"51.120.105.0/27\",\r\n - \ \"51.120.208.0/27\",\r\n \"51.120.209.0/27\",\r\n \"51.120.216.0/27\",\r\n - \ \"51.120.217.0/27\",\r\n \"51.140.77.9/32\",\r\n \"51.140.114.26/32\",\r\n - \ \"51.140.115.150/32\",\r\n \"51.140.144.0/27\",\r\n \"51.140.145.0/27\",\r\n - \ \"51.140.180.9/32\",\r\n \"51.140.183.238/32\",\r\n \"51.140.184.11/32\",\r\n - \ \"51.140.184.12/32\",\r\n \"51.140.208.64/27\",\r\n \"51.140.209.0/27\",\r\n - \ \"51.141.8.11/32\",\r\n \"51.141.8.12/32\",\r\n \"51.141.15.53/32\",\r\n - \ \"51.141.25.212/32\",\r\n \"51.142.211.129/32\",\r\n \"52.138.88.0/27\",\r\n - \ \"52.138.89.0/27\",\r\n \"52.138.224.0/26\",\r\n \"52.138.224.128/26\",\r\n - \ \"52.138.225.0/26\",\r\n \"52.138.225.128/26\",\r\n \"52.161.15.204/32\",\r\n - \ \"52.161.100.158/32\",\r\n \"52.161.105.228/32\",\r\n \"52.161.128.32/27\",\r\n - \ \"52.162.104.0/26\",\r\n \"52.162.105.0/26\",\r\n \"52.162.125.1/32\",\r\n - \ \"52.162.241.250/32\",\r\n \"52.165.184.67/32\",\r\n \"52.166.76.0/32\",\r\n - \ \"52.166.131.195/32\",\r\n \"52.167.104.0/26\",\r\n \"52.167.105.0/26\",\r\n - \ \"52.167.117.226/32\",\r\n \"52.168.166.153/32\",\r\n \"52.168.169.124/32\",\r\n - \ \"52.168.183.223/32\",\r\n \"52.170.41.199/32\",\r\n \"52.170.97.16/32\",\r\n - \ \"52.170.98.29/32\",\r\n \"52.171.56.10/32\",\r\n \"52.172.24.47/32\",\r\n - \ \"52.172.43.208/32\",\r\n \"52.172.217.233/32\",\r\n \"52.172.221.154/32\",\r\n - \ \"52.173.205.59/32\",\r\n \"52.175.33.150/32\",\r\n \"52.176.43.167/32\",\r\n - \ \"52.176.59.12/32\",\r\n \"52.176.95.237/32\",\r\n \"52.176.100.98/32\",\r\n - \ \"52.177.185.181/32\",\r\n \"52.177.197.103/32\",\r\n \"52.177.200.215/32\",\r\n - \ \"52.179.16.95/32\",\r\n \"52.179.157.248/32\",\r\n \"52.179.165.160/32\",\r\n - \ \"52.179.167.70/32\",\r\n \"52.179.178.184/32\",\r\n \"52.180.176.154/31\",\r\n - \ \"52.180.183.226/32\",\r\n \"52.182.136.0/26\",\r\n \"52.182.137.0/26\",\r\n - \ \"52.183.250.62/32\",\r\n \"52.184.192.175/32\",\r\n \"52.184.231.0/32\",\r\n - \ \"52.185.152.149/32\",\r\n \"52.187.15.214/32\",\r\n \"52.187.76.130/32\",\r\n - \ \"52.191.144.64/26\",\r\n \"52.191.152.64/26\",\r\n \"52.191.172.187/32\",\r\n - \ \"52.191.174.114/32\",\r\n \"52.225.188.46/32\",\r\n \"52.225.188.113/32\",\r\n - \ \"52.225.222.124/32\",\r\n \"52.228.24.103/32\",\r\n \"52.228.35.221/32\",\r\n - \ \"52.228.39.117/32\",\r\n \"52.229.17.93/32\",\r\n \"52.229.122.195/32\",\r\n - \ \"52.229.123.147/32\",\r\n \"52.229.124.23/32\",\r\n \"52.231.16.0/27\",\r\n - \ \"52.231.17.0/27\",\r\n \"52.231.32.42/31\",\r\n \"52.231.39.56/32\",\r\n - \ \"52.231.144.0/27\",\r\n \"52.231.145.0/27\",\r\n \"52.231.200.86/31\",\r\n - \ \"52.231.206.133/32\",\r\n \"52.236.184.0/27\",\r\n \"52.236.184.128/25\",\r\n - \ \"52.236.185.0/27\",\r\n \"52.236.185.128/25\",\r\n \"52.237.28.86/32\",\r\n - \ \"52.237.219.227/32\",\r\n \"52.242.26.53/32\",\r\n \"52.242.29.91/32\",\r\n - \ \"52.242.30.154/32\",\r\n \"52.242.36.107/32\",\r\n \"52.243.32.19/32\",\r\n - \ \"52.243.43.186/32\",\r\n \"52.246.152.0/27\",\r\n \"52.246.153.0/27\",\r\n - \ \"52.246.251.248/32\",\r\n \"52.255.48.161/32\",\r\n \"65.52.208.91/32\",\r\n - \ \"65.52.213.108/32\",\r\n \"65.52.214.127/32\",\r\n \"65.52.218.82/32\",\r\n - \ \"65.52.225.245/32\",\r\n \"65.52.226.209/32\",\r\n \"65.52.248.0/27\",\r\n - \ \"65.52.249.0/27\",\r\n \"102.133.24.0/27\",\r\n \"102.133.25.0/27\",\r\n - \ \"102.133.120.0/27\",\r\n \"102.133.121.0/27\",\r\n \"102.133.152.0/27\",\r\n - \ \"102.133.153.0/27\",\r\n \"102.133.248.0/27\",\r\n \"102.133.249.0/27\",\r\n - \ \"104.40.28.188/32\",\r\n \"104.40.49.103/32\",\r\n \"104.40.54.130/32\",\r\n - \ \"104.40.82.151/32\",\r\n \"104.40.155.247/32\",\r\n \"104.40.168.64/26\",\r\n - \ \"104.40.168.192/26\",\r\n \"104.40.169.0/27\",\r\n \"104.40.169.128/25\",\r\n - \ \"104.40.180.164/32\",\r\n \"104.40.220.28/32\",\r\n \"104.40.230.18/32\",\r\n - \ \"104.40.232.54/32\",\r\n \"104.40.237.111/32\",\r\n \"104.41.11.5/32\",\r\n - \ \"104.41.13.213/32\",\r\n \"104.41.13.233/32\",\r\n \"104.41.36.39/32\",\r\n - \ \"104.41.56.218/32\",\r\n \"104.41.57.82/32\",\r\n \"104.41.59.170/32\",\r\n - \ \"104.41.150.1/32\",\r\n \"104.41.152.74/32\",\r\n \"104.41.168.103/32\",\r\n - \ \"104.41.169.34/32\",\r\n \"104.41.202.30/32\",\r\n \"104.41.205.195/32\",\r\n - \ \"104.41.208.104/32\",\r\n \"104.41.210.68/32\",\r\n \"104.41.211.98/32\",\r\n - \ \"104.42.120.235/32\",\r\n \"104.42.127.95/32\",\r\n \"104.42.136.93/32\",\r\n - \ \"104.42.188.130/32\",\r\n \"104.42.192.190/32\",\r\n \"104.42.199.221/32\",\r\n - \ \"104.42.231.253/32\",\r\n \"104.42.237.198/32\",\r\n \"104.42.238.205/32\",\r\n - \ \"104.43.10.74/32\",\r\n \"104.43.15.0/32\",\r\n \"104.43.164.21/32\",\r\n - \ \"104.43.164.247/32\",\r\n \"104.43.203.72/32\",\r\n \"104.45.11.99/32\",\r\n - \ \"104.45.14.115/32\",\r\n \"104.45.158.30/32\",\r\n \"104.46.38.143/32\",\r\n - \ \"104.46.40.24/32\",\r\n \"104.46.100.189/32\",\r\n \"104.46.108.148/32\",\r\n - \ \"104.47.157.97/32\",\r\n \"104.208.21.0/26\",\r\n \"104.208.22.0/26\",\r\n - \ \"104.208.28.16/32\",\r\n \"104.208.28.53/32\",\r\n \"104.208.149.0/26\",\r\n - \ \"104.208.150.0/26\",\r\n \"104.208.161.78/32\",\r\n \"104.208.163.201/32\",\r\n - \ \"104.208.233.240/32\",\r\n \"104.208.238.55/32\",\r\n - \ \"104.208.241.224/32\",\r\n \"104.209.186.94/32\",\r\n - \ \"104.210.32.128/32\",\r\n \"104.210.105.215/32\",\r\n - \ \"104.211.85.0/27\",\r\n \"104.211.86.0/27\",\r\n \"104.211.96.159/32\",\r\n - \ \"104.211.96.160/32\",\r\n \"104.211.144.0/27\",\r\n \"104.211.145.0/27\",\r\n - \ \"104.211.160.80/31\",\r\n \"104.211.185.58/32\",\r\n \"104.211.190.46/32\",\r\n - \ \"104.211.224.146/31\",\r\n \"104.214.16.0/26\",\r\n \"104.214.16.192/26\",\r\n - \ \"104.214.17.0/26\",\r\n \"104.214.17.192/26\",\r\n \"104.214.67.25/32\",\r\n - \ \"104.214.73.137/32\",\r\n \"104.214.78.242/32\",\r\n \"104.214.148.156/32\",\r\n - \ \"104.214.150.17/32\",\r\n \"104.215.195.14/32\",\r\n \"104.215.196.52/32\",\r\n - \ \"111.221.106.161/32\",\r\n \"137.116.31.224/27\",\r\n - \ \"137.116.129.110/32\",\r\n \"137.116.203.91/32\",\r\n - \ \"137.135.51.212/32\",\r\n \"137.135.109.63/32\",\r\n \"137.135.186.126/32\",\r\n - \ \"137.135.189.158/32\",\r\n \"137.135.205.85/32\",\r\n - \ \"137.135.213.9/32\",\r\n \"138.91.48.99/32\",\r\n \"138.91.58.227/32\",\r\n - \ \"138.91.145.12/32\",\r\n \"138.91.160.189/32\",\r\n \"138.91.240.14/32\",\r\n - \ \"138.91.246.31/32\",\r\n \"138.91.247.51/32\",\r\n \"138.91.251.139/32\",\r\n - \ \"157.55.208.150/32\",\r\n \"168.61.136.0/27\",\r\n \"168.61.137.0/27\",\r\n - \ \"168.62.115.112/28\",\r\n \"168.62.232.188/32\",\r\n \"168.62.235.49/32\",\r\n - \ \"168.62.235.241/32\",\r\n \"168.62.239.29/32\",\r\n \"168.63.13.214/32\",\r\n - \ \"168.63.98.91/32\",\r\n \"168.63.175.68/32\",\r\n \"191.233.48.0/27\",\r\n - \ \"191.233.49.0/27\",\r\n \"191.233.69.227/32\",\r\n \"191.233.90.117/32\",\r\n - \ \"191.233.200.0/27\",\r\n \"191.233.201.0/27\",\r\n \"191.234.2.139/32\",\r\n - \ \"191.234.2.140/31\",\r\n \"191.234.2.142/32\",\r\n \"191.234.144.0/27\",\r\n - \ \"191.234.145.0/27\",\r\n \"191.234.152.0/27\",\r\n \"191.234.153.0/27\",\r\n - \ \"191.235.170.58/32\",\r\n \"191.235.193.75/32\",\r\n \"191.235.193.76/31\",\r\n - \ \"191.235.193.78/32\",\r\n \"191.235.193.139/32\",\r\n - \ \"191.235.193.140/31\",\r\n \"191.235.209.79/32\",\r\n - \ \"191.236.119.31/32\",\r\n \"191.236.148.44/32\",\r\n \"191.236.153.120/32\",\r\n - \ \"191.237.20.112/32\",\r\n \"191.237.82.74/32\",\r\n \"191.237.219.202/32\",\r\n - \ \"191.237.232.75/32\",\r\n \"191.237.232.76/31\",\r\n \"191.237.232.78/32\",\r\n - \ \"191.237.232.235/32\",\r\n \"191.237.232.236/31\",\r\n - \ \"191.237.240.43/32\",\r\n \"191.237.240.44/32\",\r\n \"191.237.240.46/32\",\r\n - \ \"191.238.6.43/32\",\r\n \"191.238.6.44/31\",\r\n \"191.238.6.46/32\",\r\n - \ \"191.238.68.11/32\",\r\n \"191.238.68.12/31\",\r\n \"191.238.68.14/32\",\r\n - \ \"191.238.224.203/32\",\r\n \"191.238.230.40/32\",\r\n - \ \"191.239.12.154/32\",\r\n \"191.239.189.48/32\",\r\n \"191.239.192.109/32\",\r\n - \ \"191.239.224.107/32\",\r\n \"191.239.224.108/31\",\r\n - \ \"191.239.224.110/32\",\r\n \"207.46.139.82/32\",\r\n \"207.46.140.180/32\",\r\n - \ \"207.46.153.182/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.AustraliaCentral\",\r\n \"id\": \"Sql.AustraliaCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"20.36.104.0/27\",\r\n - \ \"20.36.105.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.AustraliaCentral2\",\r\n \"id\": \"Sql.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.112.0/27\",\r\n \"20.36.113.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.AustraliaEast\",\r\n - \ \"id\": \"Sql.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.70.112.0/27\",\r\n \"13.70.113.0/27\",\r\n \"13.75.149.87/32\",\r\n - \ \"40.79.160.0/27\",\r\n \"40.79.161.0/27\",\r\n \"40.79.168.0/27\",\r\n - \ \"40.79.169.0/27\",\r\n \"40.126.228.153/32\",\r\n \"40.126.230.223/32\",\r\n - \ \"40.126.232.113/32\",\r\n \"40.126.233.152/32\",\r\n \"40.126.250.24/32\",\r\n - \ \"52.237.219.227/32\",\r\n \"104.210.105.215/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.AustraliaSoutheast\",\r\n - \ \"id\": \"Sql.AustraliaSoutheast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiasoutheast\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n - \ \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n - \ \"13.70.148.251/32\",\r\n \"13.70.155.163/32\",\r\n \"13.73.109.251/32\",\r\n - \ \"13.77.7.78/32\",\r\n \"13.77.48.0/27\",\r\n \"13.77.49.0/27\",\r\n - \ \"40.127.82.69/32\",\r\n \"40.127.83.164/32\",\r\n \"52.255.48.161/32\",\r\n - \ \"191.239.189.48/32\",\r\n \"191.239.192.109/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.BrazilSouth\",\r\n \"id\": - \"Sql.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"104.41.11.5/32\",\r\n - \ \"104.41.13.213/32\",\r\n \"104.41.13.233/32\",\r\n \"104.41.36.39/32\",\r\n - \ \"104.41.56.218/32\",\r\n \"104.41.57.82/32\",\r\n \"104.41.59.170/32\",\r\n - \ \"191.233.200.0/27\",\r\n \"191.233.201.0/27\",\r\n \"191.234.144.0/27\",\r\n - \ \"191.234.145.0/27\",\r\n \"191.234.152.0/27\",\r\n \"191.234.153.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.CanadaCentral\",\r\n - \ \"id\": \"Sql.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.71.168.0/27\",\r\n \"13.71.169.0/27\",\r\n \"13.88.249.189/32\",\r\n - \ \"13.88.254.42/32\",\r\n \"20.38.144.0/27\",\r\n \"20.38.145.0/27\",\r\n - \ \"40.85.224.249/32\",\r\n \"40.85.225.5/32\",\r\n \"52.228.24.103/32\",\r\n - \ \"52.228.35.221/32\",\r\n \"52.228.39.117/32\",\r\n \"52.237.28.86/32\",\r\n - \ \"52.246.152.0/27\",\r\n \"52.246.153.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.CanadaEast\",\r\n \"id\": - \"Sql.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"40.69.104.0/27\",\r\n \"40.69.105.0/27\",\r\n \"40.86.226.166/32\",\r\n - \ \"40.86.226.230/32\",\r\n \"52.229.122.195/32\",\r\n \"52.229.123.147/32\",\r\n - \ \"52.229.124.23/32\",\r\n \"52.242.26.53/32\",\r\n \"52.242.29.91/32\",\r\n - \ \"52.242.30.154/32\",\r\n \"52.242.36.107/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.CentralIndia\",\r\n \"id\": - \"Sql.CentralIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"20.192.96.0/27\",\r\n \"20.192.97.0/27\",\r\n \"40.80.48.0/27\",\r\n - \ \"40.80.49.0/27\",\r\n \"52.172.217.233/32\",\r\n \"52.172.221.154/32\",\r\n - \ \"104.211.85.0/27\",\r\n \"104.211.86.0/27\",\r\n \"104.211.96.159/32\",\r\n - \ \"104.211.96.160/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.CentralUS\",\r\n \"id\": \"Sql.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.67.215.62/32\",\r\n - \ \"13.89.36.110/32\",\r\n \"13.89.37.61/32\",\r\n \"13.89.57.50/32\",\r\n - \ \"13.89.57.115/32\",\r\n \"13.89.168.0/26\",\r\n \"13.89.169.0/26\",\r\n - \ \"23.99.160.139/32\",\r\n \"23.99.160.140/31\",\r\n \"23.99.160.142/32\",\r\n - \ \"23.99.205.183/32\",\r\n \"40.69.132.90/32\",\r\n \"40.69.143.202/32\",\r\n - \ \"40.69.169.120/32\",\r\n \"40.69.189.48/32\",\r\n \"40.77.30.201/32\",\r\n - \ \"40.86.75.134/32\",\r\n \"40.113.200.119/32\",\r\n \"40.122.205.105/32\",\r\n - \ \"40.122.215.111/32\",\r\n \"52.165.184.67/32\",\r\n \"52.173.205.59/32\",\r\n - \ \"52.176.43.167/32\",\r\n \"52.176.59.12/32\",\r\n \"52.176.95.237/32\",\r\n - \ \"52.176.100.98/32\",\r\n \"52.182.136.0/26\",\r\n \"52.182.137.0/26\",\r\n - \ \"104.43.164.21/32\",\r\n \"104.43.164.247/32\",\r\n \"104.43.203.72/32\",\r\n - \ \"104.208.21.0/26\",\r\n \"104.208.22.0/26\",\r\n \"104.208.28.16/32\",\r\n - \ \"104.208.28.53/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.CentralUSEUAP\",\r\n \"id\": \"Sql.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"52.180.176.154/31\",\r\n - \ \"52.180.183.226/32\",\r\n \"168.61.136.0/27\",\r\n \"168.61.137.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.EastAsia\",\r\n - \ \"id\": \"Sql.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.75.32.0/26\",\r\n \"13.75.33.0/26\",\r\n \"13.75.105.141/32\",\r\n - \ \"13.75.106.191/32\",\r\n \"13.75.108.188/32\",\r\n \"23.97.68.51/32\",\r\n - \ \"23.97.74.21/32\",\r\n \"23.97.78.163/32\",\r\n \"23.99.102.124/32\",\r\n - \ \"23.99.118.196/32\",\r\n \"52.175.33.150/32\",\r\n \"191.234.2.139/32\",\r\n - \ \"191.234.2.140/31\",\r\n \"191.234.2.142/32\",\r\n \"207.46.139.82/32\",\r\n - \ \"207.46.140.180/32\",\r\n \"207.46.153.182/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.EastUS\",\r\n \"id\": - \"Sql.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"23.96.89.109/32\",\r\n - \ \"23.96.106.191/32\",\r\n \"40.71.8.0/26\",\r\n \"40.71.8.192/26\",\r\n - \ \"40.71.9.0/26\",\r\n \"40.71.9.192/26\",\r\n \"40.71.196.33/32\",\r\n - \ \"40.71.211.227/32\",\r\n \"40.71.226.18/32\",\r\n \"40.76.2.172/32\",\r\n - \ \"40.76.26.90/32\",\r\n \"40.76.42.44/32\",\r\n \"40.76.65.222/32\",\r\n - \ \"40.76.66.9/32\",\r\n \"40.76.193.221/32\",\r\n \"40.76.209.171/32\",\r\n - \ \"40.76.219.185/32\",\r\n \"40.78.224.0/26\",\r\n \"40.78.224.128/26\",\r\n - \ \"40.78.225.0/26\",\r\n \"40.78.225.128/26\",\r\n \"40.79.152.0/26\",\r\n - \ \"40.79.152.192/26\",\r\n \"40.79.153.0/26\",\r\n \"40.79.153.192/26\",\r\n - \ \"40.114.40.118/32\",\r\n \"40.114.43.106/32\",\r\n \"40.114.45.195/32\",\r\n - \ \"40.114.46.128/32\",\r\n \"40.114.46.212/32\",\r\n \"40.114.81.142/32\",\r\n - \ \"40.117.42.73/32\",\r\n \"40.117.44.71/32\",\r\n \"40.117.90.115/32\",\r\n - \ \"40.117.97.189/32\",\r\n \"40.121.143.204/32\",\r\n \"40.121.149.49/32\",\r\n - \ \"40.121.154.241/32\",\r\n \"40.121.158.30/32\",\r\n \"52.168.166.153/32\",\r\n - \ \"52.168.169.124/32\",\r\n \"52.168.183.223/32\",\r\n \"52.170.41.199/32\",\r\n - \ \"52.170.97.16/32\",\r\n \"52.170.98.29/32\",\r\n \"52.179.16.95/32\",\r\n - \ \"104.41.150.1/32\",\r\n \"104.41.152.74/32\",\r\n \"104.45.158.30/32\",\r\n - \ \"137.135.109.63/32\",\r\n \"191.237.20.112/32\",\r\n \"191.237.82.74/32\",\r\n - \ \"191.238.6.43/32\",\r\n \"191.238.6.44/31\",\r\n \"191.238.6.46/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.EastUS2\",\r\n - \ \"id\": \"Sql.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.68.22.44/32\",\r\n \"13.68.30.216/32\",\r\n \"13.68.87.133/32\",\r\n - \ \"23.102.206.35/32\",\r\n \"23.102.206.36/31\",\r\n \"40.70.144.0/26\",\r\n - \ \"40.70.145.0/26\",\r\n \"40.79.84.180/32\",\r\n \"40.84.5.64/32\",\r\n - \ \"40.84.54.249/32\",\r\n \"52.167.104.0/26\",\r\n \"52.167.105.0/26\",\r\n - \ \"52.167.117.226/32\",\r\n \"52.177.185.181/32\",\r\n \"52.177.197.103/32\",\r\n - \ \"52.177.200.215/32\",\r\n \"52.179.157.248/32\",\r\n \"52.179.165.160/32\",\r\n - \ \"52.179.167.70/32\",\r\n \"52.179.178.184/32\",\r\n \"52.184.192.175/32\",\r\n - \ \"52.184.231.0/32\",\r\n \"52.225.222.124/32\",\r\n \"104.46.100.189/32\",\r\n - \ \"104.46.108.148/32\",\r\n \"104.208.149.0/26\",\r\n \"104.208.150.0/26\",\r\n - \ \"104.208.161.78/32\",\r\n \"104.208.163.201/32\",\r\n - \ \"104.208.233.240/32\",\r\n \"104.208.238.55/32\",\r\n - \ \"104.208.241.224/32\",\r\n \"104.209.186.94/32\",\r\n - \ \"191.239.224.107/32\",\r\n \"191.239.224.108/31\",\r\n - \ \"191.239.224.110/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.EastUS2EUAP\",\r\n \"id\": \"Sql.EastUS2EUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"40.74.144.0/27\",\r\n - \ \"40.74.145.0/27\",\r\n \"40.75.32.0/27\",\r\n \"40.75.33.0/27\",\r\n - \ \"52.138.88.0/27\",\r\n \"52.138.89.0/27\",\r\n \"52.225.188.46/32\",\r\n - \ \"52.225.188.113/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.EastUS2Stage\",\r\n \"id\": \"Sql.EastUS2Stage\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"137.116.31.224/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.FranceCentral\",\r\n - \ \"id\": \"Sql.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"40.79.128.0/27\",\r\n \"40.79.129.0/27\",\r\n \"40.79.136.0/27\",\r\n - \ \"40.79.137.0/27\",\r\n \"40.79.144.0/27\",\r\n \"40.79.145.0/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.FranceSouth\",\r\n - \ \"id\": \"Sql.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"40.79.176.0/27\",\r\n \"40.79.177.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.GermanyNorth\",\r\n \"id\": - \"Sql.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"51.116.56.0/27\",\r\n \"51.116.57.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.GermanyWestCentral\",\r\n - \ \"id\": \"Sql.GermanyWestCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"51.116.152.0/27\",\r\n \"51.116.153.0/27\",\r\n - \ \"51.116.240.0/27\",\r\n \"51.116.241.0/27\",\r\n \"51.116.248.0/27\",\r\n - \ \"51.116.249.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.JapanEast\",\r\n \"id\": \"Sql.JapanEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.78.61.196/32\",\r\n - \ \"13.78.104.0/27\",\r\n \"13.78.105.0/27\",\r\n \"13.78.121.203/32\",\r\n - \ \"23.102.69.95/32\",\r\n \"23.102.71.13/32\",\r\n \"23.102.74.190/32\",\r\n - \ \"40.79.184.0/27\",\r\n \"40.79.185.0/27\",\r\n \"40.79.192.0/27\",\r\n - \ \"40.79.193.0/27\",\r\n \"52.185.152.149/32\",\r\n \"52.243.32.19/32\",\r\n - \ \"52.243.43.186/32\",\r\n \"104.41.168.103/32\",\r\n \"104.41.169.34/32\",\r\n - \ \"191.237.240.43/32\",\r\n \"191.237.240.44/32\",\r\n \"191.237.240.46/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.JapanWest\",\r\n - \ \"id\": \"Sql.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"40.74.96.0/27\",\r\n - \ \"40.74.97.0/27\",\r\n \"40.74.114.22/32\",\r\n \"40.74.115.153/32\",\r\n - \ \"40.74.135.185/32\",\r\n \"104.214.148.156/32\",\r\n \"104.214.150.17/32\",\r\n - \ \"191.238.68.11/32\",\r\n \"191.238.68.12/31\",\r\n \"191.238.68.14/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.KoreaCentral\",\r\n - \ \"id\": \"Sql.KoreaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"20.44.24.0/27\",\r\n - \ \"20.44.25.0/27\",\r\n \"20.194.64.0/27\",\r\n \"20.194.65.0/27\",\r\n - \ \"52.231.16.0/27\",\r\n \"52.231.17.0/27\",\r\n \"52.231.32.42/31\",\r\n - \ \"52.231.39.56/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.KoreaSouth\",\r\n \"id\": \"Sql.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"52.231.144.0/27\",\r\n - \ \"52.231.145.0/27\",\r\n \"52.231.200.86/31\",\r\n \"52.231.206.133/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.NorthCentralUS\",\r\n - \ \"id\": \"Sql.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"23.96.178.199/32\",\r\n \"23.96.202.229/32\",\r\n - \ \"23.96.204.249/32\",\r\n \"23.96.205.215/32\",\r\n \"23.96.214.69/32\",\r\n - \ \"23.96.243.243/32\",\r\n \"23.96.247.75/32\",\r\n \"23.96.249.37/32\",\r\n - \ \"23.96.250.178/32\",\r\n \"23.98.55.75/32\",\r\n \"23.101.165.167/32\",\r\n - \ \"23.101.167.45/32\",\r\n \"23.101.170.98/32\",\r\n \"52.162.104.0/26\",\r\n - \ \"52.162.105.0/26\",\r\n \"52.162.125.1/32\",\r\n \"52.162.241.250/32\",\r\n - \ \"65.52.208.91/32\",\r\n \"65.52.213.108/32\",\r\n \"65.52.214.127/32\",\r\n - \ \"65.52.218.82/32\",\r\n \"157.55.208.150/32\",\r\n \"168.62.232.188/32\",\r\n - \ \"168.62.235.49/32\",\r\n \"168.62.235.241/32\",\r\n \"168.62.239.29/32\",\r\n - \ \"191.236.148.44/32\",\r\n \"191.236.153.120/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.NorthCentralUSStage\",\r\n - \ \"id\": \"Sql.NorthCentralUSStage\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"168.62.115.112/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.NorthEurope\",\r\n \"id\": - \"Sql.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.69.224.0/26\",\r\n \"13.69.224.192/26\",\r\n - \ \"13.69.225.0/26\",\r\n \"13.69.225.192/26\",\r\n \"13.74.104.64/26\",\r\n - \ \"13.74.104.128/26\",\r\n \"13.74.105.0/26\",\r\n \"13.74.105.128/26\",\r\n - \ \"23.102.16.130/32\",\r\n \"23.102.23.219/32\",\r\n \"23.102.25.199/32\",\r\n - \ \"23.102.52.155/32\",\r\n \"23.102.57.142/32\",\r\n \"23.102.62.171/32\",\r\n - \ \"40.85.102.50/32\",\r\n \"40.113.14.53/32\",\r\n \"40.113.16.190/32\",\r\n - \ \"40.113.17.148/32\",\r\n \"40.113.20.38/32\",\r\n \"40.113.93.91/32\",\r\n - \ \"40.127.128.10/32\",\r\n \"40.127.135.67/32\",\r\n \"40.127.137.209/32\",\r\n - \ \"40.127.141.194/32\",\r\n \"40.127.177.139/32\",\r\n \"40.127.190.50/32\",\r\n - \ \"52.138.224.0/26\",\r\n \"52.138.224.128/26\",\r\n \"52.138.225.0/26\",\r\n - \ \"52.138.225.128/26\",\r\n \"65.52.225.245/32\",\r\n \"65.52.226.209/32\",\r\n - \ \"104.41.202.30/32\",\r\n \"104.41.205.195/32\",\r\n \"104.41.208.104/32\",\r\n - \ \"104.41.210.68/32\",\r\n \"104.41.211.98/32\",\r\n \"137.135.186.126/32\",\r\n - \ \"137.135.189.158/32\",\r\n \"137.135.205.85/32\",\r\n - \ \"137.135.213.9/32\",\r\n \"138.91.48.99/32\",\r\n \"138.91.58.227/32\",\r\n - \ \"191.235.170.58/32\",\r\n \"191.235.193.75/32\",\r\n \"191.235.193.76/31\",\r\n - \ \"191.235.193.78/32\",\r\n \"191.235.193.139/32\",\r\n - \ \"191.235.193.140/31\",\r\n \"191.235.209.79/32\",\r\n - \ \"191.237.219.202/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.NorwayEast\",\r\n \"id\": \"Sql.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.120.96.0/27\",\r\n - \ \"51.120.97.0/27\",\r\n \"51.120.104.0/27\",\r\n \"51.120.105.0/27\",\r\n - \ \"51.120.208.0/27\",\r\n \"51.120.209.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.NorwayWest\",\r\n \"id\": - \"Sql.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"51.120.216.0/27\",\r\n \"51.120.217.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.SouthAfricaNorth\",\r\n - \ \"id\": \"Sql.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"102.133.120.0/27\",\r\n \"102.133.121.0/27\",\r\n - \ \"102.133.152.0/27\",\r\n \"102.133.153.0/27\",\r\n \"102.133.248.0/27\",\r\n - \ \"102.133.249.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.SouthAfricaWest\",\r\n \"id\": \"Sql.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"102.133.24.0/27\",\r\n - \ \"102.133.25.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.SouthCentralUS\",\r\n \"id\": \"Sql.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.65.31.249/32\",\r\n - \ \"13.65.39.207/32\",\r\n \"13.65.85.183/32\",\r\n \"13.65.200.105/32\",\r\n - \ \"13.65.209.243/32\",\r\n \"13.65.253.67/32\",\r\n \"13.66.60.72/32\",\r\n - \ \"13.66.60.111/32\",\r\n \"13.66.62.124/32\",\r\n \"13.84.223.76/32\",\r\n - \ \"13.85.65.48/32\",\r\n \"13.85.68.115/32\",\r\n \"13.85.69.107/32\",\r\n - \ \"20.45.120.0/27\",\r\n \"20.45.121.0/27\",\r\n \"20.49.88.0/27\",\r\n - \ \"20.49.89.0/27\",\r\n \"23.98.162.75/32\",\r\n \"23.98.162.76/31\",\r\n - \ \"23.98.162.78/32\",\r\n \"23.98.170.75/32\",\r\n \"23.98.170.76/31\",\r\n - \ \"23.102.172.251/32\",\r\n \"23.102.173.220/32\",\r\n \"23.102.174.146/32\",\r\n - \ \"23.102.179.187/32\",\r\n \"40.74.254.156/32\",\r\n \"40.84.153.95/32\",\r\n - \ \"40.84.155.210/32\",\r\n \"40.84.156.165/32\",\r\n \"40.84.191.1/32\",\r\n - \ \"40.84.193.16/32\",\r\n \"40.84.195.189/32\",\r\n \"40.84.231.203/32\",\r\n - \ \"40.124.8.76/32\",\r\n \"52.171.56.10/32\",\r\n \"52.183.250.62/32\",\r\n - \ \"104.214.16.0/26\",\r\n \"104.214.16.192/26\",\r\n \"104.214.17.0/26\",\r\n - \ \"104.214.17.192/26\",\r\n \"104.214.67.25/32\",\r\n \"104.214.73.137/32\",\r\n - \ \"104.214.78.242/32\",\r\n \"191.238.224.203/32\",\r\n - \ \"191.238.230.40/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.SoutheastAsia\",\r\n \"id\": \"Sql.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.67.16.0/26\",\r\n - \ \"13.67.17.0/26\",\r\n \"13.67.48.255/32\",\r\n \"13.67.56.134/32\",\r\n - \ \"13.67.59.217/32\",\r\n \"13.76.90.3/32\",\r\n \"13.76.247.54/32\",\r\n - \ \"23.98.80.0/26\",\r\n \"23.98.81.0/26\",\r\n \"23.100.117.95/32\",\r\n - \ \"23.100.119.70/32\",\r\n \"23.101.18.228/32\",\r\n \"40.78.232.0/26\",\r\n - \ \"40.78.233.0/26\",\r\n \"52.187.15.214/32\",\r\n \"52.187.76.130/32\",\r\n - \ \"104.43.10.74/32\",\r\n \"104.43.15.0/32\",\r\n \"104.215.195.14/32\",\r\n - \ \"104.215.196.52/32\",\r\n \"111.221.106.161/32\",\r\n - \ \"137.116.129.110/32\",\r\n \"168.63.175.68/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.SouthIndia\",\r\n \"id\": - \"Sql.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"40.78.192.0/27\",\r\n - \ \"40.78.193.0/27\",\r\n \"52.172.24.47/32\",\r\n \"52.172.43.208/32\",\r\n - \ \"104.211.224.146/31\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.SwitzerlandNorth\",\r\n \"id\": \"Sql.SwitzerlandNorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.107.56.0/27\",\r\n - \ \"51.107.57.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.SwitzerlandWest\",\r\n \"id\": \"Sql.SwitzerlandWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.107.152.0/27\",\r\n - \ \"51.107.153.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.UAECentral\",\r\n \"id\": \"Sql.UAECentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"20.37.72.64/27\",\r\n - \ \"20.37.73.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.UAENorth\",\r\n \"id\": \"Sql.UAENorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"40.120.72.0/27\",\r\n \"40.120.73.0/27\",\r\n - \ \"65.52.248.0/27\",\r\n \"65.52.249.0/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.UKNorth\",\r\n \"id\": - \"Sql.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"13.87.97.210/32\",\r\n \"13.87.97.228/32\",\r\n - \ \"13.87.97.237/32\",\r\n \"13.87.120.0/27\",\r\n \"13.87.121.0/27\",\r\n - \ \"51.142.211.129/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.UKSouth\",\r\n \"id\": \"Sql.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.64.0/27\",\r\n \"51.105.65.0/27\",\r\n - \ \"51.105.72.0/27\",\r\n \"51.105.73.0/27\",\r\n \"51.140.77.9/32\",\r\n - \ \"51.140.114.26/32\",\r\n \"51.140.115.150/32\",\r\n \"51.140.144.0/27\",\r\n - \ \"51.140.145.0/27\",\r\n \"51.140.180.9/32\",\r\n \"51.140.183.238/32\",\r\n - \ \"51.140.184.11/32\",\r\n \"51.140.184.12/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.UKSouth2\",\r\n \"id\": - \"Sql.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.87.16.64/27\",\r\n - \ \"13.87.17.0/27\",\r\n \"13.87.33.234/32\",\r\n \"13.87.34.7/32\",\r\n - \ \"13.87.34.19/32\",\r\n \"13.87.38.138/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.UKWest\",\r\n \"id\": - \"Sql.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.140.208.64/27\",\r\n - \ \"51.140.209.0/27\",\r\n \"51.141.8.11/32\",\r\n \"51.141.8.12/32\",\r\n - \ \"51.141.15.53/32\",\r\n \"51.141.25.212/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.WestCentralUS\",\r\n \"id\": - \"Sql.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.71.192.0/27\",\r\n \"13.71.193.0/27\",\r\n \"13.78.144.57/32\",\r\n - \ \"13.78.145.25/32\",\r\n \"13.78.148.71/32\",\r\n \"13.78.151.189/32\",\r\n - \ \"13.78.151.207/32\",\r\n \"13.78.178.116/32\",\r\n \"13.78.178.151/32\",\r\n - \ \"13.78.248.32/27\",\r\n \"52.161.15.204/32\",\r\n \"52.161.100.158/32\",\r\n - \ \"52.161.105.228/32\",\r\n \"52.161.128.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.WestEurope\",\r\n \"id\": - \"Sql.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": - [\r\n \"13.69.104.0/26\",\r\n \"13.69.104.192/26\",\r\n - \ \"13.69.105.0/26\",\r\n \"13.69.105.192/26\",\r\n \"23.97.167.46/32\",\r\n - \ \"23.97.169.19/32\",\r\n \"23.97.219.82/32\",\r\n \"23.97.221.176/32\",\r\n - \ \"23.101.64.10/32\",\r\n \"40.68.37.158/32\",\r\n \"40.68.215.206/32\",\r\n - \ \"40.68.220.16/32\",\r\n \"40.74.51.145/32\",\r\n \"40.74.53.36/32\",\r\n - \ \"40.74.60.91/32\",\r\n \"40.114.240.125/32\",\r\n \"40.114.240.162/32\",\r\n - \ \"40.115.37.61/32\",\r\n \"40.115.51.118/32\",\r\n \"40.115.52.141/32\",\r\n - \ \"40.115.53.255/32\",\r\n \"40.115.61.208/32\",\r\n \"40.118.12.208/32\",\r\n - \ \"52.166.76.0/32\",\r\n \"52.166.131.195/32\",\r\n \"52.236.184.0/27\",\r\n - \ \"52.236.184.128/25\",\r\n \"52.236.185.0/27\",\r\n \"52.236.185.128/25\",\r\n - \ \"104.40.155.247/32\",\r\n \"104.40.168.64/26\",\r\n \"104.40.168.192/26\",\r\n - \ \"104.40.169.0/27\",\r\n \"104.40.169.128/25\",\r\n \"104.40.180.164/32\",\r\n - \ \"104.40.220.28/32\",\r\n \"104.40.230.18/32\",\r\n \"104.40.232.54/32\",\r\n - \ \"104.40.237.111/32\",\r\n \"104.45.11.99/32\",\r\n \"104.45.14.115/32\",\r\n - \ \"104.46.38.143/32\",\r\n \"104.46.40.24/32\",\r\n \"104.47.157.97/32\",\r\n - \ \"137.116.203.91/32\",\r\n \"168.63.13.214/32\",\r\n \"168.63.98.91/32\",\r\n - \ \"191.233.69.227/32\",\r\n \"191.233.90.117/32\",\r\n \"191.237.232.75/32\",\r\n - \ \"191.237.232.76/31\",\r\n \"191.237.232.78/32\",\r\n \"191.237.232.235/32\",\r\n - \ \"191.237.232.236/31\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.WestIndia\",\r\n \"id\": \"Sql.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"104.211.144.0/27\",\r\n - \ \"104.211.145.0/27\",\r\n \"104.211.160.80/31\",\r\n \"104.211.185.58/32\",\r\n - \ \"104.211.190.46/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Sql.WestUS\",\r\n \"id\": \"Sql.WestUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n - \ \"addressPrefixes\": [\r\n \"13.86.216.0/25\",\r\n \"13.86.216.128/26\",\r\n - \ \"13.86.216.192/27\",\r\n \"13.86.217.0/25\",\r\n \"13.86.217.128/26\",\r\n - \ \"13.86.217.192/27\",\r\n \"13.88.14.200/32\",\r\n \"13.88.29.70/32\",\r\n - \ \"13.91.4.219/32\",\r\n \"13.91.6.136/32\",\r\n \"13.91.41.153/32\",\r\n - \ \"13.91.44.56/32\",\r\n \"13.91.46.83/32\",\r\n \"13.91.47.72/32\",\r\n - \ \"13.93.165.251/32\",\r\n \"13.93.237.158/32\",\r\n \"23.99.4.210/32\",\r\n - \ \"23.99.4.248/32\",\r\n \"23.99.10.185/32\",\r\n \"23.99.34.75/32\",\r\n - \ \"23.99.34.76/31\",\r\n \"23.99.34.78/32\",\r\n \"23.99.37.235/32\",\r\n - \ \"23.99.37.236/32\",\r\n \"23.99.57.14/32\",\r\n \"23.99.80.243/32\",\r\n - \ \"23.99.89.212/32\",\r\n \"23.99.90.75/32\",\r\n \"23.99.91.130/32\",\r\n - \ \"40.78.16.122/32\",\r\n \"40.78.23.252/32\",\r\n \"40.78.31.250/32\",\r\n - \ \"40.78.57.109/32\",\r\n \"40.78.101.91/32\",\r\n \"40.78.110.18/32\",\r\n - \ \"40.78.111.189/32\",\r\n \"40.83.178.165/32\",\r\n \"40.83.186.249/32\",\r\n - \ \"40.112.139.250/32\",\r\n \"40.112.240.0/27\",\r\n \"40.112.246.0/27\",\r\n - \ \"40.118.129.167/32\",\r\n \"40.118.170.1/32\",\r\n \"40.118.209.206/32\",\r\n - \ \"40.118.244.227/32\",\r\n \"40.118.249.123/32\",\r\n \"40.118.250.19/32\",\r\n - \ \"104.40.28.188/32\",\r\n \"104.40.49.103/32\",\r\n \"104.40.54.130/32\",\r\n - \ \"104.40.82.151/32\",\r\n \"104.42.120.235/32\",\r\n \"104.42.127.95/32\",\r\n - \ \"104.42.136.93/32\",\r\n \"104.42.188.130/32\",\r\n \"104.42.192.190/32\",\r\n - \ \"104.42.199.221/32\",\r\n \"104.42.231.253/32\",\r\n \"104.42.237.198/32\",\r\n - \ \"104.42.238.205/32\",\r\n \"104.210.32.128/32\",\r\n \"137.135.51.212/32\",\r\n - \ \"138.91.145.12/32\",\r\n \"138.91.160.189/32\",\r\n \"138.91.240.14/32\",\r\n - \ \"138.91.246.31/32\",\r\n \"138.91.247.51/32\",\r\n \"138.91.251.139/32\",\r\n - \ \"191.236.119.31/32\",\r\n \"191.239.12.154/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Sql.WestUS2\",\r\n \"id\": - \"Sql.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n - \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.66.136.0/26\",\r\n - \ \"13.66.137.0/26\",\r\n \"13.66.226.202/32\",\r\n \"13.66.229.222/32\",\r\n - \ \"13.66.230.18/31\",\r\n \"13.66.230.60/32\",\r\n \"13.66.230.64/32\",\r\n - \ \"13.66.230.103/32\",\r\n \"40.78.240.0/26\",\r\n \"40.78.241.0/26\",\r\n - \ \"40.78.248.0/26\",\r\n \"40.78.249.0/26\",\r\n \"52.191.144.64/26\",\r\n - \ \"52.191.152.64/26\",\r\n \"52.191.172.187/32\",\r\n \"52.191.174.114/32\",\r\n - \ \"52.229.17.93/32\",\r\n \"52.246.251.248/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"SqlManagement\",\r\n \"id\": - \"SqlManagement\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"SqlManagement\",\r\n \"addressPrefixes\": [\r\n \"13.64.155.40/32\",\r\n - \ \"13.66.140.96/27\",\r\n \"13.66.141.192/27\",\r\n \"13.67.8.192/27\",\r\n - \ \"13.67.10.32/27\",\r\n \"13.69.64.96/27\",\r\n \"13.69.67.0/27\",\r\n - \ \"13.69.106.96/27\",\r\n \"13.69.107.32/27\",\r\n \"13.69.227.96/27\",\r\n - \ \"13.69.229.192/27\",\r\n \"13.70.72.160/27\",\r\n \"13.70.73.224/27\",\r\n - \ \"13.71.119.167/32\",\r\n \"13.71.123.234/32\",\r\n \"13.71.170.160/27\",\r\n - \ \"13.71.173.96/27\",\r\n \"13.71.195.0/27\",\r\n \"13.71.196.96/27\",\r\n - \ \"13.73.240.192/27\",\r\n \"13.73.242.0/27\",\r\n \"13.73.249.176/28\",\r\n - \ \"13.74.107.96/27\",\r\n \"13.74.107.224/27\",\r\n \"13.75.36.32/27\",\r\n - \ \"13.75.39.32/27\",\r\n \"13.77.50.192/27\",\r\n \"13.77.53.0/27\",\r\n - \ \"13.78.106.224/27\",\r\n \"13.78.109.64/27\",\r\n \"13.78.181.246/32\",\r\n - \ \"13.78.182.82/32\",\r\n \"13.84.52.76/32\",\r\n \"13.86.219.96/27\",\r\n - \ \"13.87.39.133/32\",\r\n \"13.87.39.173/32\",\r\n \"13.87.56.192/27\",\r\n - \ \"13.87.58.0/27\",\r\n \"13.87.122.192/27\",\r\n \"13.87.124.0/27\",\r\n - \ \"13.89.170.224/27\",\r\n \"13.89.174.96/27\",\r\n \"13.92.242.41/32\",\r\n - \ \"13.94.47.38/32\",\r\n \"13.104.248.32/27\",\r\n \"13.104.248.96/27\",\r\n - \ \"20.36.46.202/32\",\r\n \"20.36.46.220/32\",\r\n \"20.36.75.75/32\",\r\n - \ \"20.36.75.114/32\",\r\n \"20.36.108.0/27\",\r\n \"20.36.108.64/27\",\r\n - \ \"20.36.115.160/27\",\r\n \"20.36.115.192/27\",\r\n \"20.36.123.0/28\",\r\n - \ \"20.37.67.64/28\",\r\n \"20.37.76.0/27\",\r\n \"20.37.76.64/27\",\r\n - \ \"20.37.198.96/28\",\r\n \"20.37.227.0/28\",\r\n \"20.38.87.208/28\",\r\n - \ \"20.38.128.0/27\",\r\n \"20.38.139.64/28\",\r\n \"20.38.146.192/27\",\r\n - \ \"20.38.147.32/27\",\r\n \"20.39.12.240/28\",\r\n \"20.40.200.176/28\",\r\n - \ \"20.41.67.96/28\",\r\n \"20.41.197.32/28\",\r\n \"20.42.131.34/31\",\r\n - \ \"20.42.230.96/28\",\r\n \"20.43.43.176/28\",\r\n \"20.43.70.80/28\",\r\n - \ \"20.43.120.192/27\",\r\n \"20.44.4.0/26\",\r\n \"20.44.8.128/27\",\r\n - \ \"20.44.16.160/27\",\r\n \"20.44.26.192/27\",\r\n \"20.44.27.160/27\",\r\n - \ \"20.45.75.228/32\",\r\n \"20.45.75.230/32\",\r\n \"20.45.114.208/28\",\r\n - \ \"20.45.122.192/27\",\r\n \"20.45.126.32/27\",\r\n \"20.45.197.240/28\",\r\n - \ \"20.49.83.160/27\",\r\n \"20.49.83.192/27\",\r\n \"20.49.91.160/27\",\r\n - \ \"20.49.99.48/28\",\r\n \"20.49.109.64/28\",\r\n \"20.49.113.16/28\",\r\n - \ \"20.49.120.48/28\",\r\n \"20.50.1.224/28\",\r\n \"20.150.165.160/28\",\r\n - \ \"20.150.170.32/27\",\r\n \"20.150.170.128/27\",\r\n \"20.150.172.96/27\",\r\n - \ \"20.150.178.192/26\",\r\n \"20.150.186.192/26\",\r\n \"20.187.194.208/28\",\r\n - \ \"20.192.98.192/26\",\r\n \"20.192.165.192/28\",\r\n \"20.192.230.16/28\",\r\n - \ \"20.192.238.32/27\",\r\n \"20.192.238.64/27\",\r\n \"20.194.67.128/26\",\r\n - \ \"23.96.185.63/32\",\r\n \"23.96.243.93/32\",\r\n \"23.97.120.24/32\",\r\n - \ \"23.98.82.128/27\",\r\n \"23.98.83.32/27\",\r\n \"23.98.104.144/28\",\r\n - \ \"23.99.97.255/32\",\r\n \"40.64.132.112/28\",\r\n \"40.65.124.161/32\",\r\n - \ \"40.67.50.224/28\",\r\n \"40.67.58.32/27\",\r\n \"40.67.60.32/27\",\r\n - \ \"40.69.106.192/27\",\r\n \"40.69.108.0/27\",\r\n \"40.69.161.215/32\",\r\n - \ \"40.70.72.228/32\",\r\n \"40.70.146.96/27\",\r\n \"40.70.148.64/27\",\r\n - \ \"40.71.10.224/27\",\r\n \"40.71.13.192/27\",\r\n \"40.71.215.148/32\",\r\n - \ \"40.74.100.192/27\",\r\n \"40.74.101.224/27\",\r\n \"40.74.147.0/27\",\r\n - \ \"40.74.147.96/27\",\r\n \"40.74.147.128/27\",\r\n \"40.74.254.227/32\",\r\n - \ \"40.75.34.64/27\",\r\n \"40.75.35.0/27\",\r\n \"40.78.194.192/27\",\r\n - \ \"40.78.196.0/27\",\r\n \"40.78.203.128/27\",\r\n \"40.78.203.192/27\",\r\n - \ \"40.78.226.224/27\",\r\n \"40.78.229.0/27\",\r\n \"40.78.234.64/27\",\r\n - \ \"40.78.234.224/27\",\r\n \"40.78.242.192/27\",\r\n \"40.78.243.128/27\",\r\n - \ \"40.78.250.128/27\",\r\n \"40.78.251.64/27\",\r\n \"40.79.32.162/32\",\r\n - \ \"40.79.130.160/27\",\r\n \"40.79.132.0/27\",\r\n \"40.79.138.64/27\",\r\n - \ \"40.79.138.160/27\",\r\n \"40.79.146.64/27\",\r\n \"40.79.146.160/27\",\r\n - \ \"40.79.154.0/27\",\r\n \"40.79.154.224/27\",\r\n \"40.79.156.0/27\",\r\n - \ \"40.79.162.64/27\",\r\n \"40.79.162.160/27\",\r\n \"40.79.170.160/27\",\r\n - \ \"40.79.171.0/27\",\r\n \"40.79.178.192/27\",\r\n \"40.79.179.224/27\",\r\n - \ \"40.79.186.96/27\",\r\n \"40.79.187.128/27\",\r\n \"40.79.194.0/27\",\r\n - \ \"40.79.195.128/27\",\r\n \"40.80.50.192/27\",\r\n \"40.80.51.32/27\",\r\n - \ \"40.80.62.0/28\",\r\n \"40.80.172.32/28\",\r\n \"40.89.20.144/28\",\r\n - \ \"40.112.243.128/27\",\r\n \"40.120.75.192/26\",\r\n \"40.123.207.224/32\",\r\n - \ \"40.123.219.239/32\",\r\n \"40.126.238.47/32\",\r\n \"40.127.3.232/32\",\r\n - \ \"51.12.42.0/28\",\r\n \"51.12.98.32/27\",\r\n \"51.12.98.128/27\",\r\n - \ \"51.12.194.0/28\",\r\n \"51.12.202.32/27\",\r\n \"51.12.202.128/27\",\r\n - \ \"51.12.226.192/26\",\r\n \"51.12.234.192/26\",\r\n \"51.104.8.192/27\",\r\n - \ \"51.104.28.240/28\",\r\n \"51.105.66.192/27\",\r\n \"51.105.67.128/27\",\r\n - \ \"51.105.74.192/27\",\r\n \"51.105.75.32/27\",\r\n \"51.105.83.0/28\",\r\n - \ \"51.105.90.160/28\",\r\n \"51.107.51.0/28\",\r\n \"51.107.58.32/27\",\r\n - \ \"51.107.60.0/27\",\r\n \"51.107.147.0/28\",\r\n \"51.107.154.32/27\",\r\n - \ \"51.107.156.0/27\",\r\n \"51.116.49.144/28\",\r\n \"51.116.58.32/27\",\r\n - \ \"51.116.60.0/27\",\r\n \"51.116.145.144/28\",\r\n \"51.116.154.96/27\",\r\n - \ \"51.116.156.0/27\",\r\n \"51.116.242.192/26\",\r\n \"51.116.243.32/27\",\r\n - \ \"51.116.250.192/27\",\r\n \"51.116.253.96/27\",\r\n \"51.120.43.64/28\",\r\n - \ \"51.120.98.32/27\",\r\n \"51.120.100.0/27\",\r\n \"51.120.106.192/26\",\r\n - \ \"51.120.210.192/26\",\r\n \"51.120.218.32/27\",\r\n \"51.120.218.128/27\",\r\n - \ \"51.120.227.64/28\",\r\n \"51.137.164.96/28\",\r\n \"51.140.121.92/32\",\r\n - \ \"51.140.127.51/32\",\r\n \"51.140.146.224/27\",\r\n \"51.140.210.224/27\",\r\n - \ \"51.140.212.32/27\",\r\n \"51.141.38.88/32\",\r\n \"51.141.39.175/32\",\r\n - \ \"51.142.213.97/32\",\r\n \"51.142.215.251/32\",\r\n \"51.143.195.0/28\",\r\n - \ \"52.136.51.80/28\",\r\n \"52.136.139.224/32\",\r\n \"52.136.140.157/32\",\r\n - \ \"52.138.90.96/27\",\r\n \"52.138.226.96/27\",\r\n \"52.138.226.224/27\",\r\n - \ \"52.140.108.80/28\",\r\n \"52.143.136.162/32\",\r\n \"52.143.139.82/32\",\r\n - \ \"52.150.139.78/31\",\r\n \"52.150.152.32/28\",\r\n \"52.162.107.128/27\",\r\n - \ \"52.162.110.192/27\",\r\n \"52.164.200.174/32\",\r\n \"52.165.237.178/32\",\r\n - \ \"52.166.50.138/32\",\r\n \"52.167.106.96/27\",\r\n \"52.167.106.224/27\",\r\n - \ \"52.169.6.70/32\",\r\n \"52.172.193.99/32\",\r\n \"52.172.204.185/32\",\r\n - \ \"52.173.243.204/32\",\r\n \"52.175.156.251/32\",\r\n \"52.182.138.224/27\",\r\n - \ \"52.182.139.96/27\",\r\n \"52.183.64.43/32\",\r\n \"52.185.145.40/32\",\r\n - \ \"52.185.154.136/32\",\r\n \"52.187.185.17/32\",\r\n \"52.225.130.171/32\",\r\n - \ \"52.228.84.112/28\",\r\n \"52.230.122.197/32\",\r\n \"52.231.18.160/27\",\r\n - \ \"52.231.19.224/27\",\r\n \"52.231.30.200/32\",\r\n \"52.231.34.21/32\",\r\n - \ \"52.231.146.224/27\",\r\n \"52.231.148.32/27\",\r\n \"52.231.202.76/32\",\r\n - \ \"52.231.206.187/32\",\r\n \"52.233.30.2/32\",\r\n \"52.233.38.82/32\",\r\n - \ \"52.233.130.100/32\",\r\n \"52.235.36.131/32\",\r\n \"52.236.186.96/27\",\r\n - \ \"52.236.187.32/27\",\r\n \"52.237.244.169/32\",\r\n \"52.242.36.170/32\",\r\n - \ \"52.243.87.200/32\",\r\n \"52.246.154.192/27\",\r\n \"52.246.155.32/27\",\r\n - \ \"52.255.51.21/32\",\r\n \"65.52.252.0/27\",\r\n \"65.52.252.64/27\",\r\n - \ \"102.133.27.224/27\",\r\n \"102.133.28.32/27\",\r\n \"102.133.58.208/28\",\r\n - \ \"102.133.72.35/32\",\r\n \"102.133.72.42/32\",\r\n \"102.133.122.192/27\",\r\n - \ \"102.133.123.192/27\",\r\n \"102.133.155.224/27\",\r\n - \ \"102.133.156.32/27\",\r\n \"102.133.160.35/32\",\r\n \"102.133.218.128/28\",\r\n - \ \"102.133.250.192/27\",\r\n \"102.133.251.32/27\",\r\n - \ \"104.42.96.175/32\",\r\n \"104.208.16.96/27\",\r\n \"104.208.144.96/27\",\r\n - \ \"104.211.81.160/27\",\r\n \"104.211.146.192/27\",\r\n - \ \"104.211.187.232/32\",\r\n \"104.214.19.0/27\",\r\n \"104.214.108.80/32\",\r\n - \ \"104.215.17.87/32\",\r\n \"191.232.163.58/32\",\r\n \"191.233.11.128/28\",\r\n - \ \"191.233.54.32/27\",\r\n \"191.233.54.192/27\",\r\n \"191.233.203.160/27\",\r\n - \ \"191.233.205.32/27\",\r\n \"191.234.136.64/28\",\r\n \"191.234.146.192/26\",\r\n - \ \"191.234.154.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage\",\r\n \"id\": \"Storage\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n - \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.65.107.32/28\",\r\n - \ \"13.65.160.16/28\",\r\n \"13.65.160.48/28\",\r\n \"13.65.160.64/28\",\r\n - \ \"13.66.176.16/28\",\r\n \"13.66.176.48/28\",\r\n \"13.66.232.64/28\",\r\n - \ \"13.66.232.208/28\",\r\n \"13.66.232.224/28\",\r\n \"13.66.234.0/27\",\r\n - \ \"13.67.155.16/28\",\r\n \"13.68.120.64/28\",\r\n \"13.68.163.32/28\",\r\n - \ \"13.68.165.64/28\",\r\n \"13.68.167.240/28\",\r\n \"13.69.40.16/28\",\r\n - \ \"13.70.99.16/28\",\r\n \"13.70.99.48/28\",\r\n \"13.70.99.64/28\",\r\n - \ \"13.70.208.16/28\",\r\n \"13.71.200.64/28\",\r\n \"13.71.200.96/28\",\r\n - \ \"13.71.200.240/28\",\r\n \"13.71.202.16/28\",\r\n \"13.71.202.32/28\",\r\n - \ \"13.71.202.64/27\",\r\n \"13.72.235.64/28\",\r\n \"13.72.235.96/27\",\r\n - \ \"13.72.235.144/28\",\r\n \"13.72.237.48/28\",\r\n \"13.72.237.64/28\",\r\n - \ \"13.73.8.16/28\",\r\n \"13.73.8.32/28\",\r\n \"13.74.208.64/28\",\r\n - \ \"13.74.208.112/28\",\r\n \"13.74.208.144/28\",\r\n \"13.75.240.16/28\",\r\n - \ \"13.75.240.32/28\",\r\n \"13.75.240.64/27\",\r\n \"13.76.104.16/28\",\r\n - \ \"13.77.8.16/28\",\r\n \"13.77.8.32/28\",\r\n \"13.77.8.64/28\",\r\n - \ \"13.77.8.96/28\",\r\n \"13.77.8.128/27\",\r\n \"13.77.8.160/28\",\r\n - \ \"13.77.8.192/27\",\r\n \"13.77.112.16/28\",\r\n \"13.77.112.32/28\",\r\n - \ \"13.77.112.112/28\",\r\n \"13.77.112.128/28\",\r\n \"13.77.115.16/28\",\r\n - \ \"13.77.115.32/28\",\r\n \"13.77.184.64/28\",\r\n \"13.78.152.64/28\",\r\n - \ \"13.78.240.16/28\",\r\n \"13.79.176.16/28\",\r\n \"13.79.176.48/28\",\r\n - \ \"13.79.176.80/28\",\r\n \"13.82.33.32/28\",\r\n \"13.82.152.16/28\",\r\n - \ \"13.82.152.48/28\",\r\n \"13.82.152.80/28\",\r\n \"13.83.72.16/28\",\r\n - \ \"13.84.56.16/28\",\r\n \"13.85.88.16/28\",\r\n \"13.85.200.128/28\",\r\n - \ \"13.87.40.64/28\",\r\n \"13.87.40.96/28\",\r\n \"13.87.104.64/28\",\r\n - \ \"13.87.104.96/28\",\r\n \"13.88.144.112/28\",\r\n \"13.88.144.240/28\",\r\n - \ \"13.88.145.64/28\",\r\n \"13.88.145.96/28\",\r\n \"13.88.145.128/28\",\r\n - \ \"13.93.168.80/28\",\r\n \"13.93.168.112/28\",\r\n \"13.93.168.144/28\",\r\n - \ \"13.95.96.176/28\",\r\n \"13.95.240.16/28\",\r\n \"13.95.240.32/28\",\r\n - \ \"13.95.240.64/27\",\r\n \"20.38.96.0/19\",\r\n \"20.47.0.0/18\",\r\n - \ \"20.60.0.0/23\",\r\n \"20.60.2.0/24\",\r\n \"20.60.4.0/22\",\r\n - \ \"20.60.8.0/21\",\r\n \"20.60.16.0/22\",\r\n \"20.60.20.0/24\",\r\n - \ \"20.150.0.0/17\",\r\n \"20.157.32.0/19\",\r\n \"23.96.64.64/26\",\r\n - \ \"23.97.112.64/26\",\r\n \"23.98.49.0/26\",\r\n \"23.98.49.192/26\",\r\n - \ \"23.98.55.0/26\",\r\n \"23.98.55.112/28\",\r\n \"23.98.55.144/28\",\r\n - \ \"23.98.56.0/26\",\r\n \"23.98.57.64/26\",\r\n \"23.98.160.64/26\",\r\n - \ \"23.98.162.192/26\",\r\n \"23.98.168.0/24\",\r\n \"23.98.192.64/26\",\r\n - \ \"23.98.255.64/26\",\r\n \"23.99.32.64/26\",\r\n \"23.99.34.224/28\",\r\n - \ \"23.99.37.96/28\",\r\n \"23.99.47.32/28\",\r\n \"23.99.160.64/26\",\r\n - \ \"23.99.160.192/28\",\r\n \"23.102.206.0/28\",\r\n \"23.102.206.128/28\",\r\n - \ \"23.102.206.192/28\",\r\n \"40.68.176.16/28\",\r\n \"40.68.176.48/28\",\r\n - \ \"40.68.232.16/28\",\r\n \"40.68.232.48/28\",\r\n \"40.69.176.16/28\",\r\n - \ \"40.70.88.0/28\",\r\n \"40.71.104.16/28\",\r\n \"40.71.104.32/28\",\r\n - \ \"40.71.240.16/28\",\r\n \"40.78.72.16/28\",\r\n \"40.78.112.64/28\",\r\n - \ \"40.79.8.16/28\",\r\n \"40.79.48.16/28\",\r\n \"40.79.88.16/28\",\r\n - \ \"40.83.24.16/28\",\r\n \"40.83.24.80/28\",\r\n \"40.83.24.96/27\",\r\n - \ \"40.83.104.176/28\",\r\n \"40.83.104.208/28\",\r\n \"40.83.225.32/28\",\r\n - \ \"40.83.227.16/28\",\r\n \"40.84.8.32/28\",\r\n \"40.84.11.80/28\",\r\n - \ \"40.85.105.32/28\",\r\n \"40.85.232.64/28\",\r\n \"40.85.232.96/28\",\r\n - \ \"40.85.232.144/28\",\r\n \"40.85.235.32/27\",\r\n \"40.85.235.80/28\",\r\n - \ \"40.85.235.96/28\",\r\n \"40.86.232.64/28\",\r\n \"40.86.232.96/28\",\r\n - \ \"40.86.232.128/28\",\r\n \"40.86.232.176/28\",\r\n \"40.86.232.192/28\",\r\n - \ \"40.112.152.16/28\",\r\n \"40.112.224.16/28\",\r\n \"40.112.224.48/28\",\r\n - \ \"40.113.27.176/28\",\r\n \"40.114.152.16/28\",\r\n \"40.114.152.48/28\",\r\n - \ \"40.115.169.32/28\",\r\n \"40.115.175.16/28\",\r\n \"40.115.175.32/28\",\r\n - \ \"40.115.227.80/28\",\r\n \"40.115.229.16/28\",\r\n \"40.115.229.32/28\",\r\n - \ \"40.115.231.64/27\",\r\n \"40.115.231.112/28\",\r\n \"40.115.231.128/28\",\r\n - \ \"40.116.120.16/28\",\r\n \"40.116.232.16/28\",\r\n \"40.116.232.48/28\",\r\n - \ \"40.116.232.96/28\",\r\n \"40.117.48.80/28\",\r\n \"40.117.48.112/28\",\r\n - \ \"40.117.104.16/28\",\r\n \"40.118.72.176/28\",\r\n \"40.118.73.48/28\",\r\n - \ \"40.118.73.176/28\",\r\n \"40.118.73.208/28\",\r\n \"40.122.96.16/28\",\r\n - \ \"40.122.216.16/28\",\r\n \"40.123.16.16/28\",\r\n \"51.140.16.16/28\",\r\n - \ \"51.140.16.32/28\",\r\n \"51.140.168.64/27\",\r\n \"51.140.168.112/28\",\r\n - \ \"51.140.168.128/28\",\r\n \"51.140.232.64/27\",\r\n \"51.140.232.112/28\",\r\n - \ \"51.140.232.128/28\",\r\n \"51.140.232.160/27\",\r\n \"51.141.128.0/23\",\r\n - \ \"51.141.130.0/25\",\r\n \"52.161.112.16/28\",\r\n \"52.161.112.32/28\",\r\n - \ \"52.161.168.16/28\",\r\n \"52.161.168.32/28\",\r\n \"52.162.56.16/28\",\r\n - \ \"52.162.56.32/28\",\r\n \"52.162.56.64/27\",\r\n \"52.162.56.112/28\",\r\n - \ \"52.162.56.128/28\",\r\n \"52.163.176.16/28\",\r\n \"52.163.232.16/28\",\r\n - \ \"52.164.112.16/28\",\r\n \"52.164.232.16/28\",\r\n \"52.164.232.32/28\",\r\n - \ \"52.164.232.64/28\",\r\n \"52.165.104.16/28\",\r\n \"52.165.104.32/28\",\r\n - \ \"52.165.104.64/27\",\r\n \"52.165.104.112/28\",\r\n \"52.165.104.144/28\",\r\n - \ \"52.165.104.160/28\",\r\n \"52.165.136.32/28\",\r\n \"52.165.240.64/28\",\r\n - \ \"52.166.80.32/27\",\r\n \"52.166.80.80/28\",\r\n \"52.166.80.96/28\",\r\n - \ \"52.167.88.80/28\",\r\n \"52.167.88.112/28\",\r\n \"52.167.240.16/28\",\r\n - \ \"52.169.168.32/27\",\r\n \"52.169.240.16/28\",\r\n \"52.169.240.32/28\",\r\n - \ \"52.169.240.64/28\",\r\n \"52.171.144.32/27\",\r\n \"52.171.144.80/28\",\r\n - \ \"52.171.144.96/28\",\r\n \"52.171.144.128/28\",\r\n \"52.172.16.16/28\",\r\n - \ \"52.172.16.80/28\",\r\n \"52.172.16.96/28\",\r\n \"52.172.16.128/27\",\r\n - \ \"52.173.152.64/28\",\r\n \"52.173.152.96/28\",\r\n \"52.174.8.32/28\",\r\n - \ \"52.174.224.16/28\",\r\n \"52.174.224.32/28\",\r\n \"52.174.224.64/27\",\r\n - \ \"52.174.224.112/28\",\r\n \"52.174.224.128/28\",\r\n \"52.175.40.128/28\",\r\n - \ \"52.175.112.16/28\",\r\n \"52.176.224.64/28\",\r\n \"52.176.224.96/28\",\r\n - \ \"52.177.208.80/28\",\r\n \"52.178.168.32/27\",\r\n \"52.178.168.80/28\",\r\n - \ \"52.178.168.96/28\",\r\n \"52.178.168.128/27\",\r\n \"52.179.24.16/28\",\r\n - \ \"52.179.144.32/28\",\r\n \"52.179.144.64/28\",\r\n \"52.179.240.16/28\",\r\n - \ \"52.179.240.48/28\",\r\n \"52.179.240.64/28\",\r\n \"52.179.240.96/27\",\r\n - \ \"52.179.240.144/28\",\r\n \"52.179.240.160/28\",\r\n \"52.179.240.192/27\",\r\n - \ \"52.179.240.240/28\",\r\n \"52.179.241.0/28\",\r\n \"52.179.241.32/27\",\r\n - \ \"52.180.40.16/28\",\r\n \"52.180.40.32/28\",\r\n \"52.180.184.16/28\",\r\n - \ \"52.182.176.16/28\",\r\n \"52.182.176.32/28\",\r\n \"52.182.176.64/27\",\r\n - \ \"52.183.48.16/28\",\r\n \"52.183.104.16/28\",\r\n \"52.183.104.32/28\",\r\n - \ \"52.184.40.16/28\",\r\n \"52.184.40.32/28\",\r\n \"52.184.168.32/28\",\r\n - \ \"52.184.168.96/27\",\r\n \"52.185.56.80/28\",\r\n \"52.185.56.96/28\",\r\n - \ \"52.185.56.144/28\",\r\n \"52.185.56.160/28\",\r\n \"52.185.112.16/28\",\r\n - \ \"52.185.112.48/28\",\r\n \"52.185.112.80/28\",\r\n \"52.185.112.112/28\",\r\n - \ \"52.185.233.0/24\",\r\n \"52.186.112.32/27\",\r\n \"52.187.141.32/27\",\r\n - \ \"52.189.177.0/24\",\r\n \"52.190.240.16/28\",\r\n \"52.190.240.32/28\",\r\n - \ \"52.190.240.64/27\",\r\n \"52.190.240.112/28\",\r\n \"52.190.240.128/28\",\r\n - \ \"52.191.176.16/28\",\r\n \"52.191.176.32/28\",\r\n \"52.225.40.32/27\",\r\n - \ \"52.225.136.16/28\",\r\n \"52.225.136.32/28\",\r\n \"52.225.240.0/28\",\r\n - \ \"52.226.8.32/27\",\r\n \"52.226.8.80/28\",\r\n \"52.226.8.96/28\",\r\n - \ \"52.226.8.128/27\",\r\n \"52.228.232.0/28\",\r\n \"52.229.80.64/27\",\r\n - \ \"52.230.240.16/28\",\r\n \"52.230.240.32/28\",\r\n \"52.230.240.64/27\",\r\n - \ \"52.230.240.112/28\",\r\n \"52.230.240.128/28\",\r\n \"52.230.240.160/27\",\r\n - \ \"52.231.80.64/27\",\r\n \"52.231.80.112/28\",\r\n \"52.231.80.128/28\",\r\n - \ \"52.231.80.160/27\",\r\n \"52.231.168.64/27\",\r\n \"52.231.168.112/28\",\r\n - \ \"52.231.168.128/28\",\r\n \"52.231.208.16/28\",\r\n \"52.231.208.32/28\",\r\n - \ \"52.232.232.16/28\",\r\n \"52.232.232.32/28\",\r\n \"52.232.232.80/28\",\r\n - \ \"52.232.232.96/28\",\r\n \"52.232.232.128/27\",\r\n \"52.232.232.176/28\",\r\n - \ \"52.232.232.192/28\",\r\n \"52.234.176.48/28\",\r\n \"52.234.176.64/28\",\r\n - \ \"52.234.176.96/27\",\r\n \"52.236.40.16/28\",\r\n \"52.236.40.32/28\",\r\n - \ \"52.236.240.48/28\",\r\n \"52.236.240.64/28\",\r\n \"52.237.104.16/28\",\r\n - \ \"52.237.104.32/28\",\r\n \"52.238.56.16/28\",\r\n \"52.238.56.32/28\",\r\n - \ \"52.238.56.64/27\",\r\n \"52.238.56.112/28\",\r\n \"52.238.56.128/28\",\r\n - \ \"52.238.56.160/27\",\r\n \"52.238.200.32/27\",\r\n \"52.239.104.16/28\",\r\n - \ \"52.239.104.32/28\",\r\n \"52.239.128.0/20\",\r\n \"52.239.144.0/22\",\r\n - \ \"52.239.148.0/27\",\r\n \"52.239.148.64/26\",\r\n \"52.239.148.128/25\",\r\n - \ \"52.239.149.0/24\",\r\n \"52.239.150.0/23\",\r\n \"52.239.152.0/21\",\r\n - \ \"52.239.160.0/22\",\r\n \"52.239.164.0/24\",\r\n \"52.239.165.0/26\",\r\n - \ \"52.239.165.160/27\",\r\n \"52.239.165.192/26\",\r\n \"52.239.167.0/24\",\r\n - \ \"52.239.168.0/21\",\r\n \"52.239.176.128/25\",\r\n \"52.239.177.0/24\",\r\n - \ \"52.239.178.0/23\",\r\n \"52.239.180.0/22\",\r\n \"52.239.184.0/22\",\r\n - \ \"52.239.188.0/23\",\r\n \"52.239.190.0/24\",\r\n \"52.239.191.0/28\",\r\n - \ \"52.239.192.0/18\",\r\n \"52.240.48.16/28\",\r\n \"52.240.48.32/28\",\r\n - \ \"52.240.60.16/28\",\r\n \"52.240.60.32/28\",\r\n \"52.240.60.64/27\",\r\n - \ \"52.241.88.16/28\",\r\n \"52.241.88.32/28\",\r\n \"52.241.88.64/27\",\r\n - \ \"52.245.40.0/24\",\r\n \"104.41.232.16/28\",\r\n \"104.42.200.16/28\",\r\n - \ \"104.43.80.16/28\",\r\n \"104.46.31.16/28\",\r\n \"104.208.0.16/28\",\r\n - \ \"104.208.0.48/28\",\r\n \"104.208.128.16/28\",\r\n \"104.208.248.16/28\",\r\n - \ \"104.211.104.64/28\",\r\n \"104.211.104.96/28\",\r\n \"104.211.104.128/28\",\r\n - \ \"104.211.109.0/28\",\r\n \"104.211.109.32/27\",\r\n \"104.211.109.80/28\",\r\n - \ \"104.211.109.96/28\",\r\n \"104.211.168.16/28\",\r\n \"104.211.232.16/28\",\r\n - \ \"104.211.232.48/28\",\r\n \"104.211.232.80/28\",\r\n \"104.211.232.176/28\",\r\n - \ \"104.214.40.16/28\",\r\n \"104.214.80.16/28\",\r\n \"104.214.80.48/28\",\r\n - \ \"104.214.152.16/28\",\r\n \"104.214.152.176/28\",\r\n - \ \"104.214.243.32/28\",\r\n \"104.215.32.16/28\",\r\n \"104.215.32.32/28\",\r\n - \ \"104.215.32.64/27\",\r\n \"104.215.35.32/27\",\r\n \"104.215.104.64/28\",\r\n - \ \"104.215.240.64/28\",\r\n \"104.215.240.96/28\",\r\n \"137.116.1.0/25\",\r\n - \ \"137.116.2.0/25\",\r\n \"137.116.3.0/25\",\r\n \"137.116.3.128/26\",\r\n - \ \"137.116.96.0/25\",\r\n \"137.116.96.128/26\",\r\n \"137.135.192.64/26\",\r\n - \ \"137.135.192.192/26\",\r\n \"137.135.193.192/26\",\r\n - \ \"137.135.194.0/25\",\r\n \"137.135.194.192/26\",\r\n \"138.91.96.64/26\",\r\n - \ \"138.91.96.128/26\",\r\n \"138.91.128.128/26\",\r\n \"138.91.129.0/26\",\r\n - \ \"157.56.216.0/26\",\r\n \"168.61.57.64/26\",\r\n \"168.61.57.128/25\",\r\n - \ \"168.61.58.0/26\",\r\n \"168.61.58.128/26\",\r\n \"168.61.59.64/26\",\r\n - \ \"168.61.61.0/26\",\r\n \"168.61.61.192/26\",\r\n \"168.61.120.32/27\",\r\n - \ \"168.61.120.64/27\",\r\n \"168.61.121.0/26\",\r\n \"168.61.128.192/26\",\r\n - \ \"168.61.129.0/25\",\r\n \"168.61.130.64/26\",\r\n \"168.61.130.128/25\",\r\n - \ \"168.61.131.0/26\",\r\n \"168.61.131.128/25\",\r\n \"168.61.132.0/26\",\r\n - \ \"168.62.0.0/26\",\r\n \"168.62.1.128/26\",\r\n \"168.62.32.0/26\",\r\n - \ \"168.62.32.192/26\",\r\n \"168.62.33.128/26\",\r\n \"168.62.96.128/25\",\r\n - \ \"168.62.128.128/26\",\r\n \"168.63.0.0/26\",\r\n \"168.63.2.64/26\",\r\n - \ \"168.63.3.32/27\",\r\n \"168.63.3.64/27\",\r\n \"168.63.32.0/26\",\r\n - \ \"168.63.33.192/26\",\r\n \"168.63.89.64/26\",\r\n \"168.63.89.128/26\",\r\n - \ \"168.63.113.32/27\",\r\n \"168.63.113.64/27\",\r\n \"168.63.128.0/26\",\r\n - \ \"168.63.128.128/25\",\r\n \"168.63.129.128/25\",\r\n \"168.63.130.0/26\",\r\n - \ \"168.63.130.128/26\",\r\n \"168.63.131.0/26\",\r\n \"168.63.156.64/26\",\r\n - \ \"168.63.156.192/26\",\r\n \"168.63.160.0/26\",\r\n \"168.63.160.192/26\",\r\n - \ \"168.63.161.64/26\",\r\n \"168.63.161.160/27\",\r\n \"168.63.161.192/26\",\r\n - \ \"168.63.162.32/27\",\r\n \"168.63.162.64/26\",\r\n \"168.63.162.144/28\",\r\n - \ \"168.63.162.192/26\",\r\n \"168.63.163.128/26\",\r\n \"168.63.180.64/26\",\r\n - \ \"191.232.216.32/27\",\r\n \"191.232.221.16/28\",\r\n \"191.232.221.32/28\",\r\n - \ \"191.233.128.0/24\",\r\n \"191.235.192.192/26\",\r\n \"191.235.193.32/28\",\r\n - \ \"191.235.248.0/23\",\r\n \"191.235.250.0/25\",\r\n \"191.235.255.192/26\",\r\n - \ \"191.237.32.128/28\",\r\n \"191.237.32.208/28\",\r\n \"191.237.32.240/28\",\r\n - \ \"191.237.160.64/26\",\r\n \"191.237.160.224/28\",\r\n - \ \"191.237.232.32/28\",\r\n \"191.237.232.128/28\",\r\n - \ \"191.237.238.32/28\",\r\n \"191.238.0.0/26\",\r\n \"191.238.0.224/28\",\r\n - \ \"191.238.64.64/26\",\r\n \"191.238.64.192/28\",\r\n \"191.238.66.0/26\",\r\n - \ \"191.239.192.0/26\",\r\n \"191.239.203.0/28\",\r\n \"191.239.224.0/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.AustraliaCentral\",\r\n - \ \"id\": \"Storage.AustraliaCentral\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n - \ \"addressPrefixes\": [\r\n \"20.47.35.0/24\",\r\n \"20.150.124.0/24\",\r\n - \ \"52.239.216.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.AustraliaCentral2\",\r\n \"id\": \"Storage.AustraliaCentral2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.36.0/24\",\r\n - \ \"20.150.103.0/24\",\r\n \"52.239.218.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.AustraliaEast\",\r\n - \ \"id\": \"Storage.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.70.99.16/28\",\r\n \"13.70.99.48/28\",\r\n \"13.70.99.64/28\",\r\n - \ \"13.72.235.64/28\",\r\n \"13.72.235.96/27\",\r\n \"13.72.235.144/28\",\r\n - \ \"13.72.237.48/28\",\r\n \"13.72.237.64/28\",\r\n \"13.75.240.16/28\",\r\n - \ \"13.75.240.32/28\",\r\n \"13.75.240.64/27\",\r\n \"20.38.112.0/23\",\r\n - \ \"20.47.37.0/24\",\r\n \"20.150.66.0/24\",\r\n \"20.150.92.0/24\",\r\n - \ \"20.150.117.0/24\",\r\n \"52.239.130.0/23\",\r\n \"52.239.226.0/24\",\r\n - \ \"104.46.31.16/28\",\r\n \"191.238.66.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.AustraliaSoutheast\",\r\n - \ \"id\": \"Storage.AustraliaSoutheast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.8.16/28\",\r\n \"13.77.8.32/28\",\r\n - \ \"13.77.8.64/28\",\r\n \"13.77.8.96/28\",\r\n \"13.77.8.128/27\",\r\n - \ \"13.77.8.160/28\",\r\n \"13.77.8.192/27\",\r\n \"20.47.38.0/24\",\r\n - \ \"20.150.12.0/23\",\r\n \"20.150.119.0/24\",\r\n \"52.239.132.0/23\",\r\n - \ \"52.239.225.0/24\",\r\n \"191.239.192.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.BrazilSouth\",\r\n - \ \"id\": \"Storage.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.39.0/24\",\r\n \"20.150.111.0/24\",\r\n \"23.97.112.64/26\",\r\n - \ \"191.232.216.32/27\",\r\n \"191.232.221.16/28\",\r\n \"191.232.221.32/28\",\r\n - \ \"191.233.128.0/24\",\r\n \"191.235.248.0/23\",\r\n \"191.235.250.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.CanadaCentral\",\r\n - \ \"id\": \"Storage.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.114.0/25\",\r\n - \ \"20.47.40.0/24\",\r\n \"20.150.16.0/24\",\r\n \"20.150.31.0/24\",\r\n - \ \"20.150.71.0/24\",\r\n \"20.150.100.0/24\",\r\n \"40.85.232.64/28\",\r\n - \ \"40.85.232.96/28\",\r\n \"40.85.232.144/28\",\r\n \"40.85.235.32/27\",\r\n - \ \"40.85.235.80/28\",\r\n \"40.85.235.96/28\",\r\n \"52.239.148.64/26\",\r\n - \ \"52.239.189.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.CanadaEast\",\r\n \"id\": \"Storage.CanadaEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.121.128/25\",\r\n - \ \"20.47.41.0/24\",\r\n \"20.150.1.0/25\",\r\n \"20.150.40.128/25\",\r\n - \ \"20.150.113.0/24\",\r\n \"40.86.232.64/28\",\r\n \"40.86.232.96/28\",\r\n - \ \"40.86.232.128/28\",\r\n \"40.86.232.176/28\",\r\n \"40.86.232.192/28\",\r\n - \ \"52.229.80.64/27\",\r\n \"52.239.164.128/26\",\r\n \"52.239.190.0/25\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.CentralIndia\",\r\n - \ \"id\": \"Storage.CentralIndia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.38.126.0/23\",\r\n \"20.47.42.0/24\",\r\n \"20.150.114.0/24\",\r\n - \ \"52.239.135.64/26\",\r\n \"52.239.202.0/24\",\r\n \"104.211.104.64/28\",\r\n - \ \"104.211.104.96/28\",\r\n \"104.211.104.128/28\",\r\n - \ \"104.211.109.0/28\",\r\n \"104.211.109.32/27\",\r\n \"104.211.109.80/28\",\r\n - \ \"104.211.109.96/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.CentralUS\",\r\n \"id\": \"Storage.CentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.67.155.16/28\",\r\n - \ \"20.38.96.0/23\",\r\n \"20.38.122.0/23\",\r\n \"20.47.58.0/23\",\r\n - \ \"20.60.18.0/24\",\r\n \"20.150.43.128/25\",\r\n \"20.150.58.0/24\",\r\n - \ \"20.150.63.0/24\",\r\n \"20.150.77.0/24\",\r\n \"20.150.89.0/24\",\r\n - \ \"20.150.95.0/24\",\r\n \"23.99.160.64/26\",\r\n \"23.99.160.192/28\",\r\n - \ \"40.69.176.16/28\",\r\n \"40.83.24.16/28\",\r\n \"40.83.24.80/28\",\r\n - \ \"40.122.96.16/28\",\r\n \"40.122.216.16/28\",\r\n \"52.165.104.16/28\",\r\n - \ \"52.165.104.32/28\",\r\n \"52.165.104.64/27\",\r\n \"52.165.104.112/28\",\r\n - \ \"52.165.136.32/28\",\r\n \"52.165.240.64/28\",\r\n \"52.173.152.64/28\",\r\n - \ \"52.173.152.96/28\",\r\n \"52.176.224.64/28\",\r\n \"52.176.224.96/28\",\r\n - \ \"52.180.184.16/28\",\r\n \"52.182.176.16/28\",\r\n \"52.182.176.32/28\",\r\n - \ \"52.182.176.64/27\",\r\n \"52.185.56.80/28\",\r\n \"52.185.56.96/28\",\r\n - \ \"52.185.56.144/28\",\r\n \"52.185.56.160/28\",\r\n \"52.185.112.16/28\",\r\n - \ \"52.185.112.48/28\",\r\n \"52.185.112.112/28\",\r\n \"52.228.232.0/28\",\r\n - \ \"52.230.240.16/28\",\r\n \"52.230.240.32/28\",\r\n \"52.230.240.64/27\",\r\n - \ \"52.230.240.112/28\",\r\n \"52.230.240.128/28\",\r\n \"52.230.240.160/27\",\r\n - \ \"52.238.200.32/27\",\r\n \"52.239.150.0/23\",\r\n \"52.239.177.32/27\",\r\n - \ \"52.239.177.64/26\",\r\n \"52.239.177.128/25\",\r\n \"52.239.195.0/24\",\r\n - \ \"52.239.234.0/23\",\r\n \"104.208.0.16/28\",\r\n \"104.208.0.48/28\",\r\n - \ \"168.61.128.192/26\",\r\n \"168.61.129.0/25\",\r\n \"168.61.130.64/26\",\r\n - \ \"168.61.130.128/25\",\r\n \"168.61.131.0/26\",\r\n \"168.61.131.128/25\",\r\n - \ \"168.61.132.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.CentralUSEUAP\",\r\n \"id\": \"Storage.CentralUSEUAP\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.5.0/24\",\r\n - \ \"20.150.23.0/24\",\r\n \"20.150.47.0/25\",\r\n \"40.83.24.96/27\",\r\n - \ \"52.165.104.144/28\",\r\n \"52.165.104.160/28\",\r\n \"52.185.112.80/28\",\r\n - \ \"52.239.177.0/27\",\r\n \"52.239.238.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.EastAsia\",\r\n \"id\": - \"Storage.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.43.0/24\",\r\n \"20.150.1.128/25\",\r\n \"20.150.22.0/24\",\r\n - \ \"20.150.96.0/24\",\r\n \"40.83.104.176/28\",\r\n \"40.83.104.208/28\",\r\n - \ \"52.175.40.128/28\",\r\n \"52.175.112.16/28\",\r\n \"52.184.40.16/28\",\r\n - \ \"52.184.40.32/28\",\r\n \"52.239.128.0/24\",\r\n \"52.239.224.0/24\",\r\n - \ \"168.63.128.0/26\",\r\n \"168.63.128.128/25\",\r\n \"168.63.129.128/25\",\r\n - \ \"168.63.130.0/26\",\r\n \"168.63.130.128/26\",\r\n \"168.63.131.0/26\",\r\n - \ \"168.63.156.64/26\",\r\n \"168.63.156.192/26\",\r\n \"191.237.238.32/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS\",\r\n - \ \"id\": \"Storage.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.68.163.32/28\",\r\n \"13.68.165.64/28\",\r\n - \ \"13.68.167.240/28\",\r\n \"13.82.33.32/28\",\r\n \"13.82.152.16/28\",\r\n - \ \"13.82.152.48/28\",\r\n \"13.82.152.80/28\",\r\n \"20.38.98.0/24\",\r\n - \ \"20.47.1.0/24\",\r\n \"20.47.16.0/23\",\r\n \"20.47.31.0/24\",\r\n - \ \"20.60.6.0/23\",\r\n \"20.150.32.0/23\",\r\n \"20.150.90.0/24\",\r\n - \ \"23.96.64.64/26\",\r\n \"40.71.104.16/28\",\r\n \"40.71.104.32/28\",\r\n - \ \"40.71.240.16/28\",\r\n \"40.117.48.80/28\",\r\n \"40.117.48.112/28\",\r\n - \ \"40.117.104.16/28\",\r\n \"52.179.24.16/28\",\r\n \"52.186.112.32/27\",\r\n - \ \"52.226.8.32/27\",\r\n \"52.226.8.80/28\",\r\n \"52.226.8.96/28\",\r\n - \ \"52.226.8.128/27\",\r\n \"52.234.176.48/28\",\r\n \"52.234.176.64/28\",\r\n - \ \"52.234.176.96/27\",\r\n \"52.239.152.0/22\",\r\n \"52.239.168.0/22\",\r\n - \ \"52.239.207.192/26\",\r\n \"52.239.214.0/23\",\r\n \"52.239.220.0/23\",\r\n - \ \"52.239.246.0/23\",\r\n \"52.239.252.0/24\",\r\n \"52.240.48.16/28\",\r\n - \ \"52.240.48.32/28\",\r\n \"52.240.60.16/28\",\r\n \"52.240.60.32/28\",\r\n - \ \"52.240.60.64/27\",\r\n \"138.91.96.64/26\",\r\n \"138.91.96.128/26\",\r\n - \ \"168.62.32.0/26\",\r\n \"168.62.32.192/26\",\r\n \"168.62.33.128/26\",\r\n - \ \"191.237.32.128/28\",\r\n \"191.237.32.208/28\",\r\n \"191.237.32.240/28\",\r\n - \ \"191.238.0.0/26\",\r\n \"191.238.0.224/28\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS2\",\r\n \"id\": - \"Storage.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.68.120.64/28\",\r\n \"13.77.112.16/28\",\r\n - \ \"13.77.112.32/28\",\r\n \"13.77.112.112/28\",\r\n \"13.77.112.128/28\",\r\n - \ \"13.77.115.16/28\",\r\n \"13.77.115.32/28\",\r\n \"20.38.100.0/23\",\r\n - \ \"20.47.60.0/23\",\r\n \"20.150.29.0/24\",\r\n \"20.150.36.0/24\",\r\n - \ \"20.150.50.0/23\",\r\n \"20.150.72.0/24\",\r\n \"20.150.82.0/24\",\r\n - \ \"20.150.88.0/24\",\r\n \"23.102.206.0/28\",\r\n \"23.102.206.128/28\",\r\n - \ \"23.102.206.192/28\",\r\n \"40.79.8.16/28\",\r\n \"40.79.48.16/28\",\r\n - \ \"40.84.8.32/28\",\r\n \"40.84.11.80/28\",\r\n \"40.123.16.16/28\",\r\n - \ \"52.167.88.80/28\",\r\n \"52.167.88.112/28\",\r\n \"52.167.240.16/28\",\r\n - \ \"52.177.208.80/28\",\r\n \"52.179.144.32/28\",\r\n \"52.179.144.64/28\",\r\n - \ \"52.179.240.16/28\",\r\n \"52.179.240.48/28\",\r\n \"52.179.240.64/28\",\r\n - \ \"52.179.240.96/27\",\r\n \"52.179.240.144/28\",\r\n \"52.179.240.160/28\",\r\n - \ \"52.179.240.192/27\",\r\n \"52.179.240.240/28\",\r\n \"52.179.241.0/28\",\r\n - \ \"52.179.241.32/27\",\r\n \"52.184.168.96/27\",\r\n \"52.225.136.16/28\",\r\n - \ \"52.225.136.32/28\",\r\n \"52.225.240.0/28\",\r\n \"52.232.232.16/28\",\r\n - \ \"52.232.232.32/28\",\r\n \"52.232.232.80/28\",\r\n \"52.232.232.96/28\",\r\n - \ \"52.232.232.128/27\",\r\n \"52.232.232.176/28\",\r\n \"52.232.232.192/28\",\r\n - \ \"52.239.156.0/24\",\r\n \"52.239.157.0/25\",\r\n \"52.239.157.128/26\",\r\n - \ \"52.239.157.192/27\",\r\n \"52.239.172.0/22\",\r\n \"52.239.184.0/25\",\r\n - \ \"52.239.184.160/28\",\r\n \"52.239.184.192/27\",\r\n \"52.239.185.32/27\",\r\n - \ \"52.239.185.64/27\",\r\n \"52.239.192.0/25\",\r\n \"52.239.192.160/27\",\r\n - \ \"52.239.192.192/26\",\r\n \"52.239.198.0/25\",\r\n \"52.239.198.160/27\",\r\n - \ \"52.239.198.192/26\",\r\n \"52.239.206.0/24\",\r\n \"52.239.207.0/27\",\r\n - \ \"52.239.207.32/28\",\r\n \"52.239.207.64/26\",\r\n \"52.239.207.128/26\",\r\n - \ \"52.239.222.0/23\",\r\n \"104.208.128.16/28\",\r\n \"104.208.248.16/28\",\r\n - \ \"137.116.1.0/25\",\r\n \"137.116.2.0/26\",\r\n \"137.116.2.96/29\",\r\n - \ \"137.116.2.104/30\",\r\n \"137.116.2.108/32\",\r\n \"137.116.2.110/31\",\r\n - \ \"137.116.2.112/32\",\r\n \"137.116.2.114/32\",\r\n \"137.116.2.116/30\",\r\n - \ \"137.116.2.120/29\",\r\n \"137.116.3.0/25\",\r\n \"137.116.3.128/26\",\r\n - \ \"137.116.96.0/25\",\r\n \"137.116.96.128/26\",\r\n \"191.237.160.64/26\",\r\n - \ \"191.237.160.224/28\",\r\n \"191.239.224.0/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS2EUAP\",\r\n - \ \"id\": \"Storage.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.6.0/24\",\r\n \"20.150.108.0/24\",\r\n \"40.70.88.0/30\",\r\n - \ \"40.70.88.4/31\",\r\n \"40.70.88.6/32\",\r\n \"40.70.88.8/31\",\r\n - \ \"40.70.88.10/32\",\r\n \"40.70.88.12/32\",\r\n \"40.70.88.14/31\",\r\n - \ \"40.79.88.16/30\",\r\n \"40.79.88.20/31\",\r\n \"40.79.88.22/32\",\r\n - \ \"40.79.88.24/31\",\r\n \"40.79.88.26/32\",\r\n \"40.79.88.28/32\",\r\n - \ \"40.79.88.30/31\",\r\n \"52.184.168.32/30\",\r\n \"52.184.168.36/31\",\r\n - \ \"52.184.168.38/32\",\r\n \"52.184.168.40/31\",\r\n \"52.184.168.42/32\",\r\n - \ \"52.184.168.44/32\",\r\n \"52.184.168.46/31\",\r\n \"52.239.157.224/31\",\r\n - \ \"52.239.157.226/32\",\r\n \"52.239.157.228/31\",\r\n \"52.239.157.230/32\",\r\n - \ \"52.239.157.232/32\",\r\n \"52.239.157.234/31\",\r\n \"52.239.157.236/30\",\r\n - \ \"52.239.157.240/31\",\r\n \"52.239.157.242/32\",\r\n \"52.239.157.244/31\",\r\n - \ \"52.239.157.246/32\",\r\n \"52.239.157.248/32\",\r\n \"52.239.157.250/31\",\r\n - \ \"52.239.157.252/30\",\r\n \"52.239.165.192/31\",\r\n \"52.239.165.194/32\",\r\n - \ \"52.239.165.196/31\",\r\n \"52.239.165.198/32\",\r\n \"52.239.165.200/32\",\r\n - \ \"52.239.165.202/31\",\r\n \"52.239.165.204/30\",\r\n \"52.239.165.208/28\",\r\n - \ \"52.239.165.224/27\",\r\n \"52.239.184.128/27\",\r\n \"52.239.184.176/31\",\r\n - \ \"52.239.184.178/32\",\r\n \"52.239.184.180/31\",\r\n \"52.239.184.182/32\",\r\n - \ \"52.239.184.184/32\",\r\n \"52.239.184.186/31\",\r\n \"52.239.184.188/30\",\r\n - \ \"52.239.184.224/31\",\r\n \"52.239.184.226/32\",\r\n \"52.239.184.228/31\",\r\n - \ \"52.239.184.230/32\",\r\n \"52.239.184.232/32\",\r\n \"52.239.184.234/31\",\r\n - \ \"52.239.184.236/30\",\r\n \"52.239.184.240/28\",\r\n \"52.239.185.0/28\",\r\n - \ \"52.239.192.128/31\",\r\n \"52.239.192.130/32\",\r\n \"52.239.192.132/31\",\r\n - \ \"52.239.192.134/32\",\r\n \"52.239.192.136/32\",\r\n \"52.239.192.138/31\",\r\n - \ \"52.239.192.140/30\",\r\n \"52.239.192.144/28\",\r\n \"52.239.198.128/31\",\r\n - \ \"52.239.198.130/32\",\r\n \"52.239.198.132/31\",\r\n \"52.239.198.134/32\",\r\n - \ \"52.239.198.136/32\",\r\n \"52.239.198.138/31\",\r\n \"52.239.198.140/30\",\r\n - \ \"52.239.198.144/31\",\r\n \"52.239.198.146/32\",\r\n \"52.239.198.148/31\",\r\n - \ \"52.239.198.150/32\",\r\n \"52.239.198.152/32\",\r\n \"52.239.198.154/31\",\r\n - \ \"52.239.198.156/30\",\r\n \"52.239.230.0/24\",\r\n \"52.239.239.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS2Stage\",\r\n - \ \"id\": \"Storage.EastUS2Stage\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"137.116.2.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.FranceCentral\",\r\n \"id\": \"Storage.FranceCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.44.0/24\",\r\n - \ \"20.60.13.0/24\",\r\n \"20.150.61.0/24\",\r\n \"52.239.134.0/24\",\r\n - \ \"52.239.194.0/24\",\r\n \"52.239.241.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.FranceSouth\",\r\n - \ \"id\": \"Storage.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.28.0/24\",\r\n \"20.60.11.0/24\",\r\n \"20.150.19.0/24\",\r\n - \ \"52.239.135.0/26\",\r\n \"52.239.196.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.GermanyNorth\",\r\n - \ \"id\": \"Storage.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.38.115.0/24\",\r\n \"20.47.45.0/24\",\r\n \"20.150.60.0/24\",\r\n - \ \"20.150.112.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.GermanyWestCentral\",\r\n \"id\": \"Storage.GermanyWestCentral\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.118.0/24\",\r\n - \ \"20.47.27.0/24\",\r\n \"20.150.54.0/24\",\r\n \"20.150.125.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.JapanEast\",\r\n - \ \"id\": \"Storage.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.73.8.16/28\",\r\n \"13.73.8.32/28\",\r\n \"20.38.116.0/23\",\r\n - \ \"20.47.12.0/24\",\r\n \"20.150.85.0/24\",\r\n \"20.150.105.0/24\",\r\n - \ \"23.98.57.64/26\",\r\n \"40.115.169.32/28\",\r\n \"40.115.175.16/28\",\r\n - \ \"40.115.175.32/28\",\r\n \"40.115.227.80/28\",\r\n \"40.115.229.16/28\",\r\n - \ \"40.115.229.32/28\",\r\n \"40.115.231.64/27\",\r\n \"40.115.231.112/28\",\r\n - \ \"40.115.231.128/28\",\r\n \"52.239.144.0/23\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.JapanWest\",\r\n \"id\": - \"Storage.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.10.0/24\",\r\n \"20.60.12.0/24\",\r\n \"20.150.10.0/23\",\r\n - \ \"23.98.56.0/26\",\r\n \"52.239.146.0/23\",\r\n \"104.214.152.16/28\",\r\n - \ \"104.214.152.176/28\",\r\n \"104.215.32.16/28\",\r\n \"104.215.32.32/28\",\r\n - \ \"104.215.32.64/27\",\r\n \"104.215.35.32/27\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.KoreaCentral\",\r\n - \ \"id\": \"Storage.KoreaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.46.0/24\",\r\n \"20.60.16.0/24\",\r\n \"20.150.4.0/23\",\r\n - \ \"52.231.80.64/27\",\r\n \"52.231.80.112/28\",\r\n \"52.231.80.128/28\",\r\n - \ \"52.231.80.160/27\",\r\n \"52.239.148.0/27\",\r\n \"52.239.164.192/26\",\r\n - \ \"52.239.190.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.KoreaSouth\",\r\n \"id\": \"Storage.KoreaSouth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.47.0/24\",\r\n - \ \"20.150.14.0/23\",\r\n \"52.231.168.64/27\",\r\n \"52.231.168.112/28\",\r\n - \ \"52.231.168.128/28\",\r\n \"52.231.208.16/28\",\r\n \"52.231.208.32/28\",\r\n - \ \"52.239.165.0/26\",\r\n \"52.239.165.160/27\",\r\n \"52.239.190.192/26\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.NorthCentralUS\",\r\n - \ \"id\": \"Storage.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.3.0/24\",\r\n \"20.47.15.0/24\",\r\n \"20.150.17.0/25\",\r\n - \ \"20.150.25.0/24\",\r\n \"20.150.49.0/24\",\r\n \"20.150.67.0/24\",\r\n - \ \"20.150.126.0/24\",\r\n \"23.98.49.0/26\",\r\n \"23.98.49.192/26\",\r\n - \ \"23.98.55.0/26\",\r\n \"23.98.55.112/28\",\r\n \"23.98.55.144/28\",\r\n - \ \"40.116.120.16/28\",\r\n \"40.116.232.16/28\",\r\n \"40.116.232.48/28\",\r\n - \ \"40.116.232.96/28\",\r\n \"52.162.56.16/28\",\r\n \"52.162.56.32/28\",\r\n - \ \"52.162.56.64/27\",\r\n \"52.162.56.112/28\",\r\n \"52.162.56.128/28\",\r\n - \ \"52.239.149.0/24\",\r\n \"52.239.186.0/24\",\r\n \"52.239.253.0/24\",\r\n - \ \"157.56.216.0/26\",\r\n \"168.62.96.128/26\",\r\n \"168.62.96.210/32\",\r\n - \ \"168.62.96.224/27\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.NorthCentralUSStage\",\r\n \"id\": \"Storage.NorthCentralUSStage\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"northcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"168.62.96.192/29\",\r\n - \ \"168.62.96.200/30\",\r\n \"168.62.96.204/32\",\r\n \"168.62.96.206/31\",\r\n - \ \"168.62.96.208/32\",\r\n \"168.62.96.212/30\",\r\n \"168.62.96.216/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.NorthEurope\",\r\n - \ \"id\": \"Storage.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.70.208.16/28\",\r\n \"13.74.208.64/28\",\r\n - \ \"13.74.208.112/28\",\r\n \"13.74.208.144/28\",\r\n \"13.79.176.16/28\",\r\n - \ \"13.79.176.48/28\",\r\n \"13.79.176.80/28\",\r\n \"20.38.102.0/23\",\r\n - \ \"20.47.8.0/24\",\r\n \"20.47.20.0/23\",\r\n \"20.47.32.0/24\",\r\n - \ \"20.60.19.0/24\",\r\n \"20.150.26.0/24\",\r\n \"20.150.47.128/25\",\r\n - \ \"20.150.48.0/24\",\r\n \"20.150.75.0/24\",\r\n \"20.150.84.0/24\",\r\n - \ \"20.150.104.0/24\",\r\n \"40.85.105.32/28\",\r\n \"40.113.27.176/28\",\r\n - \ \"52.164.112.16/28\",\r\n \"52.164.232.16/28\",\r\n \"52.164.232.32/28\",\r\n - \ \"52.164.232.64/28\",\r\n \"52.169.168.32/27\",\r\n \"52.169.240.16/28\",\r\n - \ \"52.169.240.32/28\",\r\n \"52.169.240.64/28\",\r\n \"52.178.168.32/27\",\r\n - \ \"52.178.168.80/28\",\r\n \"52.178.168.96/28\",\r\n \"52.178.168.128/27\",\r\n - \ \"52.236.40.16/28\",\r\n \"52.236.40.32/28\",\r\n \"52.239.136.0/22\",\r\n - \ \"52.239.205.0/24\",\r\n \"52.239.248.0/24\",\r\n \"52.245.40.0/24\",\r\n - \ \"104.41.232.16/28\",\r\n \"137.135.192.64/26\",\r\n \"137.135.192.192/26\",\r\n - \ \"137.135.193.192/26\",\r\n \"137.135.194.0/25\",\r\n \"137.135.194.192/26\",\r\n - \ \"168.61.120.32/27\",\r\n \"168.61.120.64/27\",\r\n \"168.61.121.0/26\",\r\n - \ \"168.63.32.0/26\",\r\n \"168.63.33.192/26\",\r\n \"191.235.192.192/26\",\r\n - \ \"191.235.193.32/28\",\r\n \"191.235.255.192/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.NorwayEast\",\r\n - \ \"id\": \"Storage.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.38.120.0/24\",\r\n \"20.47.48.0/24\",\r\n \"20.150.53.0/24\",\r\n - \ \"20.150.121.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.NorwayWest\",\r\n \"id\": \"Storage.NorwayWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.49.0/24\",\r\n - \ \"20.60.15.0/24\",\r\n \"20.150.0.0/24\",\r\n \"20.150.56.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.SouthAfricaNorth\",\r\n - \ \"id\": \"Storage.SouthAfricaNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.114.128/25\",\r\n \"20.47.50.0/24\",\r\n - \ \"20.150.21.0/24\",\r\n \"20.150.62.0/24\",\r\n \"20.150.101.0/24\",\r\n - \ \"52.239.232.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.SouthAfricaWest\",\r\n \"id\": \"Storage.SouthAfricaWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.121.0/25\",\r\n - \ \"20.47.51.0/24\",\r\n \"20.60.8.0/24\",\r\n \"20.150.20.0/25\",\r\n - \ \"52.239.232.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.SouthCentralUS\",\r\n \"id\": \"Storage.SouthCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.65.107.32/28\",\r\n - \ \"13.65.160.16/28\",\r\n \"13.65.160.48/28\",\r\n \"13.65.160.64/28\",\r\n - \ \"13.84.56.16/28\",\r\n \"13.85.88.16/28\",\r\n \"13.85.200.128/28\",\r\n - \ \"20.38.104.0/23\",\r\n \"20.47.0.0/27\",\r\n \"20.47.24.0/23\",\r\n - \ \"20.47.29.0/24\",\r\n \"20.150.20.128/25\",\r\n \"20.150.38.0/23\",\r\n - \ \"20.150.70.0/24\",\r\n \"20.150.79.0/24\",\r\n \"20.150.93.0/24\",\r\n - \ \"20.150.94.0/24\",\r\n \"23.98.160.64/26\",\r\n \"23.98.162.192/26\",\r\n - \ \"23.98.168.0/24\",\r\n \"23.98.192.64/26\",\r\n \"23.98.255.64/26\",\r\n - \ \"52.171.144.32/27\",\r\n \"52.171.144.80/28\",\r\n \"52.171.144.96/28\",\r\n - \ \"52.171.144.128/28\",\r\n \"52.185.233.0/24\",\r\n \"52.189.177.0/24\",\r\n - \ \"52.239.158.0/23\",\r\n \"52.239.178.0/23\",\r\n \"52.239.180.0/22\",\r\n - \ \"52.239.199.0/24\",\r\n \"52.239.200.0/23\",\r\n \"52.239.203.0/24\",\r\n - \ \"52.239.204.0/24\",\r\n \"52.239.208.0/23\",\r\n \"104.214.40.16/28\",\r\n - \ \"104.214.80.16/28\",\r\n \"104.214.80.48/28\",\r\n \"104.215.104.64/28\",\r\n - \ \"168.62.128.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.SoutheastAsia\",\r\n \"id\": \"Storage.SoutheastAsia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.76.104.16/28\",\r\n - \ \"20.47.9.0/24\",\r\n \"20.47.33.0/24\",\r\n \"20.150.17.128/25\",\r\n - \ \"20.150.28.0/24\",\r\n \"20.150.86.0/24\",\r\n \"20.150.127.0/24\",\r\n - \ \"52.163.176.16/28\",\r\n \"52.163.232.16/28\",\r\n \"52.187.141.32/27\",\r\n - \ \"52.237.104.16/28\",\r\n \"52.237.104.32/28\",\r\n \"52.239.129.0/24\",\r\n - \ \"52.239.197.0/24\",\r\n \"52.239.227.0/24\",\r\n \"52.239.249.0/24\",\r\n - \ \"104.43.80.16/28\",\r\n \"104.215.240.64/28\",\r\n \"104.215.240.96/28\",\r\n - \ \"168.63.160.0/26\",\r\n \"168.63.160.192/26\",\r\n \"168.63.161.64/26\",\r\n - \ \"168.63.161.160/27\",\r\n \"168.63.161.192/26\",\r\n \"168.63.162.32/27\",\r\n - \ \"168.63.162.64/26\",\r\n \"168.63.162.144/28\",\r\n \"168.63.162.192/26\",\r\n - \ \"168.63.163.128/26\",\r\n \"168.63.180.64/26\",\r\n \"191.238.64.64/26\",\r\n - \ \"191.238.64.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.SouthIndia\",\r\n \"id\": \"Storage.SouthIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.52.0/24\",\r\n - \ \"20.60.10.0/24\",\r\n \"20.150.24.0/24\",\r\n \"52.172.16.16/28\",\r\n - \ \"52.172.16.80/28\",\r\n \"52.172.16.96/28\",\r\n \"52.172.16.128/27\",\r\n - \ \"52.239.135.128/26\",\r\n \"52.239.188.0/24\",\r\n \"104.211.232.16/28\",\r\n - \ \"104.211.232.48/28\",\r\n \"104.211.232.80/28\",\r\n \"104.211.232.176/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.SwitzerlandNorth\",\r\n - \ \"id\": \"Storage.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n - \ \"addressPrefixes\": [\r\n \"20.47.53.0/24\",\r\n \"20.150.59.0/24\",\r\n - \ \"20.150.118.0/24\",\r\n \"52.239.251.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.SwitzerlandWest\",\r\n - \ \"id\": \"Storage.SwitzerlandWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n - \ \"addressPrefixes\": [\r\n \"20.47.26.0/24\",\r\n \"20.150.55.0/24\",\r\n - \ \"20.150.116.0/24\",\r\n \"52.239.250.0/24\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.UAECentral\",\r\n - \ \"id\": \"Storage.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.47.54.0/24\",\r\n \"20.150.6.0/23\",\r\n \"20.150.115.0/24\",\r\n - \ \"52.239.233.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.UAENorth\",\r\n \"id\": \"Storage.UAENorth\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.124.0/23\",\r\n - \ \"20.47.55.0/24\",\r\n \"52.239.233.128/25\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.UKNorth\",\r\n \"id\": - \"Storage.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.87.104.64/28\",\r\n - \ \"13.87.104.96/28\",\r\n \"20.150.46.0/24\",\r\n \"51.141.129.32/27\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.UKSouth\",\r\n - \ \"id\": \"Storage.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"20.38.106.0/23\",\r\n \"20.47.11.0/24\",\r\n \"20.47.34.0/24\",\r\n - \ \"20.60.17.0/24\",\r\n \"20.150.18.0/25\",\r\n \"20.150.40.0/25\",\r\n - \ \"20.150.41.0/24\",\r\n \"20.150.69.0/24\",\r\n \"51.140.16.16/28\",\r\n - \ \"51.140.16.32/28\",\r\n \"51.140.168.64/27\",\r\n \"51.140.168.112/28\",\r\n - \ \"51.140.168.128/28\",\r\n \"51.141.128.32/27\",\r\n \"51.141.129.64/26\",\r\n - \ \"51.141.130.0/25\",\r\n \"52.239.187.0/25\",\r\n \"52.239.231.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.UKSouth2\",\r\n - \ \"id\": \"Storage.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.87.40.64/28\",\r\n - \ \"13.87.40.96/28\",\r\n \"20.150.27.0/24\",\r\n \"51.141.129.0/27\",\r\n - \ \"51.141.129.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.UKWest\",\r\n \"id\": \"Storage.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.56.0/24\",\r\n - \ \"20.150.2.0/23\",\r\n \"20.150.52.0/24\",\r\n \"20.150.110.0/24\",\r\n - \ \"51.140.232.64/27\",\r\n \"51.140.232.112/28\",\r\n \"51.140.232.128/28\",\r\n - \ \"51.140.232.160/27\",\r\n \"51.141.128.0/27\",\r\n \"51.141.128.64/26\",\r\n - \ \"51.141.128.128/25\",\r\n \"51.141.129.128/26\",\r\n \"52.239.240.0/24\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.WestCentralUS\",\r\n - \ \"id\": \"Storage.WestCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.71.200.64/28\",\r\n - \ \"13.71.200.96/28\",\r\n \"13.71.200.240/28\",\r\n \"13.71.202.16/28\",\r\n - \ \"13.71.202.32/28\",\r\n \"13.71.202.64/27\",\r\n \"13.78.152.64/28\",\r\n - \ \"13.78.240.16/28\",\r\n \"20.47.4.0/24\",\r\n \"20.60.4.0/24\",\r\n - \ \"20.150.81.0/24\",\r\n \"20.150.98.0/24\",\r\n \"52.161.112.16/28\",\r\n - \ \"52.161.112.32/28\",\r\n \"52.161.168.16/28\",\r\n \"52.161.168.32/28\",\r\n - \ \"52.239.164.0/25\",\r\n \"52.239.167.0/24\",\r\n \"52.239.244.0/23\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.WestEurope\",\r\n - \ \"id\": \"Storage.WestEurope\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.69.40.16/28\",\r\n \"13.95.96.176/28\",\r\n \"13.95.240.16/28\",\r\n - \ \"13.95.240.32/28\",\r\n \"13.95.240.64/27\",\r\n \"20.38.108.0/23\",\r\n - \ \"20.47.7.0/24\",\r\n \"20.47.18.0/23\",\r\n \"20.47.30.0/24\",\r\n - \ \"20.150.8.0/23\",\r\n \"20.150.37.0/24\",\r\n \"20.150.42.0/24\",\r\n - \ \"20.150.74.0/24\",\r\n \"20.150.76.0/24\",\r\n \"20.150.83.0/24\",\r\n - \ \"20.150.122.0/24\",\r\n \"40.68.176.16/28\",\r\n \"40.68.176.48/28\",\r\n - \ \"40.68.232.16/28\",\r\n \"40.68.232.48/28\",\r\n \"40.114.152.16/28\",\r\n - \ \"40.114.152.48/28\",\r\n \"40.118.72.176/28\",\r\n \"40.118.73.48/28\",\r\n - \ \"40.118.73.176/28\",\r\n \"40.118.73.208/28\",\r\n \"52.166.80.32/27\",\r\n - \ \"52.166.80.80/28\",\r\n \"52.166.80.96/28\",\r\n \"52.174.8.32/28\",\r\n - \ \"52.174.224.16/28\",\r\n \"52.174.224.32/28\",\r\n \"52.174.224.64/27\",\r\n - \ \"52.174.224.112/28\",\r\n \"52.174.224.128/28\",\r\n \"52.236.240.48/28\",\r\n - \ \"52.236.240.64/28\",\r\n \"52.239.140.0/22\",\r\n \"52.239.212.0/23\",\r\n - \ \"52.239.242.0/23\",\r\n \"104.214.243.32/28\",\r\n \"168.61.57.64/26\",\r\n - \ \"168.61.57.128/25\",\r\n \"168.61.58.0/26\",\r\n \"168.61.58.128/26\",\r\n - \ \"168.61.59.64/26\",\r\n \"168.61.61.0/26\",\r\n \"168.61.61.192/26\",\r\n - \ \"168.63.0.0/26\",\r\n \"168.63.2.64/26\",\r\n \"168.63.3.32/27\",\r\n - \ \"168.63.3.64/27\",\r\n \"168.63.113.32/27\",\r\n \"168.63.113.64/27\",\r\n - \ \"191.237.232.32/28\",\r\n \"191.237.232.128/28\",\r\n - \ \"191.239.203.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"Storage.WestIndia\",\r\n \"id\": \"Storage.WestIndia\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.57.0/24\",\r\n - \ \"20.150.18.128/25\",\r\n \"20.150.43.0/25\",\r\n \"20.150.106.0/24\",\r\n - \ \"52.239.135.192/26\",\r\n \"52.239.187.128/25\",\r\n \"104.211.168.16/28\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.WestUS\",\r\n - \ \"id\": \"Storage.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.83.72.16/28\",\r\n \"13.88.144.112/28\",\r\n - \ \"13.88.144.240/28\",\r\n \"13.88.145.64/28\",\r\n \"13.88.145.96/28\",\r\n - \ \"13.88.145.128/28\",\r\n \"13.93.168.80/28\",\r\n \"13.93.168.112/28\",\r\n - \ \"13.93.168.144/28\",\r\n \"20.47.2.0/24\",\r\n \"20.47.22.0/23\",\r\n - \ \"20.150.34.0/23\",\r\n \"20.150.91.0/24\",\r\n \"20.150.102.0/24\",\r\n - \ \"20.157.32.0/24\",\r\n \"23.99.32.64/26\",\r\n \"23.99.34.224/28\",\r\n - \ \"23.99.37.96/28\",\r\n \"23.99.47.32/28\",\r\n \"40.78.72.16/28\",\r\n - \ \"40.78.112.64/28\",\r\n \"40.83.225.32/28\",\r\n \"40.83.227.16/28\",\r\n - \ \"40.112.152.16/28\",\r\n \"40.112.224.16/28\",\r\n \"40.112.224.48/28\",\r\n - \ \"52.180.40.16/28\",\r\n \"52.180.40.32/28\",\r\n \"52.190.240.16/28\",\r\n - \ \"52.190.240.32/28\",\r\n \"52.190.240.64/27\",\r\n \"52.190.240.112/28\",\r\n - \ \"52.190.240.128/28\",\r\n \"52.225.40.32/27\",\r\n \"52.238.56.16/28\",\r\n - \ \"52.238.56.32/28\",\r\n \"52.238.56.64/27\",\r\n \"52.238.56.112/28\",\r\n - \ \"52.238.56.128/28\",\r\n \"52.238.56.160/27\",\r\n \"52.239.104.16/28\",\r\n - \ \"52.239.104.32/28\",\r\n \"52.239.160.0/22\",\r\n \"52.239.228.0/23\",\r\n - \ \"52.239.254.0/23\",\r\n \"52.241.88.16/28\",\r\n \"52.241.88.32/28\",\r\n - \ \"52.241.88.64/27\",\r\n \"104.42.200.16/28\",\r\n \"138.91.128.128/26\",\r\n - \ \"138.91.129.0/26\",\r\n \"168.62.0.0/26\",\r\n \"168.62.1.128/26\",\r\n - \ \"168.63.89.64/26\",\r\n \"168.63.89.128/26\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"Storage.WestUS2\",\r\n \"id\": - \"Storage.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": - [\r\n \"13.66.176.16/28\",\r\n \"13.66.176.48/28\",\r\n - \ \"13.66.232.64/28\",\r\n \"13.66.232.208/28\",\r\n \"13.66.232.224/28\",\r\n - \ \"13.66.234.0/27\",\r\n \"13.77.184.64/28\",\r\n \"20.38.99.0/24\",\r\n - \ \"20.47.62.0/23\",\r\n \"20.60.20.0/24\",\r\n \"20.150.68.0/24\",\r\n - \ \"20.150.78.0/24\",\r\n \"20.150.87.0/24\",\r\n \"20.150.107.0/24\",\r\n - \ \"52.183.48.16/28\",\r\n \"52.183.104.16/28\",\r\n \"52.183.104.32/28\",\r\n - \ \"52.191.176.16/28\",\r\n \"52.191.176.32/28\",\r\n \"52.239.148.128/25\",\r\n - \ \"52.239.176.128/25\",\r\n \"52.239.193.0/24\",\r\n \"52.239.210.0/23\",\r\n - \ \"52.239.236.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"StorageSyncService\",\r\n \"id\": \"StorageSyncService\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"13.70.176.196/32\",\r\n \"13.73.248.112/29\",\r\n - \ \"13.75.153.240/32\",\r\n \"13.76.81.46/32\",\r\n \"20.36.120.216/29\",\r\n - \ \"20.37.64.216/29\",\r\n \"20.37.157.80/29\",\r\n \"20.37.195.96/29\",\r\n - \ \"20.37.224.216/29\",\r\n \"20.38.85.152/29\",\r\n \"20.38.136.224/29\",\r\n - \ \"20.39.11.96/29\",\r\n \"20.41.5.144/29\",\r\n \"20.41.65.184/29\",\r\n - \ \"20.41.193.160/29\",\r\n \"20.42.4.248/29\",\r\n \"20.42.131.224/29\",\r\n - \ \"20.42.227.128/29\",\r\n \"20.43.42.8/29\",\r\n \"20.43.66.0/29\",\r\n - \ \"20.43.131.40/29\",\r\n \"20.45.71.151/32\",\r\n \"20.45.112.216/29\",\r\n - \ \"20.45.192.248/29\",\r\n \"20.50.1.0/29\",\r\n \"20.150.161.152/29\",\r\n - \ \"20.189.108.56/29\",\r\n \"20.192.161.128/29\",\r\n \"20.192.225.200/29\",\r\n - \ \"23.100.106.151/32\",\r\n \"23.102.225.54/32\",\r\n \"40.67.48.208/29\",\r\n - \ \"40.80.57.192/29\",\r\n \"40.80.169.176/29\",\r\n \"40.80.188.24/29\",\r\n - \ \"40.82.253.192/29\",\r\n \"40.89.17.232/29\",\r\n \"40.112.150.67/32\",\r\n - \ \"40.113.94.67/32\",\r\n \"40.123.47.110/32\",\r\n \"40.123.216.130/32\",\r\n - \ \"51.104.25.224/29\",\r\n \"51.105.80.208/29\",\r\n \"51.105.88.248/29\",\r\n - \ \"51.107.48.224/29\",\r\n \"51.107.144.216/29\",\r\n \"51.120.40.224/29\",\r\n - \ \"51.120.224.216/29\",\r\n \"51.137.161.240/29\",\r\n \"51.140.67.72/32\",\r\n - \ \"51.140.202.34/32\",\r\n \"51.143.192.208/29\",\r\n \"52.136.48.216/29\",\r\n - \ \"52.136.131.99/32\",\r\n \"52.140.105.184/29\",\r\n \"52.143.166.54/32\",\r\n - \ \"52.150.139.104/29\",\r\n \"52.161.25.233/32\",\r\n \"52.176.149.179/32\",\r\n - \ \"52.183.27.204/32\",\r\n \"52.225.171.85/32\",\r\n \"52.228.42.41/32\",\r\n - \ \"52.228.81.248/29\",\r\n \"52.231.67.75/32\",\r\n \"52.231.159.38/32\",\r\n - \ \"52.235.36.119/32\",\r\n \"65.52.62.167/32\",\r\n \"102.133.56.128/29\",\r\n - \ \"102.133.75.173/32\",\r\n \"102.133.175.72/32\",\r\n \"104.40.191.8/32\",\r\n - \ \"104.41.148.238/32\",\r\n \"104.41.161.113/32\",\r\n \"104.208.61.223/32\",\r\n - \ \"104.210.219.252/32\",\r\n \"104.211.73.56/32\",\r\n \"104.211.231.18/32\",\r\n - \ \"191.233.9.96/29\",\r\n \"191.235.225.216/29\",\r\n \"191.237.253.115/32\",\r\n - \ \"2603:1000:104:1::300/123\",\r\n \"2603:1010:6:1::300/123\",\r\n - \ \"2603:1020:5:1::300/123\",\r\n \"2603:1020:206:1::300/123\",\r\n - \ \"2603:1020:705:1::300/123\",\r\n \"2603:1020:805:1::300/123\",\r\n - \ \"2603:1020:a04:1::300/123\",\r\n \"2603:1020:c04:1::300/123\",\r\n - \ \"2603:1020:e04:1::300/123\",\r\n \"2603:1020:1004::300/123\",\r\n - \ \"2603:1030:10:1::300/123\",\r\n \"2603:1030:104:1::300/123\",\r\n - \ \"2603:1030:210:1::300/123\",\r\n \"2603:1030:40b:1::300/123\",\r\n - \ \"2603:1030:40c:1::300/123\",\r\n \"2603:1030:504:1::300/123\",\r\n - \ \"2603:1030:807:1::300/123\",\r\n \"2603:1030:c06:1::300/123\",\r\n - \ \"2603:1030:f05:1::300/123\",\r\n \"2603:1040:5:1::300/123\",\r\n - \ \"2603:1040:407:1::300/123\",\r\n \"2603:1040:904:1::300/123\",\r\n - \ \"2603:1040:a06:1::300/123\",\r\n \"2603:1040:d04::300/123\",\r\n - \ \"2603:1040:f05:1::300/123\",\r\n \"2603:1050:6:1::300/123\",\r\n - \ \"2603:1050:403::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.AustraliaCentral\",\r\n \"id\": - \"StorageSyncService.AustraliaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiacentral\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.37.224.216/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.AustraliaCentral2\",\r\n \"id\": - \"StorageSyncService.AustraliaCentral2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiacentral2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.36.120.216/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.AustraliaEast\",\r\n \"id\": - \"StorageSyncService.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"13.75.153.240/32\",\r\n \"20.37.195.96/29\",\r\n - \ \"2603:1010:6:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.AustraliaSoutheast\",\r\n \"id\": - \"StorageSyncService.AustraliaSoutheast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.176.196/32\",\r\n \"20.42.227.128/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.BrazilSouth\",\r\n - \ \"id\": \"StorageSyncService.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"191.235.225.216/29\",\r\n \"191.237.253.115/32\",\r\n - \ \"2603:1050:6:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.CanadaCentral\",\r\n \"id\": - \"StorageSyncService.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"52.228.42.41/32\",\r\n \"52.228.81.248/29\",\r\n - \ \"2603:1030:f05:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.CanadaEast\",\r\n \"id\": - \"StorageSyncService.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"40.89.17.232/29\",\r\n \"52.235.36.119/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.CentralIndia\",\r\n - \ \"id\": \"StorageSyncService.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"52.140.105.184/29\",\r\n \"104.211.73.56/32\",\r\n - \ \"2603:1040:a06:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.CentralUS\",\r\n \"id\": - \"StorageSyncService.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.37.157.80/29\",\r\n \"52.176.149.179/32\",\r\n - \ \"2603:1030:10:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.CentralUSEUAP\",\r\n \"id\": - \"StorageSyncService.CentralUSEUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.45.192.248/29\",\r\n \"104.208.61.223/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastAsia\",\r\n - \ \"id\": \"StorageSyncService.EastAsia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.189.108.56/29\",\r\n \"23.102.225.54/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastUS\",\r\n - \ \"id\": \"StorageSyncService.EastUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.42.4.248/29\",\r\n \"104.41.148.238/32\",\r\n - \ \"2603:1030:210:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.EastUS2\",\r\n \"id\": - \"StorageSyncService.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.41.5.144/29\",\r\n \"40.123.47.110/32\",\r\n - \ \"2603:1030:40c:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.EastUS2EUAP\",\r\n \"id\": - \"StorageSyncService.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.39.11.96/29\",\r\n \"52.225.171.85/32\",\r\n - \ \"2603:1030:40b:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.FranceCentral\",\r\n \"id\": - \"StorageSyncService.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.43.42.8/29\",\r\n \"52.143.166.54/32\",\r\n \"2603:1020:805:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.FranceSouth\",\r\n - \ \"id\": \"StorageSyncService.FranceSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.105.88.248/29\",\r\n \"52.136.131.99/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.GermanyWestCentral\",\r\n - \ \"id\": \"StorageSyncService.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"2603:1020:c04:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.JapanEast\",\r\n - \ \"id\": \"StorageSyncService.JapanEast\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.43.66.0/29\",\r\n \"104.41.161.113/32\",\r\n - \ \"2603:1040:407:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.JapanWest\",\r\n \"id\": - \"StorageSyncService.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"23.100.106.151/32\",\r\n \"40.80.57.192/29\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.KoreaCentral\",\r\n - \ \"id\": \"StorageSyncService.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.65.184/29\",\r\n \"52.231.67.75/32\",\r\n - \ \"2603:1040:f05:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.KoreaSouth\",\r\n \"id\": - \"StorageSyncService.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"40.80.169.176/29\",\r\n \"52.231.159.38/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorthCentralUS\",\r\n - \ \"id\": \"StorageSyncService.NorthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"40.80.188.24/29\",\r\n \"65.52.62.167/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorthEurope\",\r\n - \ \"id\": \"StorageSyncService.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.85.152/29\",\r\n \"40.113.94.67/32\",\r\n - \ \"2603:1020:5:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.NorwayEast\",\r\n \"id\": - \"StorageSyncService.NorwayEast\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"51.120.40.224/29\",\r\n \"2603:1020:e04:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorwayWest\",\r\n - \ \"id\": \"StorageSyncService.NorwayWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.120.224.216/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthAfricaNorth\",\r\n - \ \"id\": \"StorageSyncService.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.175.72/32\",\r\n \"2603:1000:104:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthAfricaWest\",\r\n - \ \"id\": \"StorageSyncService.SouthAfricaWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"102.133.56.128/29\",\r\n \"102.133.75.173/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthCentralUS\",\r\n - \ \"id\": \"StorageSyncService.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.248.112/29\",\r\n \"104.210.219.252/32\",\r\n - \ \"2603:1030:807:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.SoutheastAsia\",\r\n \"id\": - \"StorageSyncService.SoutheastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"13.76.81.46/32\",\r\n \"20.43.131.40/29\",\r\n \"2603:1040:5:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthIndia\",\r\n - \ \"id\": \"StorageSyncService.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.193.160/29\",\r\n \"104.211.231.18/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SwitzerlandNorth\",\r\n - \ \"id\": \"StorageSyncService.SwitzerlandNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.48.224/29\",\r\n \"2603:1020:a04:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SwitzerlandWest\",\r\n - \ \"id\": \"StorageSyncService.SwitzerlandWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.144.216/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.UAECentral\",\r\n - \ \"id\": \"StorageSyncService.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.37.64.216/29\",\r\n \"20.45.71.151/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.UAENorth\",\r\n - \ \"id\": \"StorageSyncService.UAENorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"20.38.136.224/29\",\r\n \"40.123.216.130/32\",\r\n - \ \"2603:1040:904:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.UKNorth\",\r\n \"id\": - \"StorageSyncService.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"51.105.80.208/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.UKSouth\",\r\n \"id\": - \"StorageSyncService.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"51.104.25.224/29\",\r\n \"51.140.67.72/32\",\r\n - \ \"2603:1020:705:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.UKSouth2\",\r\n \"id\": - \"StorageSyncService.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"51.143.192.208/29\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"StorageSyncService.UKWest\",\r\n \"id\": \"StorageSyncService.UKWest\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"51.137.161.240/29\",\r\n - \ \"51.140.202.34/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"StorageSyncService.WestCentralUS\",\r\n \"id\": \"StorageSyncService.WestCentralUS\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"52.150.139.104/29\",\r\n - \ \"52.161.25.233/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"StorageSyncService.WestEurope\",\r\n \"id\": \"StorageSyncService.WestEurope\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"20.50.1.0/29\",\r\n - \ \"104.40.191.8/32\",\r\n \"2603:1020:206:1::300/123\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestIndia\",\r\n - \ \"id\": \"StorageSyncService.WestIndia\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\",\r\n - \ \"addressPrefixes\": [\r\n \"52.136.48.216/29\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestUS\",\r\n - \ \"id\": \"StorageSyncService.WestUS\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"40.82.253.192/29\",\r\n \"40.112.150.67/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestUS2\",\r\n - \ \"id\": \"StorageSyncService.WestUS2\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": - [\r\n \"20.42.131.224/29\",\r\n \"52.183.27.204/32\",\r\n - \ \"2603:1030:c06:1::300/123\"\r\n ]\r\n }\r\n },\r\n - \ {\r\n \"name\": \"WindowsVirtualDesktop\",\r\n \"id\": \"WindowsVirtualDesktop\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n - \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n - \ \"systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": - [\r\n \"13.66.251.49/32\",\r\n \"13.67.68.78/32\",\r\n \"13.68.76.104/32\",\r\n - \ \"13.69.82.138/32\",\r\n \"13.69.156.85/32\",\r\n \"13.70.40.201/32\",\r\n - \ \"13.70.120.215/32\",\r\n \"13.71.5.20/32\",\r\n \"13.71.67.87/32\",\r\n - \ \"13.71.81.161/32\",\r\n \"13.71.113.6/32\",\r\n \"13.73.237.154/32\",\r\n - \ \"13.75.114.143/32\",\r\n \"13.75.171.61/32\",\r\n \"13.75.198.169/32\",\r\n - \ \"13.76.88.89/32\",\r\n \"13.76.195.19/32\",\r\n \"13.76.230.148/32\",\r\n - \ \"13.77.45.213/32\",\r\n \"13.77.140.58/32\",\r\n \"13.79.243.194/32\",\r\n - \ \"13.88.221.28/32\",\r\n \"13.88.254.98/32\",\r\n \"20.36.33.29/32\",\r\n - \ \"20.36.33.170/32\",\r\n \"20.36.35.190/32\",\r\n \"20.36.38.195/32\",\r\n - \ \"20.36.39.50/32\",\r\n \"20.36.39.171/32\",\r\n \"20.36.41.74/32\",\r\n - \ \"20.41.77.252/32\",\r\n \"20.45.64.86/32\",\r\n \"20.45.67.112/32\",\r\n - \ \"20.45.67.185/32\",\r\n \"20.45.79.3/32\",\r\n \"20.45.79.24/32\",\r\n - \ \"20.45.79.91/32\",\r\n \"20.45.79.96/32\",\r\n \"20.45.79.168/32\",\r\n - \ \"20.188.3.1/32\",\r\n \"20.188.39.108/32\",\r\n \"20.188.41.240/32\",\r\n - \ \"20.188.45.82/32\",\r\n \"20.190.43.99/32\",\r\n \"23.97.108.170/32\",\r\n - \ \"23.98.66.174/32\",\r\n \"23.98.133.187/32\",\r\n \"23.99.141.138/32\",\r\n - \ \"23.100.50.154/32\",\r\n \"23.100.98.36/32\",\r\n \"23.101.5.54/32\",\r\n - \ \"23.101.220.135/32\",\r\n \"23.102.229.113/32\",\r\n \"40.65.122.222/32\",\r\n - \ \"40.68.18.120/32\",\r\n \"40.69.31.73/32\",\r\n \"40.69.90.166/32\",\r\n - \ \"40.69.102.46/32\",\r\n \"40.69.149.151/32\",\r\n \"40.70.189.87/32\",\r\n - \ \"40.74.84.253/32\",\r\n \"40.74.113.202/32\",\r\n \"40.74.118.163/32\",\r\n - \ \"40.74.136.34/32\",\r\n \"40.83.79.39/32\",\r\n \"40.85.241.159/32\",\r\n - \ \"40.86.204.245/32\",\r\n \"40.86.205.216/32\",\r\n \"40.86.208.118/32\",\r\n - \ \"40.86.222.183/32\",\r\n \"40.89.129.146/32\",\r\n \"40.89.154.76/32\",\r\n - \ \"40.113.199.138/32\",\r\n \"40.113.200.58/32\",\r\n \"40.114.241.90/32\",\r\n - \ \"40.115.136.175/32\",\r\n \"40.122.28.196/32\",\r\n \"40.122.212.20/32\",\r\n - \ \"40.127.3.207/32\",\r\n \"51.11.13.248/32\",\r\n \"51.11.241.142/32\",\r\n - \ \"51.104.49.88/32\",\r\n \"51.105.54.123/32\",\r\n \"51.107.68.172/32\",\r\n - \ \"51.107.69.35/32\",\r\n \"51.107.78.168/32\",\r\n \"51.107.85.67/32\",\r\n - \ \"51.107.85.110/32\",\r\n \"51.107.86.7/32\",\r\n \"51.107.86.99/32\",\r\n - \ \"51.116.171.102/32\",\r\n \"51.116.182.248/32\",\r\n \"51.116.225.43/32\",\r\n - \ \"51.116.225.44/32\",\r\n \"51.116.225.55/32\",\r\n \"51.116.236.74/32\",\r\n - \ \"51.116.236.84/32\",\r\n \"51.120.69.158/32\",\r\n \"51.120.70.135/32\",\r\n - \ \"51.120.70.141/32\",\r\n \"51.120.77.155/32\",\r\n \"51.120.78.142/32\",\r\n - \ \"51.120.79.212/32\",\r\n \"51.120.88.120/32\",\r\n \"51.132.29.107/32\",\r\n - \ \"51.136.28.200/32\",\r\n \"51.137.89.79/32\",\r\n \"51.140.57.159/32\",\r\n - \ \"51.140.206.110/32\",\r\n \"51.140.231.223/32\",\r\n \"51.140.255.55/32\",\r\n - \ \"51.141.30.31/32\",\r\n \"51.141.173.236/32\",\r\n \"51.143.39.79/32\",\r\n - \ \"51.143.164.192/32\",\r\n \"51.143.169.107/32\",\r\n \"51.145.17.75/32\",\r\n - \ \"52.137.2.50/32\",\r\n \"52.138.20.115/32\",\r\n \"52.138.28.23/32\",\r\n - \ \"52.141.37.201/32\",\r\n \"52.141.56.101/32\",\r\n \"52.142.161.0/32\",\r\n - \ \"52.142.162.226/32\",\r\n \"52.143.96.87/32\",\r\n \"52.143.182.208/32\",\r\n - \ \"52.147.3.93/32\",\r\n \"52.151.53.196/32\",\r\n \"52.155.111.124/32\",\r\n - \ \"52.156.171.127/32\",\r\n \"52.163.209.255/32\",\r\n \"52.164.126.124/32\",\r\n - \ \"52.165.218.15/32\",\r\n \"52.167.163.135/32\",\r\n \"52.167.171.53/32\",\r\n - \ \"52.169.5.116/32\",\r\n \"52.172.34.74/32\",\r\n \"52.172.40.215/32\",\r\n - \ \"52.172.133.5/32\",\r\n \"52.172.194.109/32\",\r\n \"52.172.210.235/32\",\r\n - \ \"52.172.217.34/32\",\r\n \"52.172.223.46/32\",\r\n \"52.173.89.168/32\",\r\n - \ \"52.175.144.120/32\",\r\n \"52.175.253.156/32\",\r\n \"52.177.123.162/32\",\r\n - \ \"52.177.172.247/32\",\r\n \"52.183.19.64/32\",\r\n \"52.183.130.137/32\",\r\n - \ \"52.185.202.152/32\",\r\n \"52.187.127.152/32\",\r\n \"52.189.194.14/32\",\r\n - \ \"52.189.215.151/32\",\r\n \"52.189.233.158/32\",\r\n \"52.191.129.231/32\",\r\n - \ \"52.228.29.164/32\",\r\n \"52.229.117.254/32\",\r\n \"52.229.125.45/32\",\r\n - \ \"52.229.207.180/32\",\r\n \"52.231.13.193/32\",\r\n \"52.231.38.211/32\",\r\n - \ \"52.231.93.224/32\",\r\n \"52.231.98.58/32\",\r\n \"52.231.155.130/32\",\r\n - \ \"52.231.156.19/32\",\r\n \"52.231.164.163/32\",\r\n \"52.231.166.199/32\",\r\n - \ \"52.231.195.7/32\",\r\n \"52.231.197.195/32\",\r\n \"52.231.206.162/32\",\r\n - \ \"52.233.16.198/32\",\r\n \"52.237.20.14/32\",\r\n \"52.237.201.246/32\",\r\n - \ \"52.237.253.245/32\",\r\n \"52.242.86.101/32\",\r\n \"52.243.65.107/32\",\r\n - \ \"52.243.74.213/32\",\r\n \"52.246.165.140/32\",\r\n \"52.246.177.221/32\",\r\n - \ \"52.246.191.98/32\",\r\n \"52.247.122.225/32\",\r\n \"52.247.123.0/32\",\r\n - \ \"52.255.40.105/32\",\r\n \"52.255.61.145/32\",\r\n \"65.52.71.120/32\",\r\n - \ \"65.52.158.177/32\",\r\n \"70.37.83.67/32\",\r\n \"70.37.86.126/32\",\r\n - \ \"70.37.99.24/32\",\r\n \"102.37.42.159/32\",\r\n \"102.133.161.220/32\",\r\n - \ \"102.133.166.135/32\",\r\n \"102.133.172.191/32\",\r\n - \ \"102.133.175.200/32\",\r\n \"102.133.224.81/32\",\r\n - \ \"102.133.234.139/32\",\r\n \"104.40.156.194/32\",\r\n - \ \"104.41.45.182/32\",\r\n \"104.41.166.159/32\",\r\n \"104.43.169.4/32\",\r\n - \ \"104.46.237.209/32\",\r\n \"104.208.28.82/32\",\r\n \"104.209.233.222/32\",\r\n - \ \"104.210.150.160/32\",\r\n \"104.211.78.17/32\",\r\n \"104.211.114.61/32\",\r\n - \ \"104.211.138.88/32\",\r\n \"104.211.140.190/32\",\r\n - \ \"104.211.155.114/32\",\r\n \"104.211.165.123/32\",\r\n - \ \"104.211.184.150/32\",\r\n \"104.211.188.151/32\",\r\n - \ \"104.211.211.213/32\",\r\n \"104.211.216.230/32\",\r\n - \ \"104.211.242.104/32\",\r\n \"104.214.60.144/32\",\r\n - \ \"104.214.237.23/32\",\r\n \"104.215.51.3/32\",\r\n \"104.215.103.51/32\",\r\n - \ \"137.116.49.12/32\",\r\n \"137.116.248.148/32\",\r\n \"137.117.171.26/32\",\r\n - \ \"137.135.243.65/32\",\r\n \"138.91.44.13/32\",\r\n \"168.61.167.193/32\",\r\n - \ \"168.63.31.54/32\",\r\n \"168.63.71.119/32\",\r\n \"168.63.137.213/32\",\r\n - \ \"191.232.49.74/32\",\r\n \"191.232.166.149/32\",\r\n \"191.232.238.73/32\",\r\n - \ \"191.234.191.63/32\",\r\n \"191.235.65.127/32\",\r\n \"191.235.73.211/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.AustraliaCentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.AustraliaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"20.36.33.29/32\",\r\n \"20.36.33.170/32\",\r\n - \ \"20.36.35.190/32\",\r\n \"20.36.38.195/32\",\r\n \"20.36.39.50/32\",\r\n - \ \"20.36.39.171/32\",\r\n \"20.36.41.74/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.AustraliaEast\",\r\n - \ \"id\": \"WindowsVirtualDesktop.AustraliaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.120.215/32\",\r\n \"13.75.171.61/32\",\r\n - \ \"13.75.198.169/32\",\r\n \"23.101.220.135/32\",\r\n \"52.147.3.93/32\",\r\n - \ \"52.156.171.127/32\",\r\n \"52.237.201.246/32\",\r\n \"52.237.253.245/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.AustraliaSoutheast\",\r\n - \ \"id\": \"WindowsVirtualDesktop.AustraliaSoutheast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.77.45.213/32\",\r\n \"52.189.194.14/32\",\r\n - \ \"52.189.215.151/32\",\r\n \"52.189.233.158/32\",\r\n \"52.243.65.107/32\",\r\n - \ \"52.243.74.213/32\",\r\n \"52.255.40.105/32\",\r\n \"52.255.61.145/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.BrazilSouth\",\r\n - \ \"id\": \"WindowsVirtualDesktop.BrazilSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"23.97.108.170/32\",\r\n \"104.41.45.182/32\",\r\n - \ \"191.232.49.74/32\",\r\n \"191.232.166.149/32\",\r\n \"191.232.238.73/32\",\r\n - \ \"191.234.191.63/32\",\r\n \"191.235.65.127/32\",\r\n \"191.235.73.211/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CanadaCentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.CanadaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.88.254.98/32\",\r\n \"40.85.241.159/32\",\r\n - \ \"52.138.20.115/32\",\r\n \"52.138.28.23/32\",\r\n \"52.228.29.164/32\",\r\n - \ \"52.233.16.198/32\",\r\n \"52.237.20.14/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CanadaEast\",\r\n - \ \"id\": \"WindowsVirtualDesktop.CanadaEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"40.69.102.46/32\",\r\n \"40.86.204.245/32\",\r\n - \ \"40.86.205.216/32\",\r\n \"40.86.208.118/32\",\r\n \"40.86.222.183/32\",\r\n - \ \"52.229.117.254/32\",\r\n \"52.229.125.45/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CentralIndia\",\r\n - \ \"id\": \"WindowsVirtualDesktop.CentralIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.5.20/32\",\r\n \"52.172.133.5/32\",\r\n - \ \"52.172.194.109/32\",\r\n \"52.172.210.235/32\",\r\n \"52.172.217.34/32\",\r\n - \ \"52.172.223.46/32\",\r\n \"104.211.78.17/32\",\r\n \"104.211.114.61/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CentralUS\",\r\n - \ \"id\": \"WindowsVirtualDesktop.CentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"23.99.141.138/32\",\r\n \"40.69.149.151/32\",\r\n - \ \"40.113.199.138/32\",\r\n \"40.113.200.58/32\",\r\n \"40.122.28.196/32\",\r\n - \ \"40.122.212.20/32\",\r\n \"52.165.218.15/32\",\r\n \"52.173.89.168/32\",\r\n - \ \"104.43.169.4/32\",\r\n \"104.208.28.82/32\",\r\n \"168.61.167.193/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.EastAsia\",\r\n - \ \"id\": \"WindowsVirtualDesktop.EastAsia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.70.40.201/32\",\r\n \"13.75.114.143/32\",\r\n - \ \"13.88.221.28/32\",\r\n \"23.101.5.54/32\",\r\n \"23.102.229.113/32\",\r\n - \ \"40.83.79.39/32\",\r\n \"52.229.207.180/32\",\r\n \"168.63.137.213/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.EastUS2\",\r\n - \ \"id\": \"WindowsVirtualDesktop.EastUS2\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.68.76.104/32\",\r\n \"40.70.189.87/32\",\r\n - \ \"52.167.163.135/32\",\r\n \"52.167.171.53/32\",\r\n \"52.177.123.162/32\",\r\n - \ \"52.177.172.247/32\",\r\n \"52.242.86.101/32\",\r\n \"52.247.122.225/32\",\r\n - \ \"52.247.123.0/32\",\r\n \"104.209.233.222/32\",\r\n \"137.116.49.12/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.FranceCentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.FranceCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"20.188.39.108/32\",\r\n \"20.188.41.240/32\",\r\n - \ \"20.188.45.82/32\",\r\n \"40.89.129.146/32\",\r\n \"40.89.154.76/32\",\r\n - \ \"51.11.241.142/32\",\r\n \"52.143.182.208/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.GermanyWestCentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.GermanyWestCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"51.116.171.102/32\",\r\n \"51.116.182.248/32\",\r\n - \ \"51.116.225.43/32\",\r\n \"51.116.225.44/32\",\r\n \"51.116.225.55/32\",\r\n - \ \"51.116.236.74/32\",\r\n \"51.116.236.84/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.JapanEast\",\r\n - \ \"id\": \"WindowsVirtualDesktop.JapanEast\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"20.188.3.1/32\",\r\n \"23.100.98.36/32\",\r\n - \ \"40.115.136.175/32\",\r\n \"52.155.111.124/32\",\r\n \"52.246.165.140/32\",\r\n - \ \"52.246.177.221/32\",\r\n \"52.246.191.98/32\",\r\n \"104.41.166.159/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.JapanWest\",\r\n - \ \"id\": \"WindowsVirtualDesktop.JapanWest\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.73.237.154/32\",\r\n \"40.74.84.253/32\",\r\n - \ \"40.74.113.202/32\",\r\n \"40.74.118.163/32\",\r\n \"40.74.136.34/32\",\r\n - \ \"52.175.144.120/32\",\r\n \"104.46.237.209/32\",\r\n \"104.215.51.3/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.KoreaCentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.KoreaCentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"20.41.77.252/32\",\r\n \"52.141.37.201/32\",\r\n - \ \"52.141.56.101/32\",\r\n \"52.231.13.193/32\",\r\n \"52.231.38.211/32\",\r\n - \ \"52.231.93.224/32\",\r\n \"52.231.98.58/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.KoreaSouth\",\r\n - \ \"id\": \"WindowsVirtualDesktop.KoreaSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"52.231.155.130/32\",\r\n \"52.231.156.19/32\",\r\n - \ \"52.231.164.163/32\",\r\n \"52.231.166.199/32\",\r\n \"52.231.195.7/32\",\r\n - \ \"52.231.197.195/32\",\r\n \"52.231.206.162/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.NorthEurope\",\r\n - \ \"id\": \"WindowsVirtualDesktop.NorthEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.156.85/32\",\r\n \"13.79.243.194/32\",\r\n - \ \"23.100.50.154/32\",\r\n \"40.69.31.73/32\",\r\n \"40.69.90.166/32\",\r\n - \ \"52.164.126.124/32\",\r\n \"52.169.5.116/32\",\r\n \"65.52.71.120/32\",\r\n - \ \"137.116.248.148/32\",\r\n \"137.135.243.65/32\",\r\n - \ \"168.63.71.119/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"WindowsVirtualDesktop.NorwayEast\",\r\n \"id\": \"WindowsVirtualDesktop.NorwayEast\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \"51.120.69.158/32\",\r\n - \ \"51.120.70.135/32\",\r\n \"51.120.70.141/32\",\r\n \"51.120.77.155/32\",\r\n - \ \"51.120.78.142/32\",\r\n \"51.120.79.212/32\",\r\n \"51.120.88.120/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.SouthAfricaNorth\",\r\n - \ \"id\": \"WindowsVirtualDesktop.SouthAfricaNorth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"40.127.3.207/32\",\r\n \"102.37.42.159/32\",\r\n - \ \"102.133.161.220/32\",\r\n \"102.133.166.135/32\",\r\n - \ \"102.133.172.191/32\",\r\n \"102.133.175.200/32\",\r\n - \ \"102.133.224.81/32\",\r\n \"102.133.234.139/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.SouthCentralUS\",\r\n - \ \"id\": \"WindowsVirtualDesktop.SouthCentralUS\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"23.98.133.187/32\",\r\n \"52.185.202.152/32\",\r\n - \ \"70.37.83.67/32\",\r\n \"70.37.86.126/32\",\r\n \"70.37.99.24/32\",\r\n - \ \"104.210.150.160/32\",\r\n \"104.214.60.144/32\",\r\n - \ \"104.215.103.51/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"WindowsVirtualDesktop.SoutheastAsia\",\r\n \"id\": - \"WindowsVirtualDesktop.SoutheastAsia\",\r\n \"properties\": {\r\n \"changeNumber\": - \"1\",\r\n \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n - \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": - [\r\n \"13.67.68.78/32\",\r\n \"13.76.88.89/32\",\r\n \"13.76.195.19/32\",\r\n - \ \"13.76.230.148/32\",\r\n \"23.98.66.174/32\",\r\n \"52.163.209.255/32\",\r\n - \ \"52.187.127.152/32\",\r\n \"138.91.44.13/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.SouthIndia\",\r\n - \ \"id\": \"WindowsVirtualDesktop.SouthIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.71.67.87/32\",\r\n \"13.71.81.161/32\",\r\n - \ \"13.71.113.6/32\",\r\n \"52.172.34.74/32\",\r\n \"52.172.40.215/32\",\r\n - \ \"104.211.211.213/32\",\r\n \"104.211.216.230/32\",\r\n - \ \"104.211.242.104/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"WindowsVirtualDesktop.SwitzerlandNorth\",\r\n \"id\": - \"WindowsVirtualDesktop.SwitzerlandNorth\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"51.107.68.172/32\",\r\n \"51.107.69.35/32\",\r\n - \ \"51.107.78.168/32\",\r\n \"51.107.85.67/32\",\r\n \"51.107.85.110/32\",\r\n - \ \"51.107.86.7/32\",\r\n \"51.107.86.99/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.UAECentral\",\r\n - \ \"id\": \"WindowsVirtualDesktop.UAECentral\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"20.45.64.86/32\",\r\n \"20.45.67.112/32\",\r\n - \ \"20.45.67.185/32\",\r\n \"20.45.79.3/32\",\r\n \"20.45.79.24/32\",\r\n - \ \"20.45.79.91/32\",\r\n \"20.45.79.96/32\",\r\n \"20.45.79.168/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.UKSouth\",\r\n - \ \"id\": \"WindowsVirtualDesktop.UKSouth\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"51.11.13.248/32\",\r\n \"51.105.54.123/32\",\r\n - \ \"51.132.29.107/32\",\r\n \"51.140.57.159/32\",\r\n \"51.143.164.192/32\",\r\n - \ \"51.143.169.107/32\",\r\n \"51.145.17.75/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.UKWest\",\r\n - \ \"id\": \"WindowsVirtualDesktop.UKWest\",\r\n \"properties\": {\r\n - \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": - \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n - \ ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": - [\r\n \"51.104.49.88/32\",\r\n \"51.140.206.110/32\",\r\n - \ \"51.140.231.223/32\",\r\n \"51.140.255.55/32\",\r\n \"51.141.30.31/32\",\r\n - \ \"52.142.161.0/32\",\r\n \"52.142.162.226/32\"\r\n ]\r\n - \ }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.WestEurope\",\r\n - \ \"id\": \"WindowsVirtualDesktop.WestEurope\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"13.69.82.138/32\",\r\n \"40.68.18.120/32\",\r\n - \ \"40.114.241.90/32\",\r\n \"51.136.28.200/32\",\r\n \"51.137.89.79/32\",\r\n - \ \"52.137.2.50/32\",\r\n \"65.52.158.177/32\",\r\n \"104.40.156.194/32\",\r\n - \ \"104.214.237.23/32\",\r\n \"137.117.171.26/32\",\r\n \"168.63.31.54/32\"\r\n - \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.WestIndia\",\r\n - \ \"id\": \"WindowsVirtualDesktop.WestIndia\",\r\n \"properties\": - {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n - \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n - \ \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n - \ \"addressPrefixes\": [\r\n \"52.183.130.137/32\",\r\n \"104.211.138.88/32\",\r\n - \ \"104.211.140.190/32\",\r\n \"104.211.155.114/32\",\r\n - \ \"104.211.165.123/32\",\r\n \"104.211.184.150/32\",\r\n - \ \"104.211.188.151/32\"\r\n ]\r\n }\r\n },\r\n {\r\n - \ \"name\": \"WindowsVirtualDesktop.WestUS2\",\r\n \"id\": \"WindowsVirtualDesktop.WestUS2\",\r\n - \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\": - \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": - [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": - \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \"13.66.251.49/32\",\r\n - \ \"13.77.140.58/32\",\r\n \"20.190.43.99/32\",\r\n \"40.65.122.222/32\",\r\n - \ \"51.141.173.236/32\",\r\n \"51.143.39.79/32\",\r\n \"52.143.96.87/32\",\r\n - \ \"52.151.53.196/32\",\r\n \"52.175.253.156/32\",\r\n \"52.183.19.64/32\",\r\n - \ \"52.191.129.231/32\"\r\n ]\r\n }\r\n }\r\n ]\r\n}" + string: "{\r\n \"name\": \"Public\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/serviceTags/Public\"\ + ,\r\n \"type\": \"Microsoft.Network/serviceTags\",\r\n \"changeNumber\"\ + : \"67\",\r\n \"cloud\": \"Public\",\r\n \"values\": [\r\n {\r\n \ + \ \"name\": \"ActionGroup\",\r\n \"id\": \"ActionGroup\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n\ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\ + \n \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.143.220/30\",\r\n \"13.67.10.124/30\",\r\ + \n \"13.69.109.132/30\",\r\n \"13.71.199.112/30\",\r\n \ + \ \"13.77.53.216/30\",\r\n \"13.78.109.156/30\",\r\n \ + \ \"13.86.221.220/30\",\r\n \"13.106.38.142/32\",\r\n \ + \ \"13.106.38.148/32\",\r\n \"13.106.54.3/32\",\r\n \"\ + 13.106.54.19/32\",\r\n \"13.106.57.181/32\",\r\n \"13.106.57.196/31\"\ + ,\r\n \"20.38.149.132/30\",\r\n \"20.42.64.36/30\",\r\n\ + \ \"20.43.121.124/30\",\r\n \"20.44.17.220/30\",\r\n \ + \ \"20.45.123.236/30\",\r\n \"20.150.172.228/30\",\r\n \ + \ \"20.192.238.124/30\",\r\n \"20.193.202.4/30\",\r\n \ + \ \"51.104.9.100/30\",\r\n \"52.183.31.0/32\",\r\n \"\ + 52.184.145.166/32\",\r\n \"191.233.50.4/30\",\r\n \"191.233.207.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.AustraliaSoutheast\"\ + ,\r\n \"id\": \"ActionGroup.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.53.216/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.BrazilSouth\",\r\n \"id\": \"\ + ActionGroup.BrazilSouth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"brazilsouth\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"191.233.207.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.CanadaCentral\"\ + ,\r\n \"id\": \"ActionGroup.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.149.132/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.CentralIndia\",\r\n \"id\": \"\ + ActionGroup.CentralIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralindia\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"20.43.121.124/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.EastUS\"\ + ,\r\n \"id\": \"ActionGroup.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\":\ + \ [\r\n \"20.42.64.36/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.EastUS2\",\r\n \"id\": \"ActionGroup.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.44.17.220/30\",\r\n \"52.184.145.166/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.JapanEast\"\ + ,\r\n \"id\": \"ActionGroup.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.78.109.156/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.NorthCentralUS\",\r\n \"id\"\ + : \"ActionGroup.NorthCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.106.38.142/32\",\r\n \"13.106.38.148/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.SouthCentralUS\"\ + ,\r\n \"id\": \"ActionGroup.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.106.54.3/32\",\r\n \"13.106.54.19/32\",\r\n\ + \ \"20.45.123.236/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ActionGroup.SoutheastAsia\",\r\n \"id\": \"ActionGroup.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"ActionGroup\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.10.124/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.UKSouth\"\ + ,\r\n \"id\": \"ActionGroup.UKSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.104.9.100/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.WestCentralUS\",\r\n \"id\":\ + \ \"ActionGroup.WestCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"ActionGroup\",\r\n \"addressPrefixes\": [\r\n \"13.71.199.112/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ActionGroup.WestEurope\"\ + ,\r\n \"id\": \"ActionGroup.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.109.132/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.WestUS\",\r\n \"id\": \"ActionGroup.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.86.221.220/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ActionGroup.WestUS2\",\r\n \"id\": \"ActionGroup.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"ActionGroup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.143.220/30\",\r\n \"13.106.57.181/32\",\r\ + \n \"13.106.57.196/31\",\r\n \"52.183.31.0/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement\"\ + ,\r\n \"id\": \"ApiManagement\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.64.39.16/32\",\r\n \"13.66.138.92/31\",\r\n \"13.66.140.176/28\"\ + ,\r\n \"13.67.8.108/31\",\r\n \"13.67.9.208/28\",\r\n \ + \ \"13.69.64.76/31\",\r\n \"13.69.66.144/28\",\r\n \ + \ \"13.69.227.76/31\",\r\n \"13.69.229.80/28\",\r\n \"\ + 13.70.72.28/31\",\r\n \"13.70.72.240/28\",\r\n \"13.71.49.1/32\"\ + ,\r\n \"13.71.170.44/31\",\r\n \"13.71.172.144/28\",\r\n\ + \ \"13.71.194.116/31\",\r\n \"13.71.196.32/28\",\r\n \ + \ \"13.75.34.148/31\",\r\n \"13.75.38.16/28\",\r\n \ + \ \"13.75.217.184/32\",\r\n \"13.75.221.78/32\",\r\n \"\ + 13.77.50.68/31\",\r\n \"13.77.52.224/28\",\r\n \"13.78.106.92/31\"\ + ,\r\n \"13.78.108.176/28\",\r\n \"13.84.189.17/32\",\r\n\ + \ \"13.85.22.63/32\",\r\n \"13.86.102.66/32\",\r\n \ + \ \"13.87.56.84/31\",\r\n \"13.87.57.144/28\",\r\n \"\ + 13.87.122.84/31\",\r\n \"13.87.123.144/28\",\r\n \"13.89.170.204/31\"\ + ,\r\n \"13.89.174.64/28\",\r\n \"20.36.106.68/31\",\r\n\ + \ \"20.36.107.176/28\",\r\n \"20.36.114.20/31\",\r\n \ + \ \"20.36.115.128/28\",\r\n \"20.37.52.67/32\",\r\n \ + \ \"20.37.74.224/31\",\r\n \"20.37.76.32/28\",\r\n \"\ + 20.37.81.41/32\",\r\n \"20.39.80.2/32\",\r\n \"20.39.99.81/32\"\ + ,\r\n \"20.40.125.155/32\",\r\n \"20.40.160.107/32\",\r\n\ + \ \"20.44.2.4/31\",\r\n \"20.44.3.224/28\",\r\n \ + \ \"20.44.33.246/32\",\r\n \"20.44.72.3/32\",\r\n \"20.46.144.85/32\"\ + ,\r\n \"20.150.170.224/28\",\r\n \"20.188.77.119/32\",\r\ + \n \"20.192.234.160/28\",\r\n \"20.193.202.160/28\",\r\n\ + \ \"23.96.224.175/32\",\r\n \"23.101.67.140/32\",\r\n \ + \ \"23.101.166.38/32\",\r\n \"40.66.60.111/32\",\r\n \ + \ \"40.67.58.224/28\",\r\n \"40.69.106.68/31\",\r\n \ + \ \"40.69.107.224/28\",\r\n \"40.70.146.76/31\",\r\n \"\ + 40.70.148.16/28\",\r\n \"40.71.10.204/31\",\r\n \"40.71.13.128/28\"\ + ,\r\n \"40.74.100.52/31\",\r\n \"40.74.101.48/28\",\r\n\ + \ \"40.74.146.80/31\",\r\n \"40.74.147.32/28\",\r\n \ + \ \"40.78.194.68/31\",\r\n \"40.78.195.224/28\",\r\n \ + \ \"40.78.202.128/31\",\r\n \"40.78.203.160/28\",\r\n \ + \ \"40.79.130.44/31\",\r\n \"40.79.131.192/28\",\r\n \"\ + 40.79.178.68/31\",\r\n \"40.79.179.192/28\",\r\n \"40.80.232.185/32\"\ + ,\r\n \"40.81.47.216/32\",\r\n \"40.81.89.24/32\",\r\n \ + \ \"40.81.185.8/32\",\r\n \"40.82.157.167/32\",\r\n \ + \ \"40.90.185.46/32\",\r\n \"40.112.242.148/31\",\r\n \ + \ \"40.112.243.240/28\",\r\n \"51.12.98.224/28\",\r\n \ + \ \"51.12.202.224/28\",\r\n \"51.107.0.91/32\",\r\n \"51.107.59.0/28\"\ + ,\r\n \"51.107.96.8/32\",\r\n \"51.107.155.0/28\",\r\n \ + \ \"51.116.0.0/32\",\r\n \"51.116.59.0/28\",\r\n \ + \ \"51.116.96.0/32\",\r\n \"51.116.155.64/28\",\r\n \"\ + 51.120.2.185/32\",\r\n \"51.120.98.176/28\",\r\n \"51.120.130.134/32\"\ + ,\r\n \"51.120.218.224/28\",\r\n \"51.137.136.0/32\",\r\n\ + \ \"51.140.146.60/31\",\r\n \"51.140.149.0/28\",\r\n \ + \ \"51.140.210.84/31\",\r\n \"51.140.211.176/28\",\r\n \ + \ \"51.143.127.203/32\",\r\n \"51.145.56.125/32\",\r\n \ + \ \"51.145.179.78/32\",\r\n \"52.139.20.34/32\",\r\n \ + \ \"52.139.80.117/32\",\r\n \"52.139.152.27/32\",\r\n \"\ + 52.140.238.179/32\",\r\n \"52.142.95.35/32\",\r\n \"52.162.106.148/31\"\ + ,\r\n \"52.162.110.80/28\",\r\n \"52.224.186.99/32\",\r\n\ + \ \"52.231.18.44/31\",\r\n \"52.231.19.192/28\",\r\n \ + \ \"52.231.146.84/31\",\r\n \"52.231.147.176/28\",\r\n \ + \ \"52.253.135.58/32\",\r\n \"52.253.159.160/32\",\r\n \ + \ \"52.253.229.253/32\",\r\n \"65.52.164.91/32\",\r\n \ + \ \"65.52.173.247/32\",\r\n \"65.52.250.4/31\",\r\n \"\ + 65.52.252.32/28\",\r\n \"102.133.0.79/32\",\r\n \"102.133.26.4/31\"\ + ,\r\n \"102.133.28.0/28\",\r\n \"102.133.130.197/32\",\r\ + \n \"102.133.154.4/31\",\r\n \"102.133.156.0/28\",\r\n \ + \ \"104.41.217.243/32\",\r\n \"104.41.218.160/32\",\r\n \ + \ \"104.211.81.28/31\",\r\n \"104.211.81.240/28\",\r\n \ + \ \"104.211.146.68/31\",\r\n \"104.211.147.144/28\",\r\n \ + \ \"104.214.18.172/31\",\r\n \"104.214.19.224/28\",\r\n \ + \ \"137.117.160.56/32\",\r\n \"191.233.24.179/32\",\r\n \ + \ \"191.233.50.192/28\",\r\n \"191.233.203.28/31\",\r\n \ + \ \"191.233.203.240/28\",\r\n \"191.238.241.97/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.AustraliaCentral\"\ + ,\r\n \"id\": \"ApiManagement.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.36.106.68/31\",\r\n \"20.36.107.176/28\",\r\ + \n \"20.37.52.67/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.AustraliaCentral2\",\r\n \"id\": \"\ + ApiManagement.AustraliaCentral2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.36.114.20/31\",\r\n \"20.36.115.128/28\",\r\ + \n \"20.39.99.81/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.AustraliaEast\",\r\n \"id\": \"ApiManagement.AustraliaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.72.28/31\",\r\n \ + \ \"13.70.72.240/28\",\r\n \"13.75.217.184/32\",\r\n \ + \ \"13.75.221.78/32\",\r\n \"20.40.125.155/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.AustraliaSoutheast\"\ + ,\r\n \"id\": \"ApiManagement.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.50.68/31\",\r\n \"13.77.52.224/28\",\r\n\ + \ \"20.40.160.107/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.BrazilSouth\",\r\n \"id\": \"ApiManagement.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"191.233.24.179/32\",\r\n\ + \ \"191.233.203.28/31\",\r\n \"191.233.203.240/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CanadaCentral\"\ + ,\r\n \"id\": \"ApiManagement.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.170.44/31\",\r\n \"13.71.172.144/28\",\r\ + \n \"52.139.20.34/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.CanadaEast\",\r\n \"id\": \"ApiManagement.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.69.106.68/31\",\r\n\ + \ \"40.69.107.224/28\",\r\n \"52.139.80.117/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CentralIndia\"\ + ,\r\n \"id\": \"ApiManagement.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.49.1/32\",\r\n \"104.211.81.28/31\",\r\n\ + \ \"104.211.81.240/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.CentralUS\",\r\n \"id\": \"ApiManagement.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.86.102.66/32\",\r\n\ + \ \"13.89.170.204/31\",\r\n \"13.89.174.64/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.CentralUSEUAP\"\ + ,\r\n \"id\": \"ApiManagement.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.78.202.128/31\",\r\n \"40.78.203.160/28\",\r\ + \n \"52.253.159.160/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.EastAsia\",\r\n \"id\": \"ApiManagement.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.75.34.148/31\",\r\n\ + \ \"13.75.38.16/28\",\r\n \"52.139.152.27/32\",\r\n \ + \ \"65.52.164.91/32\",\r\n \"65.52.173.247/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.EastUS\",\r\ + \n \"id\": \"ApiManagement.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.71.10.204/31\",\r\n \"40.71.13.128/28\",\r\n\ + \ \"52.224.186.99/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.EastUS2\",\r\n \"id\": \"ApiManagement.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureApiManagement\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.44.72.3/32\",\r\n \"\ + 40.70.146.76/31\",\r\n \"40.70.148.16/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.EastUS2EUAP\",\r\ + \n \"id\": \"ApiManagement.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.146.80/31\",\r\n \"40.74.147.32/28\",\r\n\ + \ \"52.253.229.253/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.FranceCentral\",\r\n \"id\": \"\ + ApiManagement.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.66.60.111/32\",\r\n \"40.79.130.44/31\",\r\n \"40.79.131.192/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.FranceSouth\"\ + ,\r\n \"id\": \"ApiManagement.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.39.80.2/32\",\r\n \"40.79.178.68/31\",\r\n\ + \ \"40.79.179.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.GermanyNorth\",\r\n \"id\": \"ApiManagement.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.0.0/32\",\r\n \ + \ \"51.116.59.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ApiManagement.GermanyWestCentral\",\r\n \"id\": \"\ + ApiManagement.GermanyWestCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.116.96.0/32\",\r\n \"51.116.155.64/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.JapanEast\",\r\n\ + \ \"id\": \"ApiManagement.JapanEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.78.106.92/31\",\r\n \"13.78.108.176/28\",\r\ + \n \"52.140.238.179/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.JapanWest\",\r\n \"id\": \"ApiManagement.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.74.100.52/31\",\r\n\ + \ \"40.74.101.48/28\",\r\n \"40.81.185.8/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.KoreaCentral\"\ + ,\r\n \"id\": \"ApiManagement.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.82.157.167/32\",\r\n \"52.231.18.44/31\",\r\ + \n \"52.231.19.192/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.KoreaSouth\",\r\n \"id\": \"ApiManagement.KoreaSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.232.185/32\",\r\n\ + \ \"52.231.146.84/31\",\r\n \"52.231.147.176/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorthCentralUS\"\ + ,\r\n \"id\": \"ApiManagement.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"23.96.224.175/32\",\r\n \"23.101.166.38/32\",\r\ + \n \"40.81.47.216/32\",\r\n \"52.162.106.148/31\",\r\n \ + \ \"52.162.110.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.NorthEurope\",\r\n \"id\": \"ApiManagement.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.227.76/31\",\r\n\ + \ \"13.69.229.80/28\",\r\n \"52.142.95.35/32\",\r\n \ + \ \"104.41.217.243/32\",\r\n \"104.41.218.160/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorwayEast\"\ + ,\r\n \"id\": \"ApiManagement.NorwayEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.120.2.185/32\",\r\n \"51.120.98.176/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.NorwayWest\"\ + ,\r\n \"id\": \"ApiManagement.NorwayWest\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.120.130.134/32\",\r\n \"51.120.218.224/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthAfricaNorth\"\ + ,\r\n \"id\": \"ApiManagement.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.130.197/32\",\r\n \"102.133.154.4/31\"\ + ,\r\n \"102.133.156.0/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ApiManagement.SouthAfricaWest\",\r\n \"id\"\ + : \"ApiManagement.SouthAfricaWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.0.79/32\",\r\n \"102.133.26.4/31\",\r\n\ + \ \"102.133.28.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.SouthCentralUS\",\r\n \"id\": \"ApiManagement.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.84.189.17/32\",\r\n\ + \ \"13.85.22.63/32\",\r\n \"20.188.77.119/32\",\r\n \ + \ \"104.214.18.172/31\",\r\n \"104.214.19.224/28\",\r\n \ + \ \"191.238.241.97/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ApiManagement.SoutheastAsia\",\r\n \"id\": \"ApiManagement.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.8.108/31\",\r\n \ + \ \"13.67.9.208/28\",\r\n \"40.90.185.46/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.SouthIndia\"\ + ,\r\n \"id\": \"ApiManagement.SouthIndia\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.44.33.246/32\",\r\n \"40.78.194.68/31\",\r\n\ + \ \"40.78.195.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.SwitzerlandNorth\",\r\n \"id\": \"\ + ApiManagement.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureApiManagement\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.0.91/32\",\r\n \"51.107.59.0/28\"\r\n ]\r\n }\r\ + \n },\r\n {\r\n \"name\": \"ApiManagement.SwitzerlandWest\",\r\n\ + \ \"id\": \"ApiManagement.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.96.8/32\",\r\n \"51.107.155.0/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UAECentral\"\ + ,\r\n \"id\": \"ApiManagement.UAECentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.74.224/31\",\r\n \"20.37.76.32/28\",\r\n\ + \ \"20.37.81.41/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.UAENorth\",\r\n \"id\": \"ApiManagement.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.46.144.85/32\",\r\n\ + \ \"65.52.250.4/31\",\r\n \"65.52.252.32/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UKNorth\"\ + ,\r\n \"id\": \"ApiManagement.UKNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.87.122.84/31\",\r\n \"13.87.123.144/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.UKSouth\"\ + ,\r\n \"id\": \"ApiManagement.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.140.146.60/31\",\r\n \"51.140.149.0/28\",\r\ + \n \"51.145.56.125/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.UKSouth2\",\r\n \"id\": \"ApiManagement.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.56.84/31\",\r\n \ + \ \"13.87.57.144/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ApiManagement.UKWest\",\r\n \"id\": \"ApiManagement.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureApiManagement\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.137.136.0/32\",\r\n \"\ + 51.140.210.84/31\",\r\n \"51.140.211.176/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.WestCentralUS\"\ + ,\r\n \"id\": \"ApiManagement.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.194.116/31\",\r\n \"13.71.196.32/28\",\r\ + \n \"52.253.135.58/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.WestEurope\",\r\n \"id\": \"ApiManagement.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureApiManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.64.76/31\",\r\n \ + \ \"13.69.66.144/28\",\r\n \"23.101.67.140/32\",\r\n \ + \ \"51.145.179.78/32\",\r\n \"137.117.160.56/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApiManagement.WestIndia\"\ + ,\r\n \"id\": \"ApiManagement.WestIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.81.89.24/32\",\r\n \"104.211.146.68/31\",\r\ + \n \"104.211.147.144/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApiManagement.WestUS\",\r\n \"id\": \"ApiManagement.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureApiManagement\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.64.39.16/32\",\r\n \"\ + 40.112.242.148/31\",\r\n \"40.112.243.240/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ApiManagement.WestUS2\",\r\ + \n \"id\": \"ApiManagement.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureApiManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.138.92/31\",\r\n \"13.66.140.176/28\",\r\ + \n \"51.143.127.203/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppConfiguration\",\r\n \"id\": \"AppConfiguration\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureAppConfiguration\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.142.72/29\",\r\n \"13.66.143.192/28\",\r\ + \n \"13.66.143.208/29\",\r\n \"13.67.10.112/29\",\r\n \ + \ \"13.67.13.192/28\",\r\n \"13.67.13.208/29\",\r\n \ + \ \"13.69.67.112/29\",\r\n \"13.69.67.240/28\",\r\n \"\ + 13.69.71.128/29\",\r\n \"13.69.107.72/29\",\r\n \"13.69.112.144/28\"\ + ,\r\n \"13.69.112.160/29\",\r\n \"13.69.230.8/29\",\r\n\ + \ \"13.69.230.40/29\",\r\n \"13.69.231.144/28\",\r\n \ + \ \"13.70.74.128/29\",\r\n \"13.70.78.144/28\",\r\n \ + \ \"13.70.78.160/29\",\r\n \"13.71.175.64/28\",\r\n \"\ + 13.71.175.96/28\",\r\n \"13.71.196.176/28\",\r\n \"13.71.199.80/28\"\ + ,\r\n \"13.73.242.56/29\",\r\n \"13.73.244.96/28\",\r\n\ + \ \"13.73.244.112/29\",\r\n \"13.74.108.160/28\",\r\n \ + \ \"13.74.108.240/28\",\r\n \"13.77.53.88/29\",\r\n \ + \ \"13.77.53.192/28\",\r\n \"13.77.53.208/29\",\r\n \"\ + 13.78.109.144/29\",\r\n \"13.78.109.208/28\",\r\n \"13.78.111.128/29\"\ + ,\r\n \"13.86.219.192/29\",\r\n \"13.86.221.192/28\",\r\n\ + \ \"13.86.221.208/29\",\r\n \"13.87.58.64/29\",\r\n \ + \ \"13.87.58.80/28\",\r\n \"13.87.58.128/29\",\r\n \ + \ \"13.87.124.64/29\",\r\n \"13.87.124.80/28\",\r\n \"13.87.124.128/29\"\ + ,\r\n \"13.89.175.208/28\",\r\n \"13.89.178.16/29\",\r\n\ + \ \"13.89.178.32/29\",\r\n \"20.36.108.120/29\",\r\n \ + \ \"20.36.108.136/29\",\r\n \"20.36.108.144/28\",\r\n \ + \ \"20.36.115.248/29\",\r\n \"20.36.117.40/29\",\r\n \ + \ \"20.36.117.48/28\",\r\n \"20.36.123.16/28\",\r\n \"\ + 20.37.67.96/28\",\r\n \"20.37.76.112/29\",\r\n \"20.37.76.144/28\"\ + ,\r\n \"20.37.76.192/29\",\r\n \"20.37.198.144/28\",\r\n\ + \ \"20.37.227.32/28\",\r\n \"20.38.128.96/29\",\r\n \ + \ \"20.38.128.112/28\",\r\n \"20.38.128.160/29\",\r\n \ + \ \"20.38.139.96/28\",\r\n \"20.38.147.176/28\",\r\n \ + \ \"20.38.147.240/28\",\r\n \"20.39.14.16/28\",\r\n \"20.40.206.144/28\"\ + ,\r\n \"20.40.206.160/28\",\r\n \"20.41.68.64/28\",\r\n\ + \ \"20.41.197.48/28\",\r\n \"20.42.64.16/28\",\r\n \ + \ \"20.42.230.144/28\",\r\n \"20.43.44.144/28\",\r\n \ + \ \"20.43.70.128/28\",\r\n \"20.43.121.40/29\",\r\n \"\ + 20.43.121.96/28\",\r\n \"20.43.121.112/29\",\r\n \"20.44.4.96/29\"\ + ,\r\n \"20.44.4.120/29\",\r\n \"20.44.4.160/28\",\r\n \ + \ \"20.44.8.168/29\",\r\n \"20.44.10.96/28\",\r\n \ + \ \"20.44.10.112/29\",\r\n \"20.44.17.56/29\",\r\n \"20.44.17.192/28\"\ + ,\r\n \"20.44.17.208/29\",\r\n \"20.44.27.224/28\",\r\n\ + \ \"20.44.29.32/28\",\r\n \"20.45.123.120/29\",\r\n \ + \ \"20.45.123.176/28\",\r\n \"20.45.123.224/29\",\r\n \ + \ \"20.45.126.0/27\",\r\n \"20.45.198.0/27\",\r\n \"\ + 20.49.83.96/27\",\r\n \"20.49.91.96/27\",\r\n \"20.49.99.80/28\"\ + ,\r\n \"20.49.109.96/28\",\r\n \"20.49.120.80/28\",\r\n\ + \ \"20.50.1.240/28\",\r\n \"20.50.65.96/28\",\r\n \ + \ \"20.150.165.176/28\",\r\n \"20.150.172.64/27\",\r\n \ + \ \"20.150.173.32/27\",\r\n \"20.150.179.200/29\",\r\n \ + \ \"20.150.181.0/28\",\r\n \"20.150.181.16/29\",\r\n \"\ + 20.150.181.128/27\",\r\n \"20.150.187.200/29\",\r\n \"20.150.189.0/28\"\ + ,\r\n \"20.150.189.16/29\",\r\n \"20.187.194.224/28\",\r\ + \n \"20.192.99.200/29\",\r\n \"20.192.101.0/28\",\r\n \ + \ \"20.192.101.16/29\",\r\n \"20.192.235.240/29\",\r\n \ + \ \"20.192.238.112/29\",\r\n \"20.192.238.192/27\",\r\n \ + \ \"20.193.203.224/27\",\r\n \"20.194.67.64/27\",\r\n \ + \ \"23.98.83.72/29\",\r\n \"23.98.86.32/28\",\r\n \"\ + 23.98.86.48/29\",\r\n \"23.98.104.176/28\",\r\n \"40.64.132.144/28\"\ + ,\r\n \"40.67.60.72/29\",\r\n \"40.67.60.112/28\",\r\n \ + \ \"40.67.60.160/29\",\r\n \"40.69.108.80/29\",\r\n \ + \ \"40.69.108.176/28\",\r\n \"40.69.110.160/29\",\r\n \ + \ \"40.70.148.56/29\",\r\n \"40.70.151.48/28\",\r\n \"\ + 40.70.151.64/29\",\r\n \"40.71.13.248/29\",\r\n \"40.71.14.120/29\"\ + ,\r\n \"40.71.15.128/28\",\r\n \"40.74.149.40/29\",\r\n\ + \ \"40.74.149.56/29\",\r\n \"40.74.149.80/28\",\r\n \ + \ \"40.75.35.72/29\",\r\n \"40.75.35.192/28\",\r\n \ + \ \"40.75.35.208/29\",\r\n \"40.78.196.80/29\",\r\n \"40.78.196.144/28\"\ + ,\r\n \"40.78.196.160/29\",\r\n \"40.78.204.8/29\",\r\n\ + \ \"40.78.204.144/28\",\r\n \"40.78.204.192/29\",\r\n \ + \ \"40.78.229.80/28\",\r\n \"40.78.229.112/28\",\r\n \ + \ \"40.78.236.136/29\",\r\n \"40.78.238.32/28\",\r\n \ + \ \"40.78.238.48/29\",\r\n \"40.78.243.176/28\",\r\n \"\ + 40.78.245.128/28\",\r\n \"40.78.251.144/28\",\r\n \"40.78.251.208/28\"\ + ,\r\n \"40.79.132.88/29\",\r\n \"40.79.139.64/28\",\r\n\ + \ \"40.79.139.128/28\",\r\n \"40.79.146.208/28\",\r\n \ + \ \"40.79.148.64/28\",\r\n \"40.79.156.96/28\",\r\n \ + \ \"40.79.163.64/29\",\r\n \"40.79.163.128/28\",\r\n \ + \ \"40.79.163.144/29\",\r\n \"40.79.165.96/27\",\r\n \"\ + 40.79.171.112/28\",\r\n \"40.79.171.176/28\",\r\n \"40.79.180.48/29\"\ + ,\r\n \"40.79.180.128/28\",\r\n \"40.79.180.144/29\",\r\n\ + \ \"40.79.187.192/29\",\r\n \"40.79.189.32/28\",\r\n \ + \ \"40.79.189.48/29\",\r\n \"40.79.195.176/28\",\r\n \ + \ \"40.79.195.240/28\",\r\n \"40.80.51.112/28\",\r\n \ + \ \"40.80.51.176/28\",\r\n \"40.80.62.32/28\",\r\n \"40.80.172.48/28\"\ + ,\r\n \"40.80.176.40/29\",\r\n \"40.80.176.56/29\",\r\n\ + \ \"40.80.176.112/28\",\r\n \"40.80.191.240/28\",\r\n \ + \ \"40.89.20.160/28\",\r\n \"40.119.11.192/28\",\r\n \ + \ \"40.120.75.128/27\",\r\n \"51.11.192.0/28\",\r\n \ + \ \"51.11.192.16/29\",\r\n \"51.12.99.216/29\",\r\n \"51.12.100.48/28\"\ + ,\r\n \"51.12.100.96/29\",\r\n \"51.12.204.48/28\",\r\n\ + \ \"51.12.204.96/28\",\r\n \"51.12.227.200/29\",\r\n \ + \ \"51.12.229.0/28\",\r\n \"51.12.229.16/29\",\r\n \ + \ \"51.12.235.200/29\",\r\n \"51.12.237.0/28\",\r\n \"\ + 51.12.237.16/29\",\r\n \"51.104.9.48/28\",\r\n \"51.104.29.224/28\"\ + ,\r\n \"51.105.67.184/29\",\r\n \"51.105.67.216/29\",\r\n\ + \ \"51.105.69.64/28\",\r\n \"51.105.75.224/28\",\r\n \ + \ \"51.105.77.32/28\",\r\n \"51.105.90.176/28\",\r\n \ + \ \"51.107.51.48/28\",\r\n \"51.107.60.56/29\",\r\n \"\ + 51.107.60.128/28\",\r\n \"51.107.60.144/29\",\r\n \"51.107.147.48/28\"\ + ,\r\n \"51.107.156.64/29\",\r\n \"51.107.156.136/29\",\r\ + \n \"51.107.156.144/28\",\r\n \"51.116.49.192/28\",\r\n\ + \ \"51.116.60.56/29\",\r\n \"51.116.60.88/29\",\r\n \ + \ \"51.116.60.128/28\",\r\n \"51.116.145.176/28\",\r\n \ + \ \"51.116.156.56/29\",\r\n \"51.116.156.168/29\",\r\n \ + \ \"51.116.158.32/28\",\r\n \"51.116.158.48/29\",\r\n \ + \ \"51.116.243.152/29\",\r\n \"51.116.243.192/28\",\r\n \ + \ \"51.116.243.208/29\",\r\n \"51.116.245.128/27\",\r\n \ + \ \"51.116.251.40/29\",\r\n \"51.116.251.160/28\",\r\n \ + \ \"51.116.251.176/29\",\r\n \"51.116.253.64/27\",\r\n \"\ + 51.120.43.96/28\",\r\n \"51.120.100.56/29\",\r\n \"51.120.100.128/28\"\ + ,\r\n \"51.120.100.144/29\",\r\n \"51.120.107.200/29\",\r\ + \n \"51.120.109.0/28\",\r\n \"51.120.109.16/29\",\r\n \ + \ \"51.120.211.200/29\",\r\n \"51.120.213.0/28\",\r\n \ + \ \"51.120.213.16/29\",\r\n \"51.120.220.56/29\",\r\n \ + \ \"51.120.220.96/28\",\r\n \"51.120.220.112/29\",\r\n \ + \ \"51.120.227.96/28\",\r\n \"51.137.164.128/28\",\r\n \ + \ \"51.140.148.40/29\",\r\n \"51.140.149.16/29\",\r\n \"\ + 51.140.212.96/29\",\r\n \"51.140.212.192/28\",\r\n \"51.140.212.208/29\"\ + ,\r\n \"52.136.51.96/28\",\r\n \"52.138.92.88/29\",\r\n\ + \ \"52.138.92.144/28\",\r\n \"52.138.92.160/29\",\r\n \ + \ \"52.138.227.176/28\",\r\n \"52.138.229.48/28\",\r\n \ + \ \"52.140.108.112/28\",\r\n \"52.140.108.128/28\",\r\n \ + \ \"52.150.152.64/28\",\r\n \"52.162.111.32/28\",\r\n \ + \ \"52.162.111.112/28\",\r\n \"52.167.107.112/28\",\r\n \ + \ \"52.167.107.240/28\",\r\n \"52.182.141.0/29\",\r\n \ + \ \"52.182.141.32/28\",\r\n \"52.182.141.48/29\",\r\n \ + \ \"52.228.85.208/28\",\r\n \"52.231.20.8/29\",\r\n \"52.231.20.80/28\"\ + ,\r\n \"52.231.23.0/29\",\r\n \"52.231.148.112/29\",\r\n\ + \ \"52.231.148.176/28\",\r\n \"52.231.148.192/29\",\r\n\ + \ \"52.236.186.248/29\",\r\n \"52.236.187.96/28\",\r\n \ + \ \"52.236.189.64/29\",\r\n \"52.246.155.176/28\",\r\n \ + \ \"52.246.155.240/28\",\r\n \"52.246.157.32/27\",\r\n \ + \ \"65.52.252.112/29\",\r\n \"65.52.252.224/28\",\r\n \ + \ \"65.52.252.240/29\",\r\n \"102.133.28.96/29\",\r\n \ + \ \"102.133.28.152/29\",\r\n \"102.133.28.192/28\",\r\n \ + \ \"102.133.58.240/28\",\r\n \"102.133.124.80/29\",\r\n \ + \ \"102.133.124.112/28\",\r\n \"102.133.124.128/29\",\r\n \ + \ \"102.133.156.120/29\",\r\n \"102.133.156.152/29\",\r\n \ + \ \"102.133.156.160/28\",\r\n \"102.133.218.160/28\",\r\n \ + \ \"102.133.251.88/29\",\r\n \"102.133.251.192/28\",\r\n\ + \ \"102.133.251.208/29\",\r\n \"104.214.161.0/29\",\r\n\ + \ \"104.214.161.16/28\",\r\n \"104.214.161.32/29\",\r\n\ + \ \"191.233.11.144/28\",\r\n \"191.233.51.224/27\",\r\n\ + \ \"191.233.205.112/28\",\r\n \"191.233.205.176/28\",\r\n\ + \ \"191.234.136.96/28\",\r\n \"191.234.147.200/29\",\r\n\ + \ \"191.234.149.16/28\",\r\n \"191.234.149.128/29\",\r\n\ + \ \"191.234.149.192/27\",\r\n \"191.234.155.200/29\",\r\n\ + \ \"191.234.157.16/28\",\r\n \"191.234.157.32/29\",\r\n\ + \ \"191.234.157.96/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ApplicationInsightsAvailability\",\r\n \"id\"\ + : \"ApplicationInsightsAvailability\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"ApplicationInsightsAvailability\",\r\n \"addressPrefixes\": [\r\ + \n \"13.86.97.224/27\",\r\n \"13.86.98.0/27\",\r\n \ + \ \"13.86.98.48/28\",\r\n \"13.86.98.64/28\",\r\n \"\ + 20.37.156.64/27\",\r\n \"20.37.192.80/29\",\r\n \"20.38.80.80/28\"\ + ,\r\n \"20.40.104.96/27\",\r\n \"20.40.104.128/27\",\r\n\ + \ \"20.40.124.176/28\",\r\n \"20.40.124.240/28\",\r\n \ + \ \"20.40.125.80/28\",\r\n \"20.40.129.32/27\",\r\n \ + \ \"20.40.129.64/26\",\r\n \"20.40.129.128/27\",\r\n \ + \ \"20.42.4.64/27\",\r\n \"20.42.35.32/28\",\r\n \"20.42.35.64/26\"\ + ,\r\n \"20.42.35.128/28\",\r\n \"20.42.129.32/27\",\r\n\ + \ \"20.43.40.80/28\",\r\n \"20.43.64.80/29\",\r\n \ + \ \"20.43.128.96/29\",\r\n \"20.45.5.160/27\",\r\n \"\ + 20.45.5.192/26\",\r\n \"20.189.106.64/29\",\r\n \"23.100.224.16/28\"\ + ,\r\n \"23.100.224.32/27\",\r\n \"23.100.224.64/26\",\r\n\ + \ \"23.100.225.0/28\",\r\n \"40.74.24.80/28\",\r\n \ + \ \"40.80.186.128/26\",\r\n \"40.91.82.48/28\",\r\n \ + \ \"40.91.82.64/26\",\r\n \"40.91.82.128/28\",\r\n \"40.119.8.96/27\"\ + ,\r\n \"51.104.24.80/29\",\r\n \"51.105.9.128/27\",\r\n\ + \ \"51.105.9.160/28\",\r\n \"51.137.160.80/29\",\r\n \ + \ \"51.144.56.96/27\",\r\n \"51.144.56.128/26\",\r\n \ + \ \"52.139.250.96/27\",\r\n \"52.139.250.128/27\",\r\n \ + \ \"52.140.232.160/27\",\r\n \"52.140.232.192/28\",\r\n \ + \ \"52.158.28.64/26\",\r\n \"52.229.216.48/28\",\r\n \"\ + 52.229.216.64/27\",\r\n \"191.233.26.64/28\",\r\n \"191.233.26.128/28\"\ + ,\r\n \"191.233.26.176/28\",\r\n \"191.235.224.80/29\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.EastUS\"\ + ,\r\n \"id\": \"ApplicationInsightsAvailability.EastUS\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"ApplicationInsightsAvailability\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.4.64/27\",\r\n \ + \ \"20.42.35.32/28\",\r\n \"20.42.35.64/26\",\r\n \ + \ \"20.42.35.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"ApplicationInsightsAvailability.JapanEast\",\r\n \"id\"\ + : \"ApplicationInsightsAvailability.JapanEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"ApplicationInsightsAvailability\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.43.64.80/29\",\r\n \"\ + 52.140.232.160/27\",\r\n \"52.140.232.192/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.NorthCentralUS\"\ + ,\r\n \"id\": \"ApplicationInsightsAvailability.NorthCentralUS\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"ApplicationInsightsAvailability\"\ + ,\r\n \"addressPrefixes\": [\r\n \"23.100.224.16/28\",\r\n\ + \ \"23.100.224.32/27\",\r\n \"23.100.224.64/26\",\r\n \ + \ \"23.100.225.0/28\",\r\n \"40.80.186.128/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ApplicationInsightsAvailability.SoutheastAsia\"\ + ,\r\n \"id\": \"ApplicationInsightsAvailability.SoutheastAsia\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"ApplicationInsightsAvailability\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.128.96/29\",\r\n\ + \ \"52.139.250.96/27\",\r\n \"52.139.250.128/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService\",\r\ + \n \"id\": \"AppService\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.64.73.110/32\"\ + ,\r\n \"13.65.30.245/32\",\r\n \"13.65.37.122/32\",\r\n\ + \ \"13.65.39.165/32\",\r\n \"13.65.42.35/32\",\r\n \ + \ \"13.65.42.183/32\",\r\n \"13.65.45.30/32\",\r\n \"\ + 13.65.85.146/32\",\r\n \"13.65.89.91/32\",\r\n \"13.65.92.72/32\"\ + ,\r\n \"13.65.94.204/32\",\r\n \"13.65.95.109/32\",\r\n\ + \ \"13.65.97.243/32\",\r\n \"13.65.193.29/32\",\r\n \ + \ \"13.65.210.166/32\",\r\n \"13.65.212.252/32\",\r\n \ + \ \"13.65.241.130/32\",\r\n \"13.65.243.110/32\",\r\n \ + \ \"13.66.16.101/32\",\r\n \"13.66.38.99/32\",\r\n \"13.66.39.88/32\"\ + ,\r\n \"13.66.138.96/27\",\r\n \"13.66.209.135/32\",\r\n\ + \ \"13.66.212.205/32\",\r\n \"13.66.226.80/32\",\r\n \ + \ \"13.66.231.217/32\",\r\n \"13.66.241.134/32\",\r\n \ + \ \"13.66.244.249/32\",\r\n \"13.67.9.0/25\",\r\n \"\ + 13.67.56.225/32\",\r\n \"13.67.63.90/32\",\r\n \"13.67.129.26/32\"\ + ,\r\n \"13.67.141.98/32\",\r\n \"13.68.29.136/32\",\r\n\ + \ \"13.68.101.62/32\",\r\n \"13.69.68.0/23\",\r\n \ + \ \"13.69.186.152/32\",\r\n \"13.69.228.0/25\",\r\n \"\ + 13.69.253.145/32\",\r\n \"13.70.72.32/27\",\r\n \"13.70.123.149/32\"\ + ,\r\n \"13.70.146.110/32\",\r\n \"13.70.147.206/32\",\r\n\ + \ \"13.71.122.35/32\",\r\n \"13.71.123.138/32\",\r\n \ + \ \"13.71.149.151/32\",\r\n \"13.71.170.128/27\",\r\n \ + \ \"13.71.194.192/27\",\r\n \"13.73.1.134/32\",\r\n \ + \ \"13.73.26.73/32\",\r\n \"13.73.116.45/32\",\r\n \"13.73.118.104/32\"\ + ,\r\n \"13.74.41.233/32\",\r\n \"13.74.147.218/32\",\r\n\ + \ \"13.74.158.5/32\",\r\n \"13.74.252.44/32\",\r\n \ + \ \"13.75.34.160/27\",\r\n \"13.75.46.26/32\",\r\n \"\ + 13.75.47.15/32\",\r\n \"13.75.89.224/32\",\r\n \"13.75.112.108/32\"\ + ,\r\n \"13.75.115.40/32\",\r\n \"13.75.138.224/32\",\r\n\ + \ \"13.75.147.143/32\",\r\n \"13.75.147.201/32\",\r\n \ + \ \"13.75.218.45/32\",\r\n \"13.76.44.139/32\",\r\n \ + \ \"13.76.245.96/32\",\r\n \"13.77.7.175/32\",\r\n \"\ + 13.77.50.96/27\",\r\n \"13.77.82.141/32\",\r\n \"13.77.83.246/32\"\ + ,\r\n \"13.77.96.119/32\",\r\n \"13.77.157.133/32\",\r\n\ + \ \"13.77.160.237/32\",\r\n \"13.77.182.13/32\",\r\n \ + \ \"13.78.59.237/32\",\r\n \"13.78.106.96/27\",\r\n \ + \ \"13.78.117.86/32\",\r\n \"13.78.123.87/32\",\r\n \"\ + 13.78.150.96/32\",\r\n \"13.78.184.89/32\",\r\n \"13.79.2.71/32\"\ + ,\r\n \"13.79.38.229/32\",\r\n \"13.79.172.40/32\",\r\n\ + \ \"13.80.19.74/32\",\r\n \"13.81.7.21/32\",\r\n \ + \ \"13.81.108.99/32\",\r\n \"13.81.215.235/32\",\r\n \"\ + 13.82.93.245/32\",\r\n \"13.82.101.179/32\",\r\n \"13.82.175.96/32\"\ + ,\r\n \"13.84.36.2/32\",\r\n \"13.84.40.227/32\",\r\n \ + \ \"13.84.42.35/32\",\r\n \"13.84.46.29/32\",\r\n \ + \ \"13.84.55.137/32\",\r\n \"13.84.146.60/32\",\r\n \"\ + 13.84.180.32/32\",\r\n \"13.84.181.47/32\",\r\n \"13.84.188.162/32\"\ + ,\r\n \"13.84.189.137/32\",\r\n \"13.84.227.164/32\",\r\n\ + \ \"13.85.15.194/32\",\r\n \"13.85.16.224/32\",\r\n \ + \ \"13.85.20.144/32\",\r\n \"13.85.24.220/32\",\r\n \ + \ \"13.85.27.14/32\",\r\n \"13.85.31.243/32\",\r\n \"13.85.72.129/32\"\ + ,\r\n \"13.85.77.179/32\",\r\n \"13.85.82.0/32\",\r\n \ + \ \"13.89.57.7/32\",\r\n \"13.89.172.0/23\",\r\n \ + \ \"13.89.238.239/32\",\r\n \"13.90.143.69/32\",\r\n \"\ + 13.90.213.204/32\",\r\n \"13.91.40.166/32\",\r\n \"13.91.242.166/32\"\ + ,\r\n \"13.92.139.214/32\",\r\n \"13.92.193.110/32\",\r\n\ + \ \"13.92.237.218/32\",\r\n \"13.93.141.10/32\",\r\n \ + \ \"13.93.158.16/32\",\r\n \"13.93.220.109/32\",\r\n \ + \ \"13.93.231.75/32\",\r\n \"13.94.47.87/32\",\r\n \"\ + 13.94.143.57/32\",\r\n \"13.94.192.98/32\",\r\n \"13.94.211.38/32\"\ + ,\r\n \"13.95.82.181/32\",\r\n \"13.95.93.152/32\",\r\n\ + \ \"13.95.150.128/32\",\r\n \"13.95.238.192/32\",\r\n \ + \ \"20.36.43.207/32\",\r\n \"20.36.72.230/32\",\r\n \ + \ \"20.36.106.96/27\",\r\n \"20.36.117.0/27\",\r\n \"\ + 20.36.122.0/27\",\r\n \"20.37.66.0/27\",\r\n \"20.37.74.96/27\"\ + ,\r\n \"20.37.196.192/27\",\r\n \"20.37.226.0/27\",\r\n\ + \ \"20.38.138.0/27\",\r\n \"20.38.146.160/27\",\r\n \ + \ \"20.39.11.104/29\",\r\n \"20.40.202.0/23\",\r\n \ + \ \"20.41.66.224/27\",\r\n \"20.41.195.192/27\",\r\n \"\ + 20.42.26.252/32\",\r\n \"20.42.128.96/27\",\r\n \"20.42.228.160/27\"\ + ,\r\n \"20.43.43.32/27\",\r\n \"20.43.67.32/27\",\r\n \ + \ \"20.43.132.128/25\",\r\n \"20.44.2.32/27\",\r\n \ + \ \"20.44.26.160/27\",\r\n \"20.45.122.160/27\",\r\n \"\ + 20.45.196.16/29\",\r\n \"20.49.82.32/27\",\r\n \"20.49.90.32/27\"\ + ,\r\n \"20.49.97.0/25\",\r\n \"20.49.104.0/25\",\r\n \ + \ \"20.50.2.0/23\",\r\n \"20.50.64.0/25\",\r\n \"\ + 20.150.170.192/27\",\r\n \"20.150.178.160/27\",\r\n \"20.150.186.160/27\"\ + ,\r\n \"20.188.98.74/32\",\r\n \"20.189.104.96/27\",\r\n\ + \ \"20.189.109.96/27\",\r\n \"20.189.112.66/32\",\r\n \ + \ \"20.192.98.160/27\",\r\n \"20.192.234.128/27\",\r\n \ + \ \"20.193.202.128/27\",\r\n \"20.194.66.32/27\",\r\n \ + \ \"23.96.0.52/32\",\r\n \"23.96.1.109/32\",\r\n \"\ + 23.96.13.243/32\",\r\n \"23.96.32.128/32\",\r\n \"23.96.96.142/32\"\ + ,\r\n \"23.96.103.159/32\",\r\n \"23.96.112.53/32\",\r\n\ + \ \"23.96.113.128/32\",\r\n \"23.96.124.25/32\",\r\n \ + \ \"23.96.187.5/32\",\r\n \"23.96.201.21/32\",\r\n \ + \ \"23.96.207.177/32\",\r\n \"23.96.209.155/32\",\r\n \"\ + 23.96.220.116/32\",\r\n \"23.97.56.169/32\",\r\n \"23.97.79.119/32\"\ + ,\r\n \"23.97.96.32/32\",\r\n \"23.97.160.56/32\",\r\n \ + \ \"23.97.160.74/32\",\r\n \"23.97.162.202/32\",\r\n \ + \ \"23.97.195.129/32\",\r\n \"23.97.208.18/32\",\r\n \ + \ \"23.97.214.177/32\",\r\n \"23.97.216.47/32\",\r\n \"\ + 23.97.224.11/32\",\r\n \"23.98.64.36/32\",\r\n \"23.98.64.158/32\"\ + ,\r\n \"23.99.0.12/32\",\r\n \"23.99.65.65/32\",\r\n \ + \ \"23.99.91.55/32\",\r\n \"23.99.110.192/32\",\r\n \ + \ \"23.99.116.70/32\",\r\n \"23.99.128.52/32\",\r\n \"\ + 23.99.183.149/32\",\r\n \"23.99.192.132/32\",\r\n \"23.99.196.180/32\"\ + ,\r\n \"23.99.206.151/32\",\r\n \"23.99.224.56/32\",\r\n\ + \ \"23.100.1.29/32\",\r\n \"23.100.46.198/32\",\r\n \ + \ \"23.100.48.106/32\",\r\n \"23.100.50.51/32\",\r\n \ + \ \"23.100.52.22/32\",\r\n \"23.100.56.27/32\",\r\n \"\ + 23.100.72.240/32\",\r\n \"23.100.82.11/32\",\r\n \"23.101.10.141/32\"\ + ,\r\n \"23.101.27.182/32\",\r\n \"23.101.54.230/32\",\r\n\ + \ \"23.101.63.214/32\",\r\n \"23.101.67.245/32\",\r\n \ + \ \"23.101.118.145/32\",\r\n \"23.101.119.44/32\",\r\n \ + \ \"23.101.119.163/32\",\r\n \"23.101.120.195/32\",\r\n \ + \ \"23.101.125.65/32\",\r\n \"23.101.147.117/32\",\r\n \ + \ \"23.101.169.175/32\",\r\n \"23.101.171.94/32\",\r\n \ + \ \"23.101.172.244/32\",\r\n \"23.101.180.75/32\",\r\n \ + \ \"23.101.203.117/32\",\r\n \"23.101.203.214/32\",\r\n \ + \ \"23.101.207.250/32\",\r\n \"23.101.208.52/32\",\r\n \ + \ \"23.101.224.24/32\",\r\n \"23.101.230.162/32\",\r\n \ + \ \"23.102.12.43/32\",\r\n \"23.102.21.198/32\",\r\n \"\ + 23.102.21.212/32\",\r\n \"23.102.25.149/32\",\r\n \"23.102.28.178/32\"\ + ,\r\n \"23.102.154.38/32\",\r\n \"23.102.161.217/32\",\r\ + \n \"23.102.191.170/32\",\r\n \"40.64.128.224/27\",\r\n\ + \ \"40.67.58.192/27\",\r\n \"40.68.40.55/32\",\r\n \ + \ \"40.68.205.178/32\",\r\n \"40.68.208.131/32\",\r\n \ + \ \"40.68.210.104/32\",\r\n \"40.68.214.185/32\",\r\n \ + \ \"40.69.43.225/32\",\r\n \"40.69.88.149/32\",\r\n \"40.69.106.96/27\"\ + ,\r\n \"40.69.190.41/32\",\r\n \"40.69.200.124/32\",\r\n\ + \ \"40.69.210.172/32\",\r\n \"40.69.218.150/32\",\r\n \ + \ \"40.70.27.35/32\",\r\n \"40.70.147.0/25\",\r\n \ + \ \"40.71.0.179/32\",\r\n \"40.71.11.128/25\",\r\n \"40.71.177.34/32\"\ + ,\r\n \"40.71.199.117/32\",\r\n \"40.71.234.254/32\",\r\n\ + \ \"40.71.250.191/32\",\r\n \"40.74.100.128/27\",\r\n \ + \ \"40.74.133.20/32\",\r\n \"40.74.245.188/32\",\r\n \ + \ \"40.74.253.108/32\",\r\n \"40.74.255.112/32\",\r\n \ + \ \"40.76.5.137/32\",\r\n \"40.76.192.15/32\",\r\n \"\ + 40.76.210.54/32\",\r\n \"40.76.218.33/32\",\r\n \"40.76.223.101/32\"\ + ,\r\n \"40.77.56.174/32\",\r\n \"40.78.18.232/32\",\r\n\ + \ \"40.78.25.157/32\",\r\n \"40.78.48.219/32\",\r\n \ + \ \"40.78.194.96/27\",\r\n \"40.78.204.160/27\",\r\n \ + \ \"40.79.65.200/32\",\r\n \"40.79.130.128/27\",\r\n \"\ + 40.79.154.192/27\",\r\n \"40.79.163.160/27\",\r\n \"40.79.171.64/27\"\ + ,\r\n \"40.79.178.96/27\",\r\n \"40.79.195.0/27\",\r\n \ + \ \"40.80.50.160/27\",\r\n \"40.80.58.224/27\",\r\n \ + \ \"40.80.155.102/32\",\r\n \"40.80.156.205/32\",\r\n \ + \ \"40.80.170.224/27\",\r\n \"40.80.191.0/25\",\r\n \"\ + 40.82.191.84/32\",\r\n \"40.82.217.93/32\",\r\n \"40.82.255.128/25\"\ + ,\r\n \"40.83.16.172/32\",\r\n \"40.83.72.59/32\",\r\n \ + \ \"40.83.124.73/32\",\r\n \"40.83.145.50/32\",\r\n \ + \ \"40.83.150.233/32\",\r\n \"40.83.182.206/32\",\r\n \ + \ \"40.83.183.236/32\",\r\n \"40.83.184.25/32\",\r\n \"\ + 40.84.54.203/32\",\r\n \"40.84.59.174/32\",\r\n \"40.84.148.247/32\"\ + ,\r\n \"40.84.159.58/32\",\r\n \"40.84.194.106/32\",\r\n\ + \ \"40.84.226.176/32\",\r\n \"40.84.227.180/32\",\r\n \ + \ \"40.84.232.28/32\",\r\n \"40.85.74.227/32\",\r\n \ + \ \"40.85.92.115/32\",\r\n \"40.85.96.208/32\",\r\n \"\ + 40.85.190.10/32\",\r\n \"40.85.212.173/32\",\r\n \"40.85.230.182/32\"\ + ,\r\n \"40.86.86.144/32\",\r\n \"40.86.91.212/32\",\r\n\ + \ \"40.86.96.177/32\",\r\n \"40.86.99.202/32\",\r\n \ + \ \"40.86.225.89/32\",\r\n \"40.86.230.96/32\",\r\n \ + \ \"40.87.65.131/32\",\r\n \"40.87.70.95/32\",\r\n \"40.89.19.0/27\"\ + ,\r\n \"40.89.131.148/32\",\r\n \"40.89.141.103/32\",\r\n\ + \ \"40.112.69.156/32\",\r\n \"40.112.90.244/32\",\r\n \ + \ \"40.112.93.201/32\",\r\n \"40.112.142.148/32\",\r\n \ + \ \"40.112.143.134/32\",\r\n \"40.112.143.140/32\",\r\n \ + \ \"40.112.143.214/32\",\r\n \"40.112.165.44/32\",\r\n \ + \ \"40.112.166.161/32\",\r\n \"40.112.191.159/32\",\r\n \ + \ \"40.112.192.69/32\",\r\n \"40.112.216.189/32\",\r\n \ + \ \"40.112.243.0/25\",\r\n \"40.113.2.52/32\",\r\n \"\ + 40.113.65.9/32\",\r\n \"40.113.71.148/32\",\r\n \"40.113.81.82/32\"\ + ,\r\n \"40.113.90.202/32\",\r\n \"40.113.126.251/32\",\r\ + \n \"40.113.131.37/32\",\r\n \"40.113.136.240/32\",\r\n\ + \ \"40.113.142.219/32\",\r\n \"40.113.204.88/32\",\r\n \ + \ \"40.113.232.243/32\",\r\n \"40.113.236.45/32\",\r\n \ + \ \"40.114.13.25/32\",\r\n \"40.114.41.245/32\",\r\n \ + \ \"40.114.51.68/32\",\r\n \"40.114.68.21/32\",\r\n \ + \ \"40.114.106.25/32\",\r\n \"40.114.194.188/32\",\r\n \"\ + 40.114.210.78/32\",\r\n \"40.114.228.161/32\",\r\n \"40.114.237.65/32\"\ + ,\r\n \"40.114.243.70/32\",\r\n \"40.115.55.251/32\",\r\n\ + \ \"40.115.98.85/32\",\r\n \"40.115.179.121/32\",\r\n \ + \ \"40.115.251.148/32\",\r\n \"40.117.154.240/32\",\r\n \ + \ \"40.117.188.126/32\",\r\n \"40.117.190.72/32\",\r\n \ + \ \"40.118.29.72/32\",\r\n \"40.118.71.240/32\",\r\n \ + \ \"40.118.96.231/32\",\r\n \"40.118.100.127/32\",\r\n \ + \ \"40.118.101.67/32\",\r\n \"40.118.102.46/32\",\r\n \ + \ \"40.118.185.161/32\",\r\n \"40.118.235.113/32\",\r\n \ + \ \"40.118.246.51/32\",\r\n \"40.118.255.59/32\",\r\n \"\ + 40.119.12.0/23\",\r\n \"40.120.74.32/27\",\r\n \"40.121.8.241/32\"\ + ,\r\n \"40.121.16.193/32\",\r\n \"40.121.32.232/32\",\r\n\ + \ \"40.121.35.221/32\",\r\n \"40.121.91.199/32\",\r\n \ + \ \"40.121.212.165/32\",\r\n \"40.121.221.52/32\",\r\n \ + \ \"40.122.36.65/32\",\r\n \"40.122.65.162/32\",\r\n \ + \ \"40.122.110.154/32\",\r\n \"40.122.114.229/32\",\r\n \ + \ \"40.123.45.47/32\",\r\n \"40.123.47.58/32\",\r\n \"\ + 40.124.12.75/32\",\r\n \"40.124.13.58/32\",\r\n \"40.126.227.158/32\"\ + ,\r\n \"40.126.236.22/32\",\r\n \"40.126.242.59/32\",\r\n\ + \ \"40.126.245.169/32\",\r\n \"40.127.132.204/32\",\r\n\ + \ \"40.127.139.252/32\",\r\n \"40.127.192.244/32\",\r\n\ + \ \"40.127.196.56/32\",\r\n \"51.12.98.192/27\",\r\n \ + \ \"51.12.202.192/27\",\r\n \"51.12.226.160/27\",\r\n \ + \ \"51.12.234.160/27\",\r\n \"51.104.28.64/26\",\r\n \ + \ \"51.105.66.160/27\",\r\n \"51.105.74.160/27\",\r\n \"\ + 51.105.90.32/27\",\r\n \"51.105.172.25/32\",\r\n \"51.107.50.0/27\"\ + ,\r\n \"51.107.58.160/27\",\r\n \"51.107.146.0/27\",\r\n\ + \ \"51.107.154.160/27\",\r\n \"51.116.49.32/27\",\r\n \ + \ \"51.116.58.160/27\",\r\n \"51.116.145.32/27\",\r\n \ + \ \"51.116.154.224/27\",\r\n \"51.116.242.160/27\",\r\n \ + \ \"51.116.250.160/27\",\r\n \"51.120.42.0/27\",\r\n \ + \ \"51.120.98.192/27\",\r\n \"51.120.106.160/27\",\r\n \ + \ \"51.120.210.160/27\",\r\n \"51.120.218.192/27\",\r\n \ + \ \"51.120.226.0/27\",\r\n \"51.136.14.31/32\",\r\n \"\ + 51.137.106.13/32\",\r\n \"51.137.163.32/27\",\r\n \"51.140.37.241/32\"\ + ,\r\n \"51.140.57.176/32\",\r\n \"51.140.59.233/32\",\r\n\ + \ \"51.140.75.147/32\",\r\n \"51.140.84.145/32\",\r\n \ + \ \"51.140.85.106/32\",\r\n \"51.140.87.39/32\",\r\n \ + \ \"51.140.122.226/32\",\r\n \"51.140.146.128/26\",\r\n \ + \ \"51.140.152.154/32\",\r\n \"51.140.153.150/32\",\r\n \ + \ \"51.140.180.76/32\",\r\n \"51.140.185.151/32\",\r\n \ + \ \"51.140.191.223/32\",\r\n \"51.140.210.96/27\",\r\n \ + \ \"51.140.244.162/32\",\r\n \"51.140.245.89/32\",\r\n \ + \ \"51.141.12.112/32\",\r\n \"51.141.37.245/32\",\r\n \"\ + 51.141.44.139/32\",\r\n \"51.141.45.207/32\",\r\n \"51.141.90.252/32\"\ + ,\r\n \"51.143.102.21/32\",\r\n \"51.143.191.44/32\",\r\n\ + \ \"51.144.7.192/32\",\r\n \"51.144.107.53/32\",\r\n \ + \ \"51.144.116.43/32\",\r\n \"51.144.164.215/32\",\r\n \ + \ \"51.144.182.8/32\",\r\n \"52.136.50.0/27\",\r\n \ + \ \"52.136.138.55/32\",\r\n \"52.138.196.70/32\",\r\n \"\ + 52.138.218.121/32\",\r\n \"52.140.106.224/27\",\r\n \"52.143.137.150/32\"\ + ,\r\n \"52.150.140.224/27\",\r\n \"52.151.62.51/32\",\r\n\ + \ \"52.160.40.218/32\",\r\n \"52.161.96.193/32\",\r\n \ + \ \"52.162.107.0/25\",\r\n \"52.162.208.73/32\",\r\n \ + \ \"52.163.122.160/32\",\r\n \"52.164.201.186/32\",\r\n \ + \ \"52.164.250.133/32\",\r\n \"52.165.129.203/32\",\r\n \ + \ \"52.165.135.234/32\",\r\n \"52.165.155.12/32\",\r\n \ + \ \"52.165.155.237/32\",\r\n \"52.165.163.223/32\",\r\n \ + \ \"52.165.168.40/32\",\r\n \"52.165.174.123/32\",\r\n \ + \ \"52.165.184.170/32\",\r\n \"52.165.220.33/32\",\r\n \ + \ \"52.165.224.81/32\",\r\n \"52.165.237.15/32\",\r\n \"\ + 52.166.78.97/32\",\r\n \"52.166.113.188/32\",\r\n \"52.166.119.99/32\"\ + ,\r\n \"52.166.178.208/32\",\r\n \"52.166.181.85/32\",\r\ + \n \"52.166.198.163/32\",\r\n \"52.168.125.188/32\",\r\n\ + \ \"52.169.73.236/32\",\r\n \"52.169.78.163/32\",\r\n \ + \ \"52.169.180.223/32\",\r\n \"52.169.184.163/32\",\r\n \ + \ \"52.169.188.236/32\",\r\n \"52.169.191.40/32\",\r\n \ + \ \"52.170.7.25/32\",\r\n \"52.170.46.174/32\",\r\n \ + \ \"52.171.56.101/32\",\r\n \"52.171.56.110/32\",\r\n \ + \ \"52.171.136.200/32\",\r\n \"52.171.140.237/32\",\r\n \ + \ \"52.171.218.239/32\",\r\n \"52.171.221.170/32\",\r\n \ + \ \"52.171.222.247/32\",\r\n \"52.172.54.225/32\",\r\n \"\ + 52.172.195.80/32\",\r\n \"52.172.204.196/32\",\r\n \"52.172.219.121/32\"\ + ,\r\n \"52.173.28.95/32\",\r\n \"52.173.36.83/32\",\r\n\ + \ \"52.173.76.33/32\",\r\n \"52.173.77.140/32\",\r\n \ + \ \"52.173.83.49/32\",\r\n \"52.173.84.157/32\",\r\n \ + \ \"52.173.87.130/32\",\r\n \"52.173.94.173/32\",\r\n \ + \ \"52.173.134.115/32\",\r\n \"52.173.139.99/32\",\r\n \ + \ \"52.173.139.125/32\",\r\n \"52.173.149.254/32\",\r\n \ + \ \"52.173.151.229/32\",\r\n \"52.173.184.147/32\",\r\n \ + \ \"52.173.245.249/32\",\r\n \"52.173.249.137/32\",\r\n \ + \ \"52.174.3.80/32\",\r\n \"52.174.7.133/32\",\r\n \"52.174.35.5/32\"\ + ,\r\n \"52.174.106.15/32\",\r\n \"52.174.150.25/32\",\r\n\ + \ \"52.174.181.178/32\",\r\n \"52.174.184.18/32\",\r\n \ + \ \"52.174.193.210/32\",\r\n \"52.174.235.29/32\",\r\n \ + \ \"52.175.158.219/32\",\r\n \"52.175.202.25/32\",\r\n \ + \ \"52.175.254.10/32\",\r\n \"52.176.2.229/32\",\r\n \ + \ \"52.176.5.241/32\",\r\n \"52.176.6.0/32\",\r\n \"\ + 52.176.6.37/32\",\r\n \"52.176.61.128/32\",\r\n \"52.176.104.120/32\"\ + ,\r\n \"52.176.149.197/32\",\r\n \"52.176.165.69/32\",\r\ + \n \"52.177.169.150/32\",\r\n \"52.177.189.138/32\",\r\n\ + \ \"52.177.206.73/32\",\r\n \"52.178.29.39/32\",\r\n \ + \ \"52.178.37.244/32\",\r\n \"52.178.43.209/32\",\r\n \ + \ \"52.178.45.139/32\",\r\n \"52.178.46.181/32\",\r\n \ + \ \"52.178.75.200/32\",\r\n \"52.178.79.163/32\",\r\n \ + \ \"52.178.89.129/32\",\r\n \"52.178.90.230/32\",\r\n \"\ + 52.178.92.96/32\",\r\n \"52.178.105.179/32\",\r\n \"52.178.114.226/32\"\ + ,\r\n \"52.178.158.175/32\",\r\n \"52.178.164.235/32\",\r\ + \n \"52.178.179.169/32\",\r\n \"52.178.190.191/32\",\r\n\ + \ \"52.178.201.147/32\",\r\n \"52.178.208.12/32\",\r\n \ + \ \"52.178.212.17/32\",\r\n \"52.178.214.89/32\",\r\n \ + \ \"52.179.97.15/32\",\r\n \"52.179.188.206/32\",\r\n \ + \ \"52.180.178.6/32\",\r\n \"52.180.183.66/32\",\r\n \ + \ \"52.183.82.125/32\",\r\n \"52.184.162.135/32\",\r\n \ + \ \"52.184.193.103/32\",\r\n \"52.184.193.104/32\",\r\n \ + \ \"52.187.17.126/32\",\r\n \"52.187.36.104/32\",\r\n \"\ + 52.187.52.94/32\",\r\n \"52.187.135.79/32\",\r\n \"52.187.206.243/32\"\ + ,\r\n \"52.187.229.23/32\",\r\n \"52.189.213.49/32\",\r\n\ + \ \"52.225.179.39/32\",\r\n \"52.225.190.65/32\",\r\n \ + \ \"52.226.134.64/32\",\r\n \"52.228.42.76/32\",\r\n \ + \ \"52.228.84.32/27\",\r\n \"52.228.121.123/32\",\r\n \ + \ \"52.229.30.210/32\",\r\n \"52.229.115.84/32\",\r\n \ + \ \"52.230.1.186/32\",\r\n \"52.231.18.128/27\",\r\n \"\ + 52.231.32.120/32\",\r\n \"52.231.38.95/32\",\r\n \"52.231.77.58/32\"\ + ,\r\n \"52.231.146.96/27\",\r\n \"52.231.200.101/32\",\r\ + \n \"52.231.200.179/32\",\r\n \"52.232.19.237/32\",\r\n\ + \ \"52.232.26.228/32\",\r\n \"52.232.33.202/32\",\r\n \ + \ \"52.232.56.79/32\",\r\n \"52.232.127.196/32\",\r\n \ + \ \"52.233.38.143/32\",\r\n \"52.233.128.61/32\",\r\n \ + \ \"52.233.133.18/32\",\r\n \"52.233.133.121/32\",\r\n \ + \ \"52.233.155.168/32\",\r\n \"52.233.164.195/32\",\r\n \ + \ \"52.233.175.59/32\",\r\n \"52.233.184.181/32\",\r\n \ + \ \"52.233.198.206/32\",\r\n \"52.234.209.94/32\",\r\n \ + \ \"52.237.18.220/32\",\r\n \"52.237.22.139/32\",\r\n \"\ + 52.237.130.0/32\",\r\n \"52.237.205.163/32\",\r\n \"52.237.214.221/32\"\ + ,\r\n \"52.237.246.162/32\",\r\n \"52.240.149.243/32\",\r\ + \n \"52.240.155.58/32\",\r\n \"52.242.22.213/32\",\r\n \ + \ \"52.242.27.213/32\",\r\n \"52.243.39.89/32\",\r\n \ + \ \"52.246.154.160/27\",\r\n \"52.252.160.21/32\",\r\n \ + \ \"52.253.224.223/32\",\r\n \"52.255.35.249/32\",\r\n \ + \ \"52.255.54.134/32\",\r\n \"65.52.24.41/32\",\r\n \"\ + 65.52.128.33/32\",\r\n \"65.52.130.1/32\",\r\n \"65.52.160.119/32\"\ + ,\r\n \"65.52.168.70/32\",\r\n \"65.52.213.73/32\",\r\n\ + \ \"65.52.217.59/32\",\r\n \"65.52.218.253/32\",\r\n \ + \ \"65.52.250.96/27\",\r\n \"94.245.104.73/32\",\r\n \ + \ \"102.133.26.32/27\",\r\n \"102.133.57.128/27\",\r\n \ + \ \"102.133.122.160/27\",\r\n \"102.133.154.32/27\",\r\n \ + \ \"102.133.218.32/28\",\r\n \"102.133.250.160/27\",\r\n \ + \ \"104.40.3.53/32\",\r\n \"104.40.11.192/32\",\r\n \ + \ \"104.40.28.133/32\",\r\n \"104.40.53.219/32\",\r\n \"\ + 104.40.63.98/32\",\r\n \"104.40.84.133/32\",\r\n \"104.40.92.107/32\"\ + ,\r\n \"104.40.129.89/32\",\r\n \"104.40.147.180/32\",\r\ + \n \"104.40.147.216/32\",\r\n \"104.40.158.55/32\",\r\n\ + \ \"104.40.179.243/32\",\r\n \"104.40.183.236/32\",\r\n\ + \ \"104.40.185.192/32\",\r\n \"104.40.187.26/32\",\r\n \ + \ \"104.40.191.174/32\",\r\n \"104.40.210.25/32\",\r\n \ + \ \"104.40.215.219/32\",\r\n \"104.40.222.81/32\",\r\n \ + \ \"104.40.250.100/32\",\r\n \"104.41.9.139/32\",\r\n \ + \ \"104.41.13.179/32\",\r\n \"104.41.63.108/32\",\r\n \ + \ \"104.41.186.103/32\",\r\n \"104.41.216.137/32\",\r\n \ + \ \"104.41.229.199/32\",\r\n \"104.42.53.248/32\",\r\n \ + \ \"104.42.78.153/32\",\r\n \"104.42.128.171/32\",\r\n \ + \ \"104.42.148.55/32\",\r\n \"104.42.152.64/32\",\r\n \"\ + 104.42.154.105/32\",\r\n \"104.42.188.146/32\",\r\n \"104.42.231.5/32\"\ + ,\r\n \"104.43.129.105/32\",\r\n \"104.43.140.101/32\",\r\ + \n \"104.43.142.33/32\",\r\n \"104.43.221.31/32\",\r\n \ + \ \"104.43.246.71/32\",\r\n \"104.43.254.102/32\",\r\n \ + \ \"104.44.128.13/32\",\r\n \"104.44.130.38/32\",\r\n \ + \ \"104.45.1.117/32\",\r\n \"104.45.14.249/32\",\r\n \ + \ \"104.45.81.79/32\",\r\n \"104.45.95.61/32\",\r\n \"\ + 104.45.129.178/32\",\r\n \"104.45.141.247/32\",\r\n \"104.45.152.13/32\"\ + ,\r\n \"104.45.152.60/32\",\r\n \"104.45.154.200/32\",\r\ + \n \"104.45.226.98/32\",\r\n \"104.45.231.79/32\",\r\n \ + \ \"104.46.38.245/32\",\r\n \"104.46.44.78/32\",\r\n \ + \ \"104.46.61.116/32\",\r\n \"104.46.101.59/32\",\r\n \ + \ \"104.47.137.62/32\",\r\n \"104.47.151.115/32\",\r\n \ + \ \"104.47.160.14/32\",\r\n \"104.47.164.119/32\",\r\n \ + \ \"104.208.48.107/32\",\r\n \"104.209.178.67/32\",\r\n \ + \ \"104.209.192.206/32\",\r\n \"104.209.197.87/32\",\r\n \ + \ \"104.210.38.149/32\",\r\n \"104.210.69.241/32\",\r\n \ + \ \"104.210.92.71/32\",\r\n \"104.210.145.181/32\",\r\n \ + \ \"104.210.147.57/32\",\r\n \"104.210.152.76/32\",\r\n \ + \ \"104.210.152.122/32\",\r\n \"104.210.153.116/32\",\r\n \ + \ \"104.210.158.20/32\",\r\n \"104.211.26.212/32\",\r\n \ + \ \"104.211.81.32/27\",\r\n \"104.211.97.138/32\",\r\n \ + \ \"104.211.146.96/27\",\r\n \"104.211.160.159/32\",\r\n \ + \ \"104.211.179.11/32\",\r\n \"104.211.184.197/32\",\r\n \ + \ \"104.211.224.252/32\",\r\n \"104.211.225.167/32\",\r\n \ + \ \"104.214.20.0/23\",\r\n \"104.214.29.203/32\",\r\n \ + \ \"104.214.64.238/32\",\r\n \"104.214.74.110/32\",\r\n \ + \ \"104.214.77.221/32\",\r\n \"104.214.110.60/32\",\r\n \ + \ \"104.214.110.226/32\",\r\n \"104.214.118.174/32\",\r\n \ + \ \"104.214.119.36/32\",\r\n \"104.214.137.236/32\",\r\n \ + \ \"104.214.231.110/32\",\r\n \"104.214.236.47/32\",\r\n\ + \ \"104.214.237.135/32\",\r\n \"104.215.11.176/32\",\r\n\ + \ \"104.215.58.230/32\",\r\n \"104.215.73.236/32\",\r\n\ + \ \"104.215.78.13/32\",\r\n \"104.215.89.22/32\",\r\n \ + \ \"104.215.147.45/32\",\r\n \"104.215.155.1/32\",\r\n \ + \ \"111.221.95.27/32\",\r\n \"137.116.78.243/32\",\r\n \ + \ \"137.116.88.213/32\",\r\n \"137.116.128.188/32\",\r\n \ + \ \"137.116.153.238/32\",\r\n \"137.117.9.212/32\",\r\n \ + \ \"137.117.17.70/32\",\r\n \"137.117.58.204/32\",\r\n \ + \ \"137.117.66.167/32\",\r\n \"137.117.84.54/32\",\r\n \ + \ \"137.117.90.63/32\",\r\n \"137.117.93.87/32\",\r\n \ + \ \"137.117.166.35/32\",\r\n \"137.117.175.14/32\",\r\n \ + \ \"137.117.203.130/32\",\r\n \"137.117.211.244/32\",\r\n \ + \ \"137.117.218.101/32\",\r\n \"137.117.224.218/32\",\r\n \ + \ \"137.117.225.87/32\",\r\n \"137.135.91.176/32\",\r\n \ + \ \"137.135.107.235/32\",\r\n \"137.135.129.175/32\",\r\n \ + \ \"137.135.133.221/32\",\r\n \"138.91.0.30/32\",\r\n \ + \ \"138.91.16.18/32\",\r\n \"138.91.224.84/32\",\r\n \ + \ \"138.91.225.40/32\",\r\n \"138.91.240.81/32\",\r\n \ + \ \"157.56.13.114/32\",\r\n \"168.61.152.29/32\",\r\n \"\ + 168.61.159.114/32\",\r\n \"168.61.217.214/32\",\r\n \"168.61.218.125/32\"\ + ,\r\n \"168.62.20.37/32\",\r\n \"168.62.48.183/32\",\r\n\ + \ \"168.62.180.173/32\",\r\n \"168.62.224.13/32\",\r\n \ + \ \"168.62.225.23/32\",\r\n \"168.63.5.231/32\",\r\n \ + \ \"168.63.53.239/32\",\r\n \"168.63.107.5/32\",\r\n \ + \ \"191.232.38.77/32\",\r\n \"191.232.176.16/32\",\r\n \ + \ \"191.233.50.32/27\",\r\n \"191.233.82.44/32\",\r\n \"\ + 191.233.85.165/32\",\r\n \"191.233.87.194/32\",\r\n \"191.233.203.32/27\"\ + ,\r\n \"191.234.16.188/32\",\r\n \"191.234.146.160/27\"\ + ,\r\n \"191.234.154.160/27\",\r\n \"191.235.81.73/32\",\r\ + \n \"191.235.90.70/32\",\r\n \"191.235.160.13/32\",\r\n\ + \ \"191.235.176.12/32\",\r\n \"191.235.177.30/32\",\r\n\ + \ \"191.235.208.12/32\",\r\n \"191.235.215.184/32\",\r\n\ + \ \"191.235.228.32/27\",\r\n \"191.236.16.12/32\",\r\n \ + \ \"191.236.59.67/32\",\r\n \"191.236.80.12/32\",\r\n \ + \ \"191.236.106.123/32\",\r\n \"191.236.148.9/32\",\r\n \ + \ \"191.236.192.121/32\",\r\n \"191.237.24.89/32\",\r\n \ + \ \"191.237.27.74/32\",\r\n \"191.237.128.238/32\",\r\n \ + \ \"191.238.8.26/32\",\r\n \"191.238.33.50/32\",\r\n \ + \ \"191.238.176.139/32\",\r\n \"191.238.240.12/32\",\r\n \ + \ \"191.239.58.162/32\",\r\n \"191.239.188.11/32\",\r\n \ + \ \"207.46.144.49/32\",\r\n \"207.46.147.148/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaCentral\"\ + ,\r\n \"id\": \"AppService.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.36.43.207/32\",\r\n \ + \ \"20.36.106.96/27\",\r\n \"20.37.226.0/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaCentral2\"\ + ,\r\n \"id\": \"AppService.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.36.72.230/32\",\r\n \ + \ \"20.36.117.0/27\",\r\n \"20.36.122.0/27\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaEast\"\ + ,\r\n \"id\": \"AppService.AustraliaEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.70.72.32/27\",\r\n \ + \ \"13.70.123.149/32\",\r\n \"13.75.138.224/32\",\r\n \ + \ \"13.75.147.143/32\",\r\n \"13.75.147.201/32\",\r\n \ + \ \"13.75.218.45/32\",\r\n \"20.37.196.192/27\",\r\n \"\ + 23.101.208.52/32\",\r\n \"40.79.163.160/27\",\r\n \"40.79.171.64/27\"\ + ,\r\n \"40.82.217.93/32\",\r\n \"40.126.227.158/32\",\r\n\ + \ \"40.126.236.22/32\",\r\n \"40.126.242.59/32\",\r\n \ + \ \"40.126.245.169/32\",\r\n \"52.187.206.243/32\",\r\n \ + \ \"52.187.229.23/32\",\r\n \"52.237.205.163/32\",\r\n \ + \ \"52.237.214.221/32\",\r\n \"52.237.246.162/32\",\r\n \ + \ \"104.210.69.241/32\",\r\n \"104.210.92.71/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AppService.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.70.146.110/32\",\r\n \ + \ \"13.70.147.206/32\",\r\n \"13.73.116.45/32\",\r\n \ + \ \"13.73.118.104/32\",\r\n \"13.77.7.175/32\",\r\n \"\ + 13.77.50.96/27\",\r\n \"20.42.228.160/27\",\r\n \"23.101.224.24/32\"\ + ,\r\n \"23.101.230.162/32\",\r\n \"52.189.213.49/32\",\r\ + \n \"52.255.35.249/32\",\r\n \"52.255.54.134/32\",\r\n \ + \ \"191.239.188.11/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.BrazilSouth\",\r\n \"id\": \"AppService.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"23.97.96.32/32\"\ + ,\r\n \"104.41.9.139/32\",\r\n \"104.41.13.179/32\",\r\n\ + \ \"104.41.63.108/32\",\r\n \"191.232.38.77/32\",\r\n \ + \ \"191.232.176.16/32\",\r\n \"191.233.203.32/27\",\r\n \ + \ \"191.234.146.160/27\",\r\n \"191.234.154.160/27\",\r\n\ + \ \"191.235.81.73/32\",\r\n \"191.235.90.70/32\",\r\n \ + \ \"191.235.228.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.CanadaCentral\",\r\n \"id\": \"AppService.CanadaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.128/27\"\ + ,\r\n \"20.38.146.160/27\",\r\n \"40.82.191.84/32\",\r\n\ + \ \"40.85.212.173/32\",\r\n \"40.85.230.182/32\",\r\n \ + \ \"52.228.42.76/32\",\r\n \"52.228.84.32/27\",\r\n \ + \ \"52.228.121.123/32\",\r\n \"52.233.38.143/32\",\r\n \ + \ \"52.237.18.220/32\",\r\n \"52.237.22.139/32\",\r\n \ + \ \"52.246.154.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.CanadaEast\",\r\n \"id\": \"AppService.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.96/27\"\ + ,\r\n \"40.86.225.89/32\",\r\n \"40.86.230.96/32\",\r\n\ + \ \"40.89.19.0/27\",\r\n \"52.229.115.84/32\",\r\n \ + \ \"52.242.22.213/32\",\r\n \"52.242.27.213/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.CentralIndia\"\ + ,\r\n \"id\": \"AppService.CentralIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.192.98.160/27\",\r\n \ + \ \"40.80.50.160/27\",\r\n \"52.140.106.224/27\",\r\n \ + \ \"52.172.195.80/32\",\r\n \"52.172.204.196/32\",\r\n \ + \ \"52.172.219.121/32\",\r\n \"104.211.81.32/27\",\r\n \ + \ \"104.211.97.138/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.CentralUS\",\r\n \"id\": \"AppService.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.67.129.26/32\"\ + ,\r\n \"13.67.141.98/32\",\r\n \"13.89.57.7/32\",\r\n \ + \ \"13.89.172.0/23\",\r\n \"13.89.238.239/32\",\r\n \ + \ \"20.40.202.0/23\",\r\n \"23.99.128.52/32\",\r\n \"\ + 23.99.183.149/32\",\r\n \"23.99.192.132/32\",\r\n \"23.99.196.180/32\"\ + ,\r\n \"23.99.206.151/32\",\r\n \"23.99.224.56/32\",\r\n\ + \ \"23.100.82.11/32\",\r\n \"23.101.118.145/32\",\r\n \ + \ \"23.101.119.44/32\",\r\n \"23.101.119.163/32\",\r\n \ + \ \"23.101.120.195/32\",\r\n \"23.101.125.65/32\",\r\n \ + \ \"40.69.190.41/32\",\r\n \"40.77.56.174/32\",\r\n \ + \ \"40.83.16.172/32\",\r\n \"40.86.86.144/32\",\r\n \"\ + 40.86.91.212/32\",\r\n \"40.86.96.177/32\",\r\n \"40.86.99.202/32\"\ + ,\r\n \"40.113.204.88/32\",\r\n \"40.113.232.243/32\",\r\ + \n \"40.113.236.45/32\",\r\n \"40.122.36.65/32\",\r\n \ + \ \"40.122.65.162/32\",\r\n \"40.122.110.154/32\",\r\n \ + \ \"40.122.114.229/32\",\r\n \"52.165.129.203/32\",\r\n \ + \ \"52.165.135.234/32\",\r\n \"52.165.155.12/32\",\r\n \ + \ \"52.165.155.237/32\",\r\n \"52.165.163.223/32\",\r\n \ + \ \"52.165.168.40/32\",\r\n \"52.165.174.123/32\",\r\n \ + \ \"52.165.184.170/32\",\r\n \"52.165.220.33/32\",\r\n \ + \ \"52.165.224.81/32\",\r\n \"52.165.237.15/32\",\r\n \ + \ \"52.173.28.95/32\",\r\n \"52.173.36.83/32\",\r\n \"\ + 52.173.76.33/32\",\r\n \"52.173.77.140/32\",\r\n \"52.173.83.49/32\"\ + ,\r\n \"52.173.84.157/32\",\r\n \"52.173.87.130/32\",\r\n\ + \ \"52.173.94.173/32\",\r\n \"52.173.134.115/32\",\r\n \ + \ \"52.173.139.99/32\",\r\n \"52.173.139.125/32\",\r\n \ + \ \"52.173.149.254/32\",\r\n \"52.173.151.229/32\",\r\n \ + \ \"52.173.184.147/32\",\r\n \"52.173.245.249/32\",\r\n \ + \ \"52.173.249.137/32\",\r\n \"52.176.2.229/32\",\r\n \ + \ \"52.176.5.241/32\",\r\n \"52.176.6.0/32\",\r\n \"\ + 52.176.6.37/32\",\r\n \"52.176.61.128/32\",\r\n \"52.176.104.120/32\"\ + ,\r\n \"52.176.149.197/32\",\r\n \"52.176.165.69/32\",\r\ + \n \"104.43.129.105/32\",\r\n \"104.43.140.101/32\",\r\n\ + \ \"104.43.142.33/32\",\r\n \"104.43.221.31/32\",\r\n \ + \ \"104.43.246.71/32\",\r\n \"104.43.254.102/32\",\r\n \ + \ \"168.61.152.29/32\",\r\n \"168.61.159.114/32\",\r\n \ + \ \"168.61.217.214/32\",\r\n \"168.61.218.125/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.CentralUSEUAP\"\ + ,\r\n \"id\": \"AppService.CentralUSEUAP\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.45.196.16/29\",\r\n \ + \ \"40.78.204.160/27\",\r\n \"52.180.178.6/32\",\r\n \ + \ \"52.180.183.66/32\",\r\n \"104.208.48.107/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.EastAsia\",\r\ + \n \"id\": \"AppService.EastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.75.34.160/27\",\r\n \ + \ \"13.75.46.26/32\",\r\n \"13.75.47.15/32\",\r\n \"13.75.89.224/32\"\ + ,\r\n \"13.75.112.108/32\",\r\n \"13.75.115.40/32\",\r\n\ + \ \"13.94.47.87/32\",\r\n \"20.189.104.96/27\",\r\n \ + \ \"20.189.109.96/27\",\r\n \"20.189.112.66/32\",\r\n \ + \ \"23.97.79.119/32\",\r\n \"23.99.110.192/32\",\r\n \ + \ \"23.99.116.70/32\",\r\n \"23.101.10.141/32\",\r\n \"\ + 40.83.72.59/32\",\r\n \"40.83.124.73/32\",\r\n \"65.52.160.119/32\"\ + ,\r\n \"65.52.168.70/32\",\r\n \"191.234.16.188/32\",\r\n\ + \ \"207.46.144.49/32\",\r\n \"207.46.147.148/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.EastUS\"\ + ,\r\n \"id\": \"AppService.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n\ + \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.82.93.245/32\",\r\n \"\ + 13.82.101.179/32\",\r\n \"13.82.175.96/32\",\r\n \"13.90.143.69/32\"\ + ,\r\n \"13.90.213.204/32\",\r\n \"13.92.139.214/32\",\r\n\ + \ \"13.92.193.110/32\",\r\n \"13.92.237.218/32\",\r\n \ + \ \"20.42.26.252/32\",\r\n \"20.49.104.0/25\",\r\n \ + \ \"23.96.0.52/32\",\r\n \"23.96.1.109/32\",\r\n \"23.96.13.243/32\"\ + ,\r\n \"23.96.32.128/32\",\r\n \"23.96.96.142/32\",\r\n\ + \ \"23.96.103.159/32\",\r\n \"23.96.112.53/32\",\r\n \ + \ \"23.96.113.128/32\",\r\n \"23.96.124.25/32\",\r\n \ + \ \"40.71.0.179/32\",\r\n \"40.71.11.128/25\",\r\n \"\ + 40.71.177.34/32\",\r\n \"40.71.199.117/32\",\r\n \"40.71.234.254/32\"\ + ,\r\n \"40.71.250.191/32\",\r\n \"40.76.5.137/32\",\r\n\ + \ \"40.76.192.15/32\",\r\n \"40.76.210.54/32\",\r\n \ + \ \"40.76.218.33/32\",\r\n \"40.76.223.101/32\",\r\n \ + \ \"40.79.154.192/27\",\r\n \"40.85.190.10/32\",\r\n \"\ + 40.87.65.131/32\",\r\n \"40.87.70.95/32\",\r\n \"40.114.13.25/32\"\ + ,\r\n \"40.114.41.245/32\",\r\n \"40.114.51.68/32\",\r\n\ + \ \"40.114.68.21/32\",\r\n \"40.114.106.25/32\",\r\n \ + \ \"40.117.154.240/32\",\r\n \"40.117.188.126/32\",\r\n \ + \ \"40.117.190.72/32\",\r\n \"40.121.8.241/32\",\r\n \ + \ \"40.121.16.193/32\",\r\n \"40.121.32.232/32\",\r\n \ + \ \"40.121.35.221/32\",\r\n \"40.121.91.199/32\",\r\n \"\ + 40.121.212.165/32\",\r\n \"40.121.221.52/32\",\r\n \"52.168.125.188/32\"\ + ,\r\n \"52.170.7.25/32\",\r\n \"52.170.46.174/32\",\r\n\ + \ \"52.179.97.15/32\",\r\n \"52.226.134.64/32\",\r\n \ + \ \"52.234.209.94/32\",\r\n \"104.45.129.178/32\",\r\n \ + \ \"104.45.141.247/32\",\r\n \"104.45.152.13/32\",\r\n \ + \ \"104.45.152.60/32\",\r\n \"104.45.154.200/32\",\r\n \ + \ \"104.211.26.212/32\",\r\n \"137.117.58.204/32\",\r\n \ + \ \"137.117.66.167/32\",\r\n \"137.117.84.54/32\",\r\n \ + \ \"137.117.90.63/32\",\r\n \"137.117.93.87/32\",\r\n \ + \ \"137.135.91.176/32\",\r\n \"137.135.107.235/32\",\r\n \ + \ \"168.62.48.183/32\",\r\n \"168.62.180.173/32\",\r\n \ + \ \"191.236.16.12/32\",\r\n \"191.236.59.67/32\",\r\n \"\ + 191.237.24.89/32\",\r\n \"191.237.27.74/32\",\r\n \"191.238.8.26/32\"\ + ,\r\n \"191.238.33.50/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppService.EastUS2\",\r\n \"id\": \"AppService.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.68.29.136/32\",\r\n\ + \ \"13.68.101.62/32\",\r\n \"13.77.82.141/32\",\r\n \ + \ \"13.77.83.246/32\",\r\n \"13.77.96.119/32\",\r\n \ + \ \"20.49.97.0/25\",\r\n \"23.101.147.117/32\",\r\n \"\ + 40.70.27.35/32\",\r\n \"40.70.147.0/25\",\r\n \"40.79.65.200/32\"\ + ,\r\n \"40.84.54.203/32\",\r\n \"40.84.59.174/32\",\r\n\ + \ \"40.123.45.47/32\",\r\n \"40.123.47.58/32\",\r\n \ + \ \"52.177.169.150/32\",\r\n \"52.177.189.138/32\",\r\n \ + \ \"52.177.206.73/32\",\r\n \"52.179.188.206/32\",\r\n \ + \ \"52.184.162.135/32\",\r\n \"52.184.193.103/32\",\r\n \ + \ \"52.184.193.104/32\",\r\n \"104.46.101.59/32\",\r\n \ + \ \"104.209.178.67/32\",\r\n \"104.209.192.206/32\",\r\n \ + \ \"104.209.197.87/32\",\r\n \"137.116.78.243/32\",\r\n \ + \ \"137.116.88.213/32\",\r\n \"191.236.192.121/32\",\r\n \ + \ \"191.237.128.238/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.EastUS2EUAP\",\r\n \"id\": \"AppService.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.39.11.104/29\"\ + ,\r\n \"52.225.179.39/32\",\r\n \"52.225.190.65/32\",\r\n\ + \ \"52.253.224.223/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppService.FranceCentral\",\r\n \"id\": \"AppService.FranceCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.43.43.32/27\"\ + ,\r\n \"40.79.130.128/27\",\r\n \"40.89.131.148/32\",\r\n\ + \ \"40.89.141.103/32\",\r\n \"52.143.137.150/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.FranceSouth\"\ + ,\r\n \"id\": \"AppService.FranceSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.79.178.96/27\",\r\n \ + \ \"51.105.90.32/27\",\r\n \"52.136.138.55/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.GermanyNorth\"\ + ,\r\n \"id\": \"AppService.GermanyNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.116.49.32/27\",\r\n \ + \ \"51.116.58.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.GermanyWestCentral\",\r\n \"id\": \"AppService.GermanyWestCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"51.116.145.32/27\"\ + ,\r\n \"51.116.154.224/27\",\r\n \"51.116.242.160/27\",\r\ + \n \"51.116.250.160/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppService.JapanEast\",\r\n \"id\": \"AppService.JapanEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.71.149.151/32\"\ + ,\r\n \"13.73.1.134/32\",\r\n \"13.73.26.73/32\",\r\n \ + \ \"13.78.59.237/32\",\r\n \"13.78.106.96/27\",\r\n \ + \ \"13.78.117.86/32\",\r\n \"13.78.123.87/32\",\r\n \"\ + 20.43.67.32/27\",\r\n \"40.79.195.0/27\",\r\n \"40.115.179.121/32\"\ + ,\r\n \"40.115.251.148/32\",\r\n \"52.243.39.89/32\",\r\n\ + \ \"104.41.186.103/32\",\r\n \"138.91.0.30/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.JapanWest\"\ + ,\r\n \"id\": \"AppService.JapanWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.74.100.128/27\",\r\n \ + \ \"40.74.133.20/32\",\r\n \"40.80.58.224/27\",\r\n \"\ + 52.175.158.219/32\",\r\n \"104.214.137.236/32\",\r\n \"\ + 104.215.11.176/32\",\r\n \"104.215.58.230/32\",\r\n \"138.91.16.18/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.KoreaCentral\"\ + ,\r\n \"id\": \"AppService.KoreaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.41.66.224/27\",\r\n \ + \ \"20.44.26.160/27\",\r\n \"20.194.66.32/27\",\r\n \ + \ \"52.231.18.128/27\",\r\n \"52.231.32.120/32\",\r\n \"\ + 52.231.38.95/32\",\r\n \"52.231.77.58/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AppService.KoreaSouth\",\r\n \ + \ \"id\": \"AppService.KoreaSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.80.170.224/27\",\r\n \ + \ \"52.231.146.96/27\",\r\n \"52.231.200.101/32\",\r\n \ + \ \"52.231.200.179/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.NorthCentralUS\",\r\n \"id\": \"AppService.NorthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"23.96.187.5/32\"\ + ,\r\n \"23.96.201.21/32\",\r\n \"23.96.207.177/32\",\r\n\ + \ \"23.96.209.155/32\",\r\n \"23.96.220.116/32\",\r\n \ + \ \"23.100.72.240/32\",\r\n \"23.101.169.175/32\",\r\n \ + \ \"23.101.171.94/32\",\r\n \"23.101.172.244/32\",\r\n \ + \ \"40.80.191.0/25\",\r\n \"52.162.107.0/25\",\r\n \ + \ \"52.162.208.73/32\",\r\n \"52.237.130.0/32\",\r\n \"\ + 52.240.149.243/32\",\r\n \"52.240.155.58/32\",\r\n \"52.252.160.21/32\"\ + ,\r\n \"65.52.24.41/32\",\r\n \"65.52.213.73/32\",\r\n \ + \ \"65.52.217.59/32\",\r\n \"65.52.218.253/32\",\r\n \ + \ \"157.56.13.114/32\",\r\n \"168.62.224.13/32\",\r\n \ + \ \"168.62.225.23/32\",\r\n \"191.236.148.9/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.NorthEurope\"\ + ,\r\n \"id\": \"AppService.NorthEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.69.186.152/32\",\r\n \ + \ \"13.69.228.0/25\",\r\n \"13.69.253.145/32\",\r\n \ + \ \"13.74.41.233/32\",\r\n \"13.74.147.218/32\",\r\n \"\ + 13.74.158.5/32\",\r\n \"13.74.252.44/32\",\r\n \"13.79.2.71/32\"\ + ,\r\n \"13.79.38.229/32\",\r\n \"13.79.172.40/32\",\r\n\ + \ \"20.50.64.0/25\",\r\n \"23.100.48.106/32\",\r\n \ + \ \"23.100.50.51/32\",\r\n \"23.100.52.22/32\",\r\n \ + \ \"23.100.56.27/32\",\r\n \"23.101.54.230/32\",\r\n \"\ + 23.101.63.214/32\",\r\n \"23.102.12.43/32\",\r\n \"23.102.21.198/32\"\ + ,\r\n \"23.102.21.212/32\",\r\n \"23.102.25.149/32\",\r\n\ + \ \"23.102.28.178/32\",\r\n \"40.69.43.225/32\",\r\n \ + \ \"40.69.88.149/32\",\r\n \"40.69.200.124/32\",\r\n \ + \ \"40.69.210.172/32\",\r\n \"40.69.218.150/32\",\r\n \ + \ \"40.85.74.227/32\",\r\n \"40.85.92.115/32\",\r\n \"\ + 40.85.96.208/32\",\r\n \"40.112.69.156/32\",\r\n \"40.112.90.244/32\"\ + ,\r\n \"40.112.93.201/32\",\r\n \"40.113.2.52/32\",\r\n\ + \ \"40.113.65.9/32\",\r\n \"40.113.71.148/32\",\r\n \ + \ \"40.113.81.82/32\",\r\n \"40.113.90.202/32\",\r\n \ + \ \"40.115.98.85/32\",\r\n \"40.127.132.204/32\",\r\n \ + \ \"40.127.139.252/32\",\r\n \"40.127.192.244/32\",\r\n \ + \ \"40.127.196.56/32\",\r\n \"52.138.196.70/32\",\r\n \"\ + 52.138.218.121/32\",\r\n \"52.164.201.186/32\",\r\n \"52.164.250.133/32\"\ + ,\r\n \"52.169.73.236/32\",\r\n \"52.169.78.163/32\",\r\n\ + \ \"52.169.180.223/32\",\r\n \"52.169.184.163/32\",\r\n\ + \ \"52.169.188.236/32\",\r\n \"52.169.191.40/32\",\r\n \ + \ \"52.178.158.175/32\",\r\n \"52.178.164.235/32\",\r\n \ + \ \"52.178.179.169/32\",\r\n \"52.178.190.191/32\",\r\n \ + \ \"52.178.201.147/32\",\r\n \"52.178.208.12/32\",\r\n \ + \ \"52.178.212.17/32\",\r\n \"52.178.214.89/32\",\r\n \ + \ \"94.245.104.73/32\",\r\n \"104.41.216.137/32\",\r\n \ + \ \"104.41.229.199/32\",\r\n \"104.45.81.79/32\",\r\n \ + \ \"104.45.95.61/32\",\r\n \"137.135.129.175/32\",\r\n \ + \ \"137.135.133.221/32\",\r\n \"168.63.53.239/32\",\r\n \ + \ \"191.235.160.13/32\",\r\n \"191.235.176.12/32\",\r\n \ + \ \"191.235.177.30/32\",\r\n \"191.235.208.12/32\",\r\n \ + \ \"191.235.215.184/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.NorwayEast\",\r\n \"id\": \"AppService.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.42.0/27\",\r\n \ + \ \"51.120.98.192/27\",\r\n \"51.120.106.160/27\",\r\n \ + \ \"51.120.210.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.NorwayWest\",\r\n \"id\": \"AppService.NorwayWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.218.192/27\",\r\n\ + \ \"51.120.226.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.SouthAfricaNorth\",\r\n \"id\": \"AppService.SouthAfricaNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"102.133.122.160/27\"\ + ,\r\n \"102.133.154.32/27\",\r\n \"102.133.218.32/28\",\r\ + \n \"102.133.250.160/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppService.SouthAfricaWest\",\r\n \"id\":\ + \ \"AppService.SouthAfricaWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n\ + \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.133.26.32/27\",\r\n \"\ + 102.133.57.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AppService.SouthCentralUS\",\r\n \"id\": \"AppService.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.65.30.245/32\"\ + ,\r\n \"13.65.37.122/32\",\r\n \"13.65.39.165/32\",\r\n\ + \ \"13.65.42.35/32\",\r\n \"13.65.42.183/32\",\r\n \ + \ \"13.65.45.30/32\",\r\n \"13.65.85.146/32\",\r\n \"\ + 13.65.89.91/32\",\r\n \"13.65.92.72/32\",\r\n \"13.65.94.204/32\"\ + ,\r\n \"13.65.95.109/32\",\r\n \"13.65.97.243/32\",\r\n\ + \ \"13.65.193.29/32\",\r\n \"13.65.210.166/32\",\r\n \ + \ \"13.65.212.252/32\",\r\n \"13.65.241.130/32\",\r\n \ + \ \"13.65.243.110/32\",\r\n \"13.66.16.101/32\",\r\n \ + \ \"13.66.38.99/32\",\r\n \"13.66.39.88/32\",\r\n \"13.84.36.2/32\"\ + ,\r\n \"13.84.40.227/32\",\r\n \"13.84.42.35/32\",\r\n \ + \ \"13.84.46.29/32\",\r\n \"13.84.55.137/32\",\r\n \ + \ \"13.84.146.60/32\",\r\n \"13.84.180.32/32\",\r\n \"\ + 13.84.181.47/32\",\r\n \"13.84.188.162/32\",\r\n \"13.84.189.137/32\"\ + ,\r\n \"13.84.227.164/32\",\r\n \"13.85.15.194/32\",\r\n\ + \ \"13.85.16.224/32\",\r\n \"13.85.20.144/32\",\r\n \ + \ \"13.85.24.220/32\",\r\n \"13.85.27.14/32\",\r\n \ + \ \"13.85.31.243/32\",\r\n \"13.85.72.129/32\",\r\n \"13.85.77.179/32\"\ + ,\r\n \"13.85.82.0/32\",\r\n \"20.45.122.160/27\",\r\n \ + \ \"20.49.90.32/27\",\r\n \"23.101.180.75/32\",\r\n \ + \ \"23.102.154.38/32\",\r\n \"23.102.161.217/32\",\r\n \ + \ \"23.102.191.170/32\",\r\n \"40.74.245.188/32\",\r\n \ + \ \"40.74.253.108/32\",\r\n \"40.74.255.112/32\",\r\n \ + \ \"40.84.148.247/32\",\r\n \"40.84.159.58/32\",\r\n \"\ + 40.84.194.106/32\",\r\n \"40.84.226.176/32\",\r\n \"40.84.227.180/32\"\ + ,\r\n \"40.84.232.28/32\",\r\n \"40.119.12.0/23\",\r\n \ + \ \"40.124.12.75/32\",\r\n \"40.124.13.58/32\",\r\n \ + \ \"52.171.56.101/32\",\r\n \"52.171.56.110/32\",\r\n \ + \ \"52.171.136.200/32\",\r\n \"52.171.140.237/32\",\r\n \ + \ \"52.171.218.239/32\",\r\n \"52.171.221.170/32\",\r\n \ + \ \"52.171.222.247/32\",\r\n \"104.44.128.13/32\",\r\n \ + \ \"104.44.130.38/32\",\r\n \"104.210.145.181/32\",\r\n \ + \ \"104.210.147.57/32\",\r\n \"104.210.152.76/32\",\r\n \ + \ \"104.210.152.122/32\",\r\n \"104.210.153.116/32\",\r\n \ + \ \"104.210.158.20/32\",\r\n \"104.214.20.0/23\",\r\n \ + \ \"104.214.29.203/32\",\r\n \"104.214.64.238/32\",\r\n \ + \ \"104.214.74.110/32\",\r\n \"104.214.77.221/32\",\r\n \ + \ \"104.214.110.60/32\",\r\n \"104.214.110.226/32\",\r\n \ + \ \"104.214.118.174/32\",\r\n \"104.214.119.36/32\",\r\n \ + \ \"104.215.73.236/32\",\r\n \"104.215.78.13/32\",\r\n \ + \ \"104.215.89.22/32\",\r\n \"191.238.176.139/32\",\r\n \ + \ \"191.238.240.12/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppService.SoutheastAsia\",\r\n \"id\": \"AppService.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.67.9.0/25\"\ + ,\r\n \"13.67.56.225/32\",\r\n \"13.67.63.90/32\",\r\n \ + \ \"13.76.44.139/32\",\r\n \"13.76.245.96/32\",\r\n \ + \ \"20.43.132.128/25\",\r\n \"20.188.98.74/32\",\r\n \ + \ \"23.97.56.169/32\",\r\n \"23.98.64.36/32\",\r\n \"23.98.64.158/32\"\ + ,\r\n \"23.101.27.182/32\",\r\n \"52.163.122.160/32\",\r\ + \n \"52.187.17.126/32\",\r\n \"52.187.36.104/32\",\r\n \ + \ \"52.187.52.94/32\",\r\n \"52.187.135.79/32\",\r\n \ + \ \"52.230.1.186/32\",\r\n \"104.215.147.45/32\",\r\n \ + \ \"104.215.155.1/32\",\r\n \"111.221.95.27/32\",\r\n \ + \ \"137.116.128.188/32\",\r\n \"137.116.153.238/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.SouthIndia\"\ + ,\r\n \"id\": \"AppService.SouthIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.71.122.35/32\",\r\n \ + \ \"13.71.123.138/32\",\r\n \"20.41.195.192/27\",\r\n \"\ + 40.78.194.96/27\",\r\n \"52.172.54.225/32\",\r\n \"104.211.224.252/32\"\ + ,\r\n \"104.211.225.167/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppService.SwitzerlandNorth\",\r\n \"id\"\ + : \"AppService.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.50.0/27\",\r\n \"51.107.58.160/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.SwitzerlandWest\"\ + ,\r\n \"id\": \"AppService.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.107.146.0/27\",\r\n \ + \ \"51.107.154.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AppService.UAECentral\",\r\n \"id\": \"AppService.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.37.66.0/27\"\ + ,\r\n \"20.37.74.96/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppService.UAENorth\",\r\n \"id\": \"AppService.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"20.38.138.0/27\"\ + ,\r\n \"40.120.74.32/27\",\r\n \"65.52.250.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.UKSouth\"\ + ,\r\n \"id\": \"AppService.UKSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.104.28.64/26\",\r\n \ + \ \"51.105.66.160/27\",\r\n \"51.105.74.160/27\",\r\n \"\ + 51.140.37.241/32\",\r\n \"51.140.57.176/32\",\r\n \"51.140.59.233/32\"\ + ,\r\n \"51.140.75.147/32\",\r\n \"51.140.84.145/32\",\r\n\ + \ \"51.140.85.106/32\",\r\n \"51.140.87.39/32\",\r\n \ + \ \"51.140.122.226/32\",\r\n \"51.140.146.128/26\",\r\n \ + \ \"51.140.152.154/32\",\r\n \"51.140.153.150/32\",\r\n \ + \ \"51.140.180.76/32\",\r\n \"51.140.185.151/32\",\r\n \ + \ \"51.140.191.223/32\",\r\n \"51.143.191.44/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.UKWest\"\ + ,\r\n \"id\": \"AppService.UKWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n\ + \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.137.163.32/27\",\r\n \"\ + 51.140.210.96/27\",\r\n \"51.140.244.162/32\",\r\n \"51.140.245.89/32\"\ + ,\r\n \"51.141.12.112/32\",\r\n \"51.141.37.245/32\",\r\n\ + \ \"51.141.44.139/32\",\r\n \"51.141.45.207/32\",\r\n \ + \ \"51.141.90.252/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppService.WestCentralUS\",\r\n \"id\": \"AppService.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppService\",\r\n \"addressPrefixes\": [\r\n \"13.71.194.192/27\"\ + ,\r\n \"13.78.150.96/32\",\r\n \"13.78.184.89/32\",\r\n\ + \ \"52.150.140.224/27\",\r\n \"52.161.96.193/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.WestEurope\"\ + ,\r\n \"id\": \"AppService.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.69.68.0/23\",\r\n \"\ + 13.80.19.74/32\",\r\n \"13.81.7.21/32\",\r\n \"13.81.108.99/32\"\ + ,\r\n \"13.81.215.235/32\",\r\n \"13.94.143.57/32\",\r\n\ + \ \"13.94.192.98/32\",\r\n \"13.94.211.38/32\",\r\n \ + \ \"13.95.82.181/32\",\r\n \"13.95.93.152/32\",\r\n \ + \ \"13.95.150.128/32\",\r\n \"13.95.238.192/32\",\r\n \"\ + 20.50.2.0/23\",\r\n \"23.97.160.56/32\",\r\n \"23.97.160.74/32\"\ + ,\r\n \"23.97.162.202/32\",\r\n \"23.97.195.129/32\",\r\n\ + \ \"23.97.208.18/32\",\r\n \"23.97.214.177/32\",\r\n \ + \ \"23.97.216.47/32\",\r\n \"23.97.224.11/32\",\r\n \ + \ \"23.100.1.29/32\",\r\n \"23.101.67.245/32\",\r\n \"\ + 40.68.40.55/32\",\r\n \"40.68.205.178/32\",\r\n \"40.68.208.131/32\"\ + ,\r\n \"40.68.210.104/32\",\r\n \"40.68.214.185/32\",\r\n\ + \ \"40.113.126.251/32\",\r\n \"40.113.131.37/32\",\r\n \ + \ \"40.113.136.240/32\",\r\n \"40.113.142.219/32\",\r\n \ + \ \"40.114.194.188/32\",\r\n \"40.114.210.78/32\",\r\n \ + \ \"40.114.228.161/32\",\r\n \"40.114.237.65/32\",\r\n \ + \ \"40.114.243.70/32\",\r\n \"40.115.55.251/32\",\r\n \ + \ \"40.118.29.72/32\",\r\n \"40.118.71.240/32\",\r\n \ + \ \"40.118.96.231/32\",\r\n \"40.118.100.127/32\",\r\n \ + \ \"40.118.101.67/32\",\r\n \"40.118.102.46/32\",\r\n \"\ + 51.105.172.25/32\",\r\n \"51.136.14.31/32\",\r\n \"51.137.106.13/32\"\ + ,\r\n \"51.144.7.192/32\",\r\n \"51.144.107.53/32\",\r\n\ + \ \"51.144.116.43/32\",\r\n \"51.144.164.215/32\",\r\n \ + \ \"51.144.182.8/32\",\r\n \"52.166.78.97/32\",\r\n \ + \ \"52.166.113.188/32\",\r\n \"52.166.119.99/32\",\r\n \ + \ \"52.166.178.208/32\",\r\n \"52.166.181.85/32\",\r\n \ + \ \"52.166.198.163/32\",\r\n \"52.174.3.80/32\",\r\n \"\ + 52.174.7.133/32\",\r\n \"52.174.35.5/32\",\r\n \"52.174.106.15/32\"\ + ,\r\n \"52.174.150.25/32\",\r\n \"52.174.181.178/32\",\r\ + \n \"52.174.184.18/32\",\r\n \"52.174.193.210/32\",\r\n\ + \ \"52.174.235.29/32\",\r\n \"52.178.29.39/32\",\r\n \ + \ \"52.178.37.244/32\",\r\n \"52.178.43.209/32\",\r\n \ + \ \"52.178.45.139/32\",\r\n \"52.178.46.181/32\",\r\n \ + \ \"52.178.75.200/32\",\r\n \"52.178.79.163/32\",\r\n \ + \ \"52.178.89.129/32\",\r\n \"52.178.90.230/32\",\r\n \"\ + 52.178.92.96/32\",\r\n \"52.178.105.179/32\",\r\n \"52.178.114.226/32\"\ + ,\r\n \"52.232.19.237/32\",\r\n \"52.232.26.228/32\",\r\n\ + \ \"52.232.33.202/32\",\r\n \"52.232.56.79/32\",\r\n \ + \ \"52.232.127.196/32\",\r\n \"52.233.128.61/32\",\r\n \ + \ \"52.233.133.18/32\",\r\n \"52.233.133.121/32\",\r\n \ + \ \"52.233.155.168/32\",\r\n \"52.233.164.195/32\",\r\n \ + \ \"52.233.175.59/32\",\r\n \"52.233.184.181/32\",\r\n \ + \ \"52.233.198.206/32\",\r\n \"65.52.128.33/32\",\r\n \ + \ \"65.52.130.1/32\",\r\n \"104.40.129.89/32\",\r\n \"\ + 104.40.147.180/32\",\r\n \"104.40.147.216/32\",\r\n \"104.40.158.55/32\"\ + ,\r\n \"104.40.179.243/32\",\r\n \"104.40.183.236/32\",\r\ + \n \"104.40.185.192/32\",\r\n \"104.40.187.26/32\",\r\n\ + \ \"104.40.191.174/32\",\r\n \"104.40.210.25/32\",\r\n \ + \ \"104.40.215.219/32\",\r\n \"104.40.222.81/32\",\r\n \ + \ \"104.40.250.100/32\",\r\n \"104.45.1.117/32\",\r\n \ + \ \"104.45.14.249/32\",\r\n \"104.46.38.245/32\",\r\n \ + \ \"104.46.44.78/32\",\r\n \"104.46.61.116/32\",\r\n \ + \ \"104.47.137.62/32\",\r\n \"104.47.151.115/32\",\r\n \"\ + 104.47.160.14/32\",\r\n \"104.47.164.119/32\",\r\n \"104.214.231.110/32\"\ + ,\r\n \"104.214.236.47/32\",\r\n \"104.214.237.135/32\"\ + ,\r\n \"137.117.166.35/32\",\r\n \"137.117.175.14/32\",\r\ + \n \"137.117.203.130/32\",\r\n \"137.117.211.244/32\",\r\ + \n \"137.117.218.101/32\",\r\n \"137.117.224.218/32\",\r\ + \n \"137.117.225.87/32\",\r\n \"168.63.5.231/32\",\r\n \ + \ \"168.63.107.5/32\",\r\n \"191.233.82.44/32\",\r\n \ + \ \"191.233.85.165/32\",\r\n \"191.233.87.194/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppService.WestIndia\"\ + ,\r\n \"id\": \"AppService.WestIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\ + \r\n ],\r\n \"systemService\": \"AzureAppService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.136.50.0/27\",\r\n \ + \ \"104.211.146.96/27\",\r\n \"104.211.160.159/32\",\r\n \ + \ \"104.211.179.11/32\",\r\n \"104.211.184.197/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AppService.WestUS\",\r\n\ + \ \"id\": \"AppService.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppService\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.64.73.110/32\",\r\n \"13.91.40.166/32\",\r\n\ + \ \"13.91.242.166/32\",\r\n \"13.93.141.10/32\",\r\n \ + \ \"13.93.158.16/32\",\r\n \"13.93.220.109/32\",\r\n \ + \ \"13.93.231.75/32\",\r\n \"23.99.0.12/32\",\r\n \"\ + 23.99.65.65/32\",\r\n \"23.99.91.55/32\",\r\n \"23.100.46.198/32\"\ + ,\r\n \"23.101.203.117/32\",\r\n \"23.101.203.214/32\",\r\ + \n \"23.101.207.250/32\",\r\n \"40.78.18.232/32\",\r\n \ + \ \"40.78.25.157/32\",\r\n \"40.78.48.219/32\",\r\n \ + \ \"40.80.155.102/32\",\r\n \"40.80.156.205/32\",\r\n \ + \ \"40.82.255.128/25\",\r\n \"40.83.145.50/32\",\r\n \"\ + 40.83.150.233/32\",\r\n \"40.83.182.206/32\",\r\n \"40.83.183.236/32\"\ + ,\r\n \"40.83.184.25/32\",\r\n \"40.112.142.148/32\",\r\n\ + \ \"40.112.143.134/32\",\r\n \"40.112.143.140/32\",\r\n\ + \ \"40.112.143.214/32\",\r\n \"40.112.165.44/32\",\r\n \ + \ \"40.112.166.161/32\",\r\n \"40.112.191.159/32\",\r\n \ + \ \"40.112.192.69/32\",\r\n \"40.112.216.189/32\",\r\n \ + \ \"40.112.243.0/25\",\r\n \"40.118.185.161/32\",\r\n \ + \ \"40.118.235.113/32\",\r\n \"40.118.246.51/32\",\r\n \ + \ \"40.118.255.59/32\",\r\n \"52.160.40.218/32\",\r\n \ + \ \"104.40.3.53/32\",\r\n \"104.40.11.192/32\",\r\n \"\ + 104.40.28.133/32\",\r\n \"104.40.53.219/32\",\r\n \"104.40.63.98/32\"\ + ,\r\n \"104.40.84.133/32\",\r\n \"104.40.92.107/32\",\r\n\ + \ \"104.42.53.248/32\",\r\n \"104.42.78.153/32\",\r\n \ + \ \"104.42.128.171/32\",\r\n \"104.42.148.55/32\",\r\n \ + \ \"104.42.152.64/32\",\r\n \"104.42.154.105/32\",\r\n \ + \ \"104.42.188.146/32\",\r\n \"104.42.231.5/32\",\r\n \ + \ \"104.45.226.98/32\",\r\n \"104.45.231.79/32\",\r\n \ + \ \"104.210.38.149/32\",\r\n \"137.117.9.212/32\",\r\n \ + \ \"137.117.17.70/32\",\r\n \"138.91.224.84/32\",\r\n \"\ + 138.91.225.40/32\",\r\n \"138.91.240.81/32\",\r\n \"168.62.20.37/32\"\ + ,\r\n \"191.236.80.12/32\",\r\n \"191.236.106.123/32\",\r\ + \n \"191.239.58.162/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppService.WestUS2\",\r\n \"id\": \"AppService.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.138.96/27\",\r\n\ + \ \"13.66.209.135/32\",\r\n \"13.66.212.205/32\",\r\n \ + \ \"13.66.226.80/32\",\r\n \"13.66.231.217/32\",\r\n \ + \ \"13.66.241.134/32\",\r\n \"13.66.244.249/32\",\r\n \ + \ \"13.77.157.133/32\",\r\n \"13.77.160.237/32\",\r\n \ + \ \"13.77.182.13/32\",\r\n \"20.42.128.96/27\",\r\n \"40.64.128.224/27\"\ + ,\r\n \"51.143.102.21/32\",\r\n \"52.151.62.51/32\",\r\n\ + \ \"52.175.202.25/32\",\r\n \"52.175.254.10/32\",\r\n \ + \ \"52.183.82.125/32\",\r\n \"52.229.30.210/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement\"\ + ,\r\n \"id\": \"AppServiceManagement\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.64.115.203/32\",\r\n \"13.66.140.0/26\",\r\n \ + \ \"13.67.8.128/26\",\r\n \"13.69.64.128/26\",\r\n \"\ + 13.69.227.128/26\",\r\n \"13.70.72.64/26\",\r\n \"13.70.73.128/26\"\ + ,\r\n \"13.71.170.64/26\",\r\n \"13.71.173.0/26\",\r\n \ + \ \"13.71.173.128/26\",\r\n \"13.71.194.128/26\",\r\n \ + \ \"13.73.240.128/26\",\r\n \"13.73.242.64/26\",\r\n \ + \ \"13.75.34.192/26\",\r\n \"13.75.127.117/32\",\r\n \ + \ \"13.77.50.128/26\",\r\n \"13.78.106.128/26\",\r\n \"\ + 13.78.109.0/26\",\r\n \"13.87.56.128/26\",\r\n \"13.87.122.128/26\"\ + ,\r\n \"13.89.171.0/26\",\r\n \"13.94.141.115/32\",\r\n\ + \ \"13.94.143.126/32\",\r\n \"13.94.149.179/32\",\r\n \ + \ \"20.36.106.128/26\",\r\n \"20.36.114.64/26\",\r\n \ + \ \"20.37.74.128/26\",\r\n \"20.43.120.128/26\",\r\n \ + \ \"20.44.2.192/26\",\r\n \"20.44.27.0/26\",\r\n \"20.45.125.128/26\"\ + ,\r\n \"20.49.82.128/26\",\r\n \"20.49.90.128/26\",\r\n\ + \ \"20.150.171.0/26\",\r\n \"20.150.179.0/26\",\r\n \ + \ \"20.150.187.0/26\",\r\n \"20.192.99.0/26\",\r\n \ + \ \"20.192.234.192/26\",\r\n \"20.193.202.192/26\",\r\n \ + \ \"20.194.66.128/26\",\r\n \"23.96.195.3/32\",\r\n \"23.100.226.236/32\"\ + ,\r\n \"23.102.188.65/32\",\r\n \"40.67.59.0/26\",\r\n \ + \ \"40.69.106.128/26\",\r\n \"40.70.146.128/26\",\r\n \ + \ \"40.71.11.0/26\",\r\n \"40.71.13.64/26\",\r\n \"\ + 40.74.100.64/26\",\r\n \"40.78.194.128/26\",\r\n \"40.79.130.64/26\"\ + ,\r\n \"40.79.165.0/26\",\r\n \"40.79.178.128/26\",\r\n\ + \ \"40.83.120.64/32\",\r\n \"40.83.121.56/32\",\r\n \ + \ \"40.83.125.161/32\",\r\n \"40.90.240.166/32\",\r\n \ + \ \"40.91.126.196/32\",\r\n \"40.112.242.192/26\",\r\n \ + \ \"40.119.4.111/32\",\r\n \"40.120.74.128/26\",\r\n \"\ + 40.124.47.188/32\",\r\n \"51.12.99.0/26\",\r\n \"51.12.203.0/26\"\ + ,\r\n \"51.12.227.0/26\",\r\n \"51.12.235.0/26\",\r\n \ + \ \"51.104.8.0/26\",\r\n \"51.104.8.128/26\",\r\n \ + \ \"51.107.58.192/26\",\r\n \"51.107.154.192/26\",\r\n \ + \ \"51.116.58.192/26\",\r\n \"51.116.155.0/26\",\r\n \"\ + 51.116.156.64/26\",\r\n \"51.116.243.64/26\",\r\n \"51.116.251.192/26\"\ + ,\r\n \"51.120.99.0/26\",\r\n \"51.120.107.0/26\",\r\n \ + \ \"51.120.211.0/26\",\r\n \"51.120.219.0/26\",\r\n \ + \ \"51.140.146.64/26\",\r\n \"51.140.210.128/26\",\r\n \ + \ \"52.151.25.45/32\",\r\n \"52.162.80.89/32\",\r\n \"\ + 52.162.106.192/26\",\r\n \"52.165.152.214/32\",\r\n \"52.165.153.122/32\"\ + ,\r\n \"52.165.154.193/32\",\r\n \"52.165.158.140/32\",\r\ + \n \"52.174.22.21/32\",\r\n \"52.178.177.147/32\",\r\n \ + \ \"52.178.184.149/32\",\r\n \"52.178.190.65/32\",\r\n \ + \ \"52.178.195.197/32\",\r\n \"52.187.56.50/32\",\r\n \ + \ \"52.187.59.251/32\",\r\n \"52.187.63.19/32\",\r\n \ + \ \"52.187.63.37/32\",\r\n \"52.224.105.172/32\",\r\n \ + \ \"52.225.177.15/32\",\r\n \"52.225.177.153/32\",\r\n \"\ + 52.231.18.64/26\",\r\n \"52.231.146.128/26\",\r\n \"52.246.157.64/26\"\ + ,\r\n \"65.52.14.230/32\",\r\n \"65.52.172.237/32\",\r\n\ + \ \"65.52.193.203/32\",\r\n \"65.52.250.128/26\",\r\n \ + \ \"70.37.57.58/32\",\r\n \"70.37.89.222/32\",\r\n \ + \ \"102.133.26.192/26\",\r\n \"102.133.123.0/26\",\r\n \ + \ \"102.133.123.128/26\",\r\n \"102.133.154.192/26\",\r\n \ + \ \"104.43.242.137/32\",\r\n \"104.44.129.141/32\",\r\n \ + \ \"104.44.129.243/32\",\r\n \"104.44.129.255/32\",\r\n \ + \ \"104.44.134.255/32\",\r\n \"104.208.54.11/32\",\r\n \ + \ \"104.211.81.64/26\",\r\n \"104.211.146.128/26\",\r\n \ + \ \"104.214.18.192/26\",\r\n \"104.214.49.0/32\",\r\n \ + \ \"157.55.176.93/32\",\r\n \"157.55.208.185/32\",\r\n \"\ + 191.233.50.128/26\",\r\n \"191.233.203.64/26\",\r\n \"191.234.147.0/26\"\ + ,\r\n \"191.234.155.0/26\",\r\n \"191.236.154.88/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaCentral\"\ + ,\r\n \"id\": \"AppServiceManagement.AustraliaCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.36.106.128/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaCentral2\"\ + ,\r\n \"id\": \"AppServiceManagement.AustraliaCentral2\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.36.114.64/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.AustraliaEast\"\ + ,\r\n \"id\": \"AppServiceManagement.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.70.72.64/26\",\r\n \"13.70.73.128/26\",\r\n\ + \ \"40.79.165.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.AustraliaSoutheast\",\r\n \"\ + id\": \"AppServiceManagement.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.50.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.BrazilSouth\",\r\n \"\ + id\": \"AppServiceManagement.BrazilSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"191.233.203.64/26\",\r\n \"191.234.147.0/26\"\ + ,\r\n \"191.234.155.0/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.CanadaCentral\",\r\n \ + \ \"id\": \"AppServiceManagement.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.170.64/26\",\r\n \"13.71.173.0/26\",\r\n\ + \ \"13.71.173.128/26\",\r\n \"52.246.157.64/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CanadaEast\"\ + ,\r\n \"id\": \"AppServiceManagement.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.69.106.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.CentralIndia\",\r\n \ + \ \"id\": \"AppServiceManagement.CentralIndia\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.43.120.128/26\",\r\n \"20.192.99.0/26\",\r\n\ + \ \"104.211.81.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.CentralUS\",\r\n \"id\": \"\ + AppServiceManagement.CentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.89.171.0/26\",\r\n \"52.165.152.214/32\",\r\n \ + \ \"52.165.153.122/32\",\r\n \"52.165.154.193/32\",\r\n \ + \ \"52.165.158.140/32\",\r\n \"104.43.242.137/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.CentralUSEUAP\"\ + ,\r\n \"id\": \"AppServiceManagement.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"104.208.54.11/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.EastAsia\",\r\n \"id\"\ + : \"AppServiceManagement.EastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.75.34.192/26\",\r\n \"13.75.127.117/32\",\r\n \ + \ \"40.83.120.64/32\",\r\n \"40.83.121.56/32\",\r\n \"\ + 40.83.125.161/32\",\r\n \"65.52.172.237/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastUS\"\ + ,\r\n \"id\": \"AppServiceManagement.EastUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.71.11.0/26\",\r\n \"40.71.13.64/26\",\r\n \ + \ \"40.90.240.166/32\",\r\n \"52.224.105.172/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.EastUS2\"\ + ,\r\n \"id\": \"AppServiceManagement.EastUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.70.146.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.EastUS2EUAP\",\r\n \"\ + id\": \"AppServiceManagement.EastUS2EUAP\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.225.177.15/32\",\r\n \"52.225.177.153/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.FranceCentral\"\ + ,\r\n \"id\": \"AppServiceManagement.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.79.130.64/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.FranceSouth\",\r\n \"\ + id\": \"AppServiceManagement.FranceSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.79.178.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.GermanyNorth\",\r\n \ + \ \"id\": \"AppServiceManagement.GermanyNorth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.58.192/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.GermanyWestCentral\",\r\n\ + \ \"id\": \"AppServiceManagement.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.155.0/26\",\r\n \"51.116.156.64/26\",\r\ + \n \"51.116.243.64/26\",\r\n \"51.116.251.192/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.JapanEast\"\ + ,\r\n \"id\": \"AppServiceManagement.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.78.106.128/26\",\r\n \"13.78.109.0/26\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.JapanWest\"\ + ,\r\n \"id\": \"AppServiceManagement.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.100.64/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.KoreaCentral\",\r\n \ + \ \"id\": \"AppServiceManagement.KoreaCentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.44.27.0/26\",\r\n \"20.194.66.128/26\",\r\n\ + \ \"52.231.18.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.KoreaSouth\",\r\n \"id\": \"\ + AppServiceManagement.KoreaSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.231.146.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.NorthCentralUS\",\r\n \"id\"\ + : \"AppServiceManagement.NorthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"23.96.195.3/32\",\r\n \"23.100.226.236/32\",\r\ + \n \"52.162.80.89/32\",\r\n \"52.162.106.192/26\",\r\n \ + \ \"65.52.14.230/32\",\r\n \"65.52.193.203/32\",\r\n \ + \ \"157.55.208.185/32\",\r\n \"191.236.154.88/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.NorthEurope\"\ + ,\r\n \"id\": \"AppServiceManagement.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.227.128/26\",\r\n \"52.178.177.147/32\"\ + ,\r\n \"52.178.184.149/32\",\r\n \"52.178.190.65/32\",\r\ + \n \"52.178.195.197/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AppServiceManagement.NorwayEast\",\r\n \"id\"\ + : \"AppServiceManagement.NorwayEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.120.99.0/26\",\r\n \"51.120.107.0/26\",\r\n\ + \ \"51.120.211.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.NorwayWest\",\r\n \"id\": \"\ + AppServiceManagement.NorwayWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.219.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AppServiceManagement.SouthAfricaNorth\",\r\n \"id\"\ + : \"AppServiceManagement.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.123.0/26\",\r\n \"102.133.123.128/26\"\ + ,\r\n \"102.133.154.192/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.SouthAfricaWest\",\r\n \ + \ \"id\": \"AppServiceManagement.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.26.192/26\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AppServiceManagement.SouthCentralUS\",\r\n \ + \ \"id\": \"AppServiceManagement.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.73.240.128/26\",\r\n \"13.73.242.64/26\",\r\ + \n \"20.45.125.128/26\",\r\n \"20.49.90.128/26\",\r\n \ + \ \"23.102.188.65/32\",\r\n \"40.119.4.111/32\",\r\n \ + \ \"40.124.47.188/32\",\r\n \"70.37.57.58/32\",\r\n \ + \ \"70.37.89.222/32\",\r\n \"104.44.129.141/32\",\r\n \"\ + 104.44.129.243/32\",\r\n \"104.44.129.255/32\",\r\n \"104.44.134.255/32\"\ + ,\r\n \"104.214.18.192/26\",\r\n \"104.214.49.0/32\",\r\n\ + \ \"157.55.176.93/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.SoutheastAsia\",\r\n \"id\"\ + : \"AppServiceManagement.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.67.8.128/26\",\r\n \"52.187.56.50/32\",\r\n\ + \ \"52.187.59.251/32\",\r\n \"52.187.63.19/32\",\r\n \ + \ \"52.187.63.37/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AppServiceManagement.SouthIndia\",\r\n \"id\": \"\ + AppServiceManagement.SouthIndia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.78.194.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AppServiceManagement.SwitzerlandNorth\",\r\n \"id\"\ + : \"AppServiceManagement.SwitzerlandNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.58.192/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.SwitzerlandWest\",\r\n \ + \ \"id\": \"AppServiceManagement.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.154.192/26\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AppServiceManagement.UAECentral\",\r\n \"\ + id\": \"AppServiceManagement.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.74.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.UAENorth\",\r\n \"id\"\ + : \"AppServiceManagement.UAENorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.120.74.128/26\",\r\n \"65.52.250.128/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.UKNorth\"\ + ,\r\n \"id\": \"AppServiceManagement.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.87.122.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.UKSouth\",\r\n \"id\"\ + : \"AppServiceManagement.UKSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.104.8.0/26\",\r\n \"51.104.8.128/26\",\r\n \ + \ \"51.140.146.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AppServiceManagement.UKSouth2\",\r\n \"id\": \"AppServiceManagement.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAppServiceManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.56.128/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AppServiceManagement.UKWest\"\ + ,\r\n \"id\": \"AppServiceManagement.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.140.210.128/26\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AppServiceManagement.WestCentralUS\",\r\n \ + \ \"id\": \"AppServiceManagement.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.194.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AppServiceManagement.WestEurope\",\r\n \"\ + id\": \"AppServiceManagement.WestEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"AzureAppServiceManagement\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.64.128/26\",\r\n \"13.94.141.115/32\",\r\ + \n \"13.94.143.126/32\",\r\n \"13.94.149.179/32\",\r\n \ + \ \"52.174.22.21/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.WestIndia\",\r\n \"id\": \"\ + AppServiceManagement.WestIndia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureAppServiceManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"104.211.146.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.WestUS\",\r\n \"id\": \"AppServiceManagement.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.64.115.203/32\",\r\n \ + \ \"40.112.242.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AppServiceManagement.WestUS2\",\r\n \"id\": \"AppServiceManagement.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAppServiceManagement\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.66.140.0/26\",\r\n \ + \ \"40.91.126.196/32\",\r\n \"52.151.25.45/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureActiveDirectory\",\r\ + \n \"id\": \"AzureActiveDirectory\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAD\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.64.151.161/32\",\r\n \"13.66.141.64/27\",\r\ + \n \"13.67.9.224/27\",\r\n \"13.69.66.160/27\",\r\n \ + \ \"13.69.229.96/27\",\r\n \"13.70.73.32/27\",\r\n \ + \ \"13.71.172.160/27\",\r\n \"13.71.195.224/27\",\r\n \"\ + 13.71.201.64/26\",\r\n \"13.73.240.32/27\",\r\n \"13.74.104.0/26\"\ + ,\r\n \"13.74.249.156/32\",\r\n \"13.75.38.32/27\",\r\n\ + \ \"13.75.105.168/32\",\r\n \"13.77.52.160/27\",\r\n \ + \ \"13.78.108.192/27\",\r\n \"13.78.172.246/32\",\r\n \ + \ \"13.79.37.247/32\",\r\n \"13.86.219.0/27\",\r\n \"\ + 13.87.16.0/26\",\r\n \"13.87.57.160/27\",\r\n \"13.87.123.160/27\"\ + ,\r\n \"13.89.174.0/27\",\r\n \"20.36.107.192/27\",\r\n\ + \ \"20.36.115.64/27\",\r\n \"20.37.75.96/27\",\r\n \ + \ \"20.43.120.32/27\",\r\n \"20.44.3.160/27\",\r\n \"\ + 20.44.16.32/27\",\r\n \"20.190.128.0/18\",\r\n \"23.101.0.70/32\"\ + ,\r\n \"23.101.6.190/32\",\r\n \"40.68.160.142/32\",\r\n\ + \ \"40.69.107.160/27\",\r\n \"40.71.13.0/27\",\r\n \ + \ \"40.74.101.64/27\",\r\n \"40.74.146.192/27\",\r\n \ + \ \"40.78.195.160/27\",\r\n \"40.78.203.64/27\",\r\n \"\ + 40.79.131.128/27\",\r\n \"40.79.179.128/27\",\r\n \"40.83.144.56/32\"\ + ,\r\n \"40.126.0.0/18\",\r\n \"51.140.148.192/27\",\r\n\ + \ \"51.140.208.0/26\",\r\n \"51.140.211.192/27\",\r\n \ + \ \"52.138.65.157/32\",\r\n \"52.138.68.41/32\",\r\n \ + \ \"52.161.13.71/32\",\r\n \"52.161.13.95/32\",\r\n \ + \ \"52.161.110.169/32\",\r\n \"52.162.110.96/27\",\r\n \"\ + 52.169.125.119/32\",\r\n \"52.169.218.0/32\",\r\n \"52.174.189.149/32\"\ + ,\r\n \"52.175.18.134/32\",\r\n \"52.178.27.112/32\",\r\n\ + \ \"52.179.122.218/32\",\r\n \"52.179.126.223/32\",\r\n\ + \ \"52.180.177.87/32\",\r\n \"52.180.179.108/32\",\r\n \ + \ \"52.180.181.61/32\",\r\n \"52.180.183.8/32\",\r\n \ + \ \"52.187.19.1/32\",\r\n \"52.187.113.48/32\",\r\n \ + \ \"52.187.117.83/32\",\r\n \"52.187.120.237/32\",\r\n \ + \ \"52.225.184.198/32\",\r\n \"52.225.188.89/32\",\r\n \"\ + 52.231.19.128/27\",\r\n \"52.231.147.192/27\",\r\n \"65.52.251.96/27\"\ + ,\r\n \"104.40.84.19/32\",\r\n \"104.40.87.209/32\",\r\n\ + \ \"104.40.156.18/32\",\r\n \"104.40.168.0/26\",\r\n \ + \ \"104.41.159.212/32\",\r\n \"104.45.138.161/32\",\r\n \ + \ \"104.211.147.160/27\",\r\n \"191.233.204.160/27\",\r\n \ + \ \"2603:1006:2000::/48\",\r\n \"2603:1007:200::/48\",\r\n\ + \ \"2603:1016:1400::/48\",\r\n \"2603:1017::/48\",\r\n \ + \ \"2603:1026:3000::/48\",\r\n \"2603:1027:1::/48\",\r\n\ + \ \"2603:1036:3000::/48\",\r\n \"2603:1037:1::/48\",\r\n\ + \ \"2603:1046:2000::/48\",\r\n \"2603:1047:1::/48\",\r\n\ + \ \"2603:1056:2000::/48\",\r\n \"2603:1057:2::/48\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureActiveDirectory.ServiceEndpoint\"\ + ,\r\n \"id\": \"AzureActiveDirectory.ServiceEndpoint\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIdentity\",\r\ + \n \"addressPrefixes\": [\r\n \"20.190.128.0/26\",\r\n \ + \ \"20.190.128.64/28\",\r\n \"20.190.128.128/27\",\r\n \ + \ \"20.190.128.160/29\",\r\n \"20.190.129.0/26\",\r\n \ + \ \"20.190.129.64/28\",\r\n \"20.190.129.128/27\",\r\n \ + \ \"20.190.129.160/29\",\r\n \"20.190.130.0/27\",\r\n \ + \ \"20.190.130.32/29\",\r\n \"20.190.131.0/27\",\r\n \"\ + 20.190.131.32/29\",\r\n \"20.190.131.64/27\",\r\n \"20.190.131.96/29\"\ + ,\r\n \"20.190.132.0/27\",\r\n \"20.190.132.32/29\",\r\n\ + \ \"20.190.132.64/27\",\r\n \"20.190.132.96/29\",\r\n \ + \ \"20.190.133.0/27\",\r\n \"20.190.133.32/29\",\r\n \ + \ \"20.190.133.64/27\",\r\n \"20.190.133.96/29\",\r\n \ + \ \"20.190.134.0/27\",\r\n \"20.190.134.32/29\",\r\n \"\ + 20.190.134.64/27\",\r\n \"20.190.134.96/29\",\r\n \"20.190.135.0/27\"\ + ,\r\n \"20.190.135.32/29\",\r\n \"20.190.135.64/27\",\r\n\ + \ \"20.190.135.96/29\",\r\n \"20.190.136.0/27\",\r\n \ + \ \"20.190.136.32/29\",\r\n \"20.190.137.0/27\",\r\n \ + \ \"20.190.137.32/29\",\r\n \"20.190.137.64/27\",\r\n \ + \ \"20.190.137.96/29\",\r\n \"20.190.138.0/27\",\r\n \"\ + 20.190.138.32/29\",\r\n \"20.190.138.64/27\",\r\n \"20.190.138.96/29\"\ + ,\r\n \"20.190.138.128/27\",\r\n \"20.190.138.160/29\",\r\ + \n \"20.190.139.0/27\",\r\n \"20.190.139.32/29\",\r\n \ + \ \"20.190.139.64/27\",\r\n \"20.190.139.96/29\",\r\n \ + \ \"20.190.139.128/27\",\r\n \"20.190.139.160/29\",\r\n \ + \ \"20.190.140.0/27\",\r\n \"20.190.140.32/29\",\r\n \ + \ \"20.190.140.64/27\",\r\n \"20.190.140.96/29\",\r\n \ + \ \"20.190.140.128/27\",\r\n \"20.190.140.160/29\",\r\n \ + \ \"20.190.140.192/27\",\r\n \"20.190.140.224/29\",\r\n \ + \ \"20.190.141.0/27\",\r\n \"20.190.141.32/29\",\r\n \"\ + 20.190.141.128/27\",\r\n \"20.190.141.160/29\",\r\n \"20.190.141.192/27\"\ + ,\r\n \"20.190.141.224/29\",\r\n \"20.190.142.0/27\",\r\n\ + \ \"20.190.142.32/29\",\r\n \"20.190.142.64/27\",\r\n \ + \ \"20.190.142.96/29\",\r\n \"20.190.142.128/27\",\r\n \ + \ \"20.190.142.160/29\",\r\n \"20.190.143.0/27\",\r\n \ + \ \"20.190.143.32/29\",\r\n \"20.190.143.64/27\",\r\n \ + \ \"20.190.143.96/29\",\r\n \"20.190.143.128/27\",\r\n \ + \ \"20.190.143.160/29\",\r\n \"20.190.144.0/27\",\r\n \"\ + 20.190.144.32/29\",\r\n \"20.190.144.128/27\",\r\n \"20.190.144.160/29\"\ + ,\r\n \"20.190.144.192/27\",\r\n \"20.190.144.224/29\",\r\ + \n \"20.190.145.0/27\",\r\n \"20.190.145.32/29\",\r\n \ + \ \"20.190.145.64/27\",\r\n \"20.190.145.96/29\",\r\n \ + \ \"20.190.145.128/27\",\r\n \"20.190.145.160/29\",\r\n \ + \ \"20.190.146.0/27\",\r\n \"20.190.146.32/29\",\r\n \ + \ \"20.190.146.64/27\",\r\n \"20.190.146.96/29\",\r\n \ + \ \"20.190.146.128/27\",\r\n \"20.190.146.160/29\",\r\n \ + \ \"20.190.147.0/27\",\r\n \"20.190.147.32/29\",\r\n \"\ + 20.190.147.64/27\",\r\n \"20.190.147.96/29\",\r\n \"20.190.147.128/27\"\ + ,\r\n \"20.190.147.160/29\",\r\n \"20.190.148.0/27\",\r\n\ + \ \"20.190.148.32/29\",\r\n \"20.190.148.128/27\",\r\n \ + \ \"20.190.148.160/29\",\r\n \"20.190.148.192/27\",\r\n \ + \ \"20.190.148.224/29\",\r\n \"20.190.149.0/28\",\r\n \ + \ \"20.190.149.16/29\",\r\n \"20.190.149.64/28\",\r\n \ + \ \"20.190.149.80/29\",\r\n \"20.190.149.128/28\",\r\n \ + \ \"20.190.149.144/29\",\r\n \"20.190.150.0/28\",\r\n \ + \ \"20.190.150.16/29\",\r\n \"20.190.150.64/27\",\r\n \"\ + 20.190.150.96/28\",\r\n \"20.190.151.0/28\",\r\n \"20.190.151.16/29\"\ + ,\r\n \"20.190.151.64/28\",\r\n \"20.190.151.80/29\",\r\n\ + \ \"20.190.151.128/28\",\r\n \"20.190.151.144/29\",\r\n\ + \ \"20.190.152.0/28\",\r\n \"20.190.152.16/29\",\r\n \ + \ \"20.190.152.64/28\",\r\n \"20.190.152.80/29\",\r\n \ + \ \"20.190.152.128/28\",\r\n \"20.190.152.144/29\",\r\n \ + \ \"20.190.153.0/28\",\r\n \"20.190.153.16/29\",\r\n \ + \ \"20.190.153.64/27\",\r\n \"20.190.153.96/28\",\r\n \"\ + 20.190.154.0/28\",\r\n \"20.190.154.16/29\",\r\n \"20.190.154.64/28\"\ + ,\r\n \"20.190.154.80/29\",\r\n \"20.190.154.128/28\",\r\ + \n \"20.190.154.144/29\",\r\n \"20.190.155.0/28\",\r\n \ + \ \"20.190.155.16/29\",\r\n \"20.190.155.64/28\",\r\n \ + \ \"20.190.155.80/29\",\r\n \"20.190.155.128/28\",\r\n \ + \ \"20.190.155.144/29\",\r\n \"20.190.156.0/28\",\r\n \ + \ \"20.190.156.16/29\",\r\n \"20.190.156.64/27\",\r\n \ + \ \"20.190.156.96/28\",\r\n \"20.190.157.0/28\",\r\n \"\ + 20.190.157.16/29\",\r\n \"20.190.157.64/28\",\r\n \"20.190.157.80/29\"\ + ,\r\n \"20.190.157.128/28\",\r\n \"20.190.157.144/29\",\r\ + \n \"20.190.158.0/28\",\r\n \"20.190.158.16/29\",\r\n \ + \ \"20.190.158.64/27\",\r\n \"20.190.158.96/28\",\r\n \ + \ \"20.190.159.0/28\",\r\n \"20.190.159.16/29\",\r\n \ + \ \"20.190.159.64/28\",\r\n \"20.190.159.80/29\",\r\n \ + \ \"20.190.159.128/28\",\r\n \"20.190.159.144/29\",\r\n \ + \ \"20.190.160.0/28\",\r\n \"20.190.160.16/29\",\r\n \"\ + 20.190.160.64/28\",\r\n \"20.190.160.80/29\",\r\n \"20.190.160.128/28\"\ + ,\r\n \"20.190.160.144/29\",\r\n \"20.190.161.0/28\",\r\n\ + \ \"20.190.161.16/29\",\r\n \"20.190.161.64/28\",\r\n \ + \ \"20.190.161.80/29\",\r\n \"20.190.161.128/28\",\r\n \ + \ \"20.190.161.144/29\",\r\n \"20.190.162.0/28\",\r\n \ + \ \"20.190.162.16/29\",\r\n \"20.190.162.64/27\",\r\n \ + \ \"20.190.162.96/28\",\r\n \"20.190.163.0/28\",\r\n \"\ + 20.190.163.16/29\",\r\n \"20.190.163.64/28\",\r\n \"20.190.163.80/29\"\ + ,\r\n \"20.190.163.128/28\",\r\n \"20.190.163.144/29\",\r\ + \n \"20.190.164.0/28\",\r\n \"20.190.164.16/29\",\r\n \ + \ \"20.190.164.64/27\",\r\n \"20.190.164.96/28\",\r\n \ + \ \"20.190.165.0/28\",\r\n \"20.190.165.16/29\",\r\n \ + \ \"20.190.165.64/27\",\r\n \"20.190.165.96/28\",\r\n \ + \ \"20.190.166.0/28\",\r\n \"20.190.166.16/29\",\r\n \"\ + 20.190.166.64/28\",\r\n \"20.190.166.80/29\",\r\n \"20.190.166.128/28\"\ + ,\r\n \"20.190.166.144/29\",\r\n \"20.190.167.0/28\",\r\n\ + \ \"20.190.167.16/29\",\r\n \"20.190.167.64/28\",\r\n \ + \ \"20.190.167.80/29\",\r\n \"20.190.167.128/28\",\r\n \ + \ \"20.190.167.144/29\",\r\n \"20.190.168.0/28\",\r\n \ + \ \"20.190.168.16/29\",\r\n \"20.190.168.64/27\",\r\n \ + \ \"20.190.168.96/28\",\r\n \"20.190.169.0/28\",\r\n \"\ + 20.190.169.16/29\",\r\n \"20.190.169.64/28\",\r\n \"20.190.169.80/29\"\ + ,\r\n \"20.190.169.128/28\",\r\n \"20.190.169.144/29\",\r\ + \n \"20.190.170.0/28\",\r\n \"20.190.170.16/29\",\r\n \ + \ \"20.190.170.64/27\",\r\n \"20.190.170.96/28\",\r\n \ + \ \"20.190.171.0/28\",\r\n \"20.190.171.16/29\",\r\n \ + \ \"20.190.171.64/27\",\r\n \"20.190.171.96/28\",\r\n \ + \ \"20.190.172.0/28\",\r\n \"20.190.172.16/29\",\r\n \"\ + 20.190.172.64/27\",\r\n \"20.190.172.96/28\",\r\n \"20.190.173.0/28\"\ + ,\r\n \"20.190.173.16/29\",\r\n \"20.190.173.64/28\",\r\n\ + \ \"20.190.173.80/29\",\r\n \"20.190.173.128/28\",\r\n \ + \ \"20.190.173.144/29\",\r\n \"20.190.174.0/28\",\r\n \ + \ \"20.190.174.16/29\",\r\n \"20.190.174.64/27\",\r\n \ + \ \"20.190.174.96/28\",\r\n \"20.190.175.0/28\",\r\n \ + \ \"20.190.175.16/29\",\r\n \"20.190.175.64/28\",\r\n \"\ + 20.190.175.80/29\",\r\n \"20.190.175.128/28\",\r\n \"20.190.175.144/29\"\ + ,\r\n \"20.190.176.0/28\",\r\n \"20.190.176.16/29\",\r\n\ + \ \"20.190.176.64/27\",\r\n \"20.190.176.96/28\",\r\n \ + \ \"20.190.177.0/28\",\r\n \"20.190.177.16/29\",\r\n \ + \ \"20.190.177.64/28\",\r\n \"20.190.177.80/29\",\r\n \ + \ \"20.190.177.128/28\",\r\n \"20.190.177.144/29\",\r\n \ + \ \"20.190.178.0/28\",\r\n \"20.190.178.16/29\",\r\n \"\ + 20.190.178.64/27\",\r\n \"20.190.178.96/28\",\r\n \"20.190.179.0/28\"\ + ,\r\n \"20.190.179.16/29\",\r\n \"20.190.179.64/27\",\r\n\ + \ \"20.190.179.96/28\",\r\n \"20.190.180.0/28\",\r\n \ + \ \"20.190.180.16/29\",\r\n \"20.190.180.64/28\",\r\n \ + \ \"20.190.180.80/29\",\r\n \"20.190.180.128/28\",\r\n \ + \ \"20.190.180.144/29\",\r\n \"20.190.181.0/28\",\r\n \ + \ \"20.190.181.16/29\",\r\n \"20.190.181.64/27\",\r\n \"\ + 20.190.181.96/28\",\r\n \"20.190.182.0/28\",\r\n \"20.190.182.16/29\"\ + ,\r\n \"20.190.182.64/27\",\r\n \"20.190.182.96/28\",\r\n\ + \ \"20.190.183.0/28\",\r\n \"20.190.183.16/29\",\r\n \ + \ \"20.190.183.64/27\",\r\n \"20.190.183.96/28\",\r\n \ + \ \"20.190.184.0/28\",\r\n \"20.190.184.16/29\",\r\n \ + \ \"20.190.184.64/27\",\r\n \"20.190.184.96/28\",\r\n \"\ + 20.190.186.0/28\",\r\n \"20.190.186.16/29\",\r\n \"20.190.186.64/27\"\ + ,\r\n \"20.190.186.96/28\",\r\n \"20.190.187.0/28\",\r\n\ + \ \"20.190.187.16/29\",\r\n \"20.190.187.64/27\",\r\n \ + \ \"20.190.187.96/28\",\r\n \"20.190.188.0/28\",\r\n \ + \ \"20.190.188.16/29\",\r\n \"20.190.188.64/27\",\r\n \ + \ \"20.190.188.96/28\",\r\n \"40.126.0.0/26\",\r\n \"\ + 40.126.0.64/28\",\r\n \"40.126.0.128/27\",\r\n \"40.126.0.160/29\"\ + ,\r\n \"40.126.1.0/26\",\r\n \"40.126.1.64/28\",\r\n \ + \ \"40.126.1.128/27\",\r\n \"40.126.1.160/29\",\r\n \ + \ \"40.126.2.0/27\",\r\n \"40.126.2.32/29\",\r\n \"40.126.3.0/27\"\ + ,\r\n \"40.126.3.32/29\",\r\n \"40.126.3.64/27\",\r\n \ + \ \"40.126.3.96/29\",\r\n \"40.126.4.0/27\",\r\n \ + \ \"40.126.4.32/29\",\r\n \"40.126.4.64/27\",\r\n \"40.126.4.96/29\"\ + ,\r\n \"40.126.5.0/27\",\r\n \"40.126.5.32/29\",\r\n \ + \ \"40.126.5.64/27\",\r\n \"40.126.5.96/29\",\r\n \ + \ \"40.126.6.0/27\",\r\n \"40.126.6.32/29\",\r\n \"40.126.6.64/27\"\ + ,\r\n \"40.126.6.96/29\",\r\n \"40.126.7.0/27\",\r\n \ + \ \"40.126.7.32/29\",\r\n \"40.126.7.64/27\",\r\n \ + \ \"40.126.7.96/29\",\r\n \"40.126.8.0/27\",\r\n \"40.126.8.32/29\"\ + ,\r\n \"40.126.9.0/27\",\r\n \"40.126.9.32/29\",\r\n \ + \ \"40.126.9.64/27\",\r\n \"40.126.9.96/29\",\r\n \ + \ \"40.126.10.0/27\",\r\n \"40.126.10.32/29\",\r\n \"40.126.10.64/27\"\ + ,\r\n \"40.126.10.96/29\",\r\n \"40.126.10.128/27\",\r\n\ + \ \"40.126.10.160/29\",\r\n \"40.126.11.0/27\",\r\n \ + \ \"40.126.11.32/29\",\r\n \"40.126.11.64/27\",\r\n \ + \ \"40.126.11.96/29\",\r\n \"40.126.11.128/27\",\r\n \"\ + 40.126.11.160/29\",\r\n \"40.126.12.0/27\",\r\n \"40.126.12.32/29\"\ + ,\r\n \"40.126.12.64/27\",\r\n \"40.126.12.96/29\",\r\n\ + \ \"40.126.12.128/27\",\r\n \"40.126.12.160/29\",\r\n \ + \ \"40.126.12.192/27\",\r\n \"40.126.12.224/29\",\r\n \ + \ \"40.126.13.0/27\",\r\n \"40.126.13.32/29\",\r\n \ + \ \"40.126.13.128/27\",\r\n \"40.126.13.160/29\",\r\n \"\ + 40.126.13.192/27\",\r\n \"40.126.13.224/29\",\r\n \"40.126.14.0/27\"\ + ,\r\n \"40.126.14.32/29\",\r\n \"40.126.14.64/27\",\r\n\ + \ \"40.126.14.96/29\",\r\n \"40.126.14.128/27\",\r\n \ + \ \"40.126.14.160/29\",\r\n \"40.126.15.0/27\",\r\n \ + \ \"40.126.15.32/29\",\r\n \"40.126.15.64/27\",\r\n \"\ + 40.126.15.96/29\",\r\n \"40.126.15.128/27\",\r\n \"40.126.15.160/29\"\ + ,\r\n \"40.126.16.0/27\",\r\n \"40.126.16.32/29\",\r\n \ + \ \"40.126.16.128/27\",\r\n \"40.126.16.160/29\",\r\n \ + \ \"40.126.16.192/27\",\r\n \"40.126.16.224/29\",\r\n \ + \ \"40.126.17.0/27\",\r\n \"40.126.17.32/29\",\r\n \"\ + 40.126.17.64/27\",\r\n \"40.126.17.96/29\",\r\n \"40.126.17.128/27\"\ + ,\r\n \"40.126.17.160/29\",\r\n \"40.126.18.0/27\",\r\n\ + \ \"40.126.18.32/29\",\r\n \"40.126.18.64/27\",\r\n \ + \ \"40.126.18.96/29\",\r\n \"40.126.18.128/27\",\r\n \ + \ \"40.126.18.160/29\",\r\n \"40.126.19.0/27\",\r\n \"\ + 40.126.19.32/29\",\r\n \"40.126.19.64/27\",\r\n \"40.126.19.96/29\"\ + ,\r\n \"40.126.19.128/27\",\r\n \"40.126.19.160/29\",\r\n\ + \ \"40.126.20.0/27\",\r\n \"40.126.20.32/29\",\r\n \ + \ \"40.126.20.128/27\",\r\n \"40.126.20.160/29\",\r\n \ + \ \"40.126.20.192/27\",\r\n \"40.126.20.224/29\",\r\n \ + \ \"40.126.21.0/28\",\r\n \"40.126.21.16/29\",\r\n \"40.126.21.64/28\"\ + ,\r\n \"40.126.21.80/29\",\r\n \"40.126.21.128/28\",\r\n\ + \ \"40.126.21.144/29\",\r\n \"40.126.22.0/28\",\r\n \ + \ \"40.126.22.16/29\",\r\n \"40.126.22.64/27\",\r\n \ + \ \"40.126.22.96/28\",\r\n \"40.126.23.0/28\",\r\n \"40.126.23.16/29\"\ + ,\r\n \"40.126.23.64/28\",\r\n \"40.126.23.80/29\",\r\n\ + \ \"40.126.23.128/28\",\r\n \"40.126.23.144/29\",\r\n \ + \ \"40.126.24.0/28\",\r\n \"40.126.24.16/29\",\r\n \ + \ \"40.126.24.64/28\",\r\n \"40.126.24.80/29\",\r\n \"\ + 40.126.24.128/28\",\r\n \"40.126.24.144/29\",\r\n \"40.126.25.0/28\"\ + ,\r\n \"40.126.25.16/29\",\r\n \"40.126.25.64/27\",\r\n\ + \ \"40.126.25.96/28\",\r\n \"40.126.26.0/28\",\r\n \ + \ \"40.126.26.16/29\",\r\n \"40.126.26.64/28\",\r\n \ + \ \"40.126.26.80/29\",\r\n \"40.126.26.128/28\",\r\n \"\ + 40.126.26.144/29\",\r\n \"40.126.27.0/28\",\r\n \"40.126.27.16/29\"\ + ,\r\n \"40.126.27.64/28\",\r\n \"40.126.27.80/29\",\r\n\ + \ \"40.126.27.128/28\",\r\n \"40.126.27.144/29\",\r\n \ + \ \"40.126.28.0/28\",\r\n \"40.126.28.16/29\",\r\n \ + \ \"40.126.28.64/27\",\r\n \"40.126.28.96/28\",\r\n \"\ + 40.126.29.0/28\",\r\n \"40.126.29.16/29\",\r\n \"40.126.29.64/28\"\ + ,\r\n \"40.126.29.80/29\",\r\n \"40.126.29.128/28\",\r\n\ + \ \"40.126.29.144/29\",\r\n \"40.126.30.0/28\",\r\n \ + \ \"40.126.30.16/29\",\r\n \"40.126.30.64/27\",\r\n \ + \ \"40.126.30.96/28\",\r\n \"40.126.31.0/28\",\r\n \"40.126.31.16/29\"\ + ,\r\n \"40.126.31.64/28\",\r\n \"40.126.31.80/29\",\r\n\ + \ \"40.126.31.128/28\",\r\n \"40.126.31.144/29\",\r\n \ + \ \"40.126.32.0/28\",\r\n \"40.126.32.16/29\",\r\n \ + \ \"40.126.32.64/28\",\r\n \"40.126.32.80/29\",\r\n \"\ + 40.126.32.128/28\",\r\n \"40.126.32.144/29\",\r\n \"40.126.33.0/28\"\ + ,\r\n \"40.126.33.16/29\",\r\n \"40.126.33.64/28\",\r\n\ + \ \"40.126.33.80/29\",\r\n \"40.126.33.128/28\",\r\n \ + \ \"40.126.33.144/29\",\r\n \"40.126.34.0/28\",\r\n \ + \ \"40.126.34.16/29\",\r\n \"40.126.34.64/27\",\r\n \"\ + 40.126.34.96/28\",\r\n \"40.126.35.0/28\",\r\n \"40.126.35.16/29\"\ + ,\r\n \"40.126.35.64/28\",\r\n \"40.126.35.80/29\",\r\n\ + \ \"40.126.35.128/28\",\r\n \"40.126.35.144/29\",\r\n \ + \ \"40.126.36.0/28\",\r\n \"40.126.36.16/29\",\r\n \ + \ \"40.126.36.64/27\",\r\n \"40.126.36.96/28\",\r\n \"\ + 40.126.37.0/28\",\r\n \"40.126.37.16/29\",\r\n \"40.126.37.64/27\"\ + ,\r\n \"40.126.37.96/28\",\r\n \"40.126.38.0/28\",\r\n \ + \ \"40.126.38.16/29\",\r\n \"40.126.38.64/28\",\r\n \ + \ \"40.126.38.80/29\",\r\n \"40.126.38.128/28\",\r\n \ + \ \"40.126.38.144/29\",\r\n \"40.126.39.0/28\",\r\n \"\ + 40.126.39.16/29\",\r\n \"40.126.39.64/28\",\r\n \"40.126.39.80/29\"\ + ,\r\n \"40.126.39.128/28\",\r\n \"40.126.39.144/29\",\r\n\ + \ \"40.126.40.0/28\",\r\n \"40.126.40.16/29\",\r\n \ + \ \"40.126.40.64/27\",\r\n \"40.126.40.96/28\",\r\n \ + \ \"40.126.41.0/28\",\r\n \"40.126.41.16/29\",\r\n \"40.126.41.64/28\"\ + ,\r\n \"40.126.41.80/29\",\r\n \"40.126.41.128/28\",\r\n\ + \ \"40.126.41.144/29\",\r\n \"40.126.42.0/28\",\r\n \ + \ \"40.126.42.16/29\",\r\n \"40.126.42.64/27\",\r\n \ + \ \"40.126.42.96/28\",\r\n \"40.126.43.0/28\",\r\n \"40.126.43.16/29\"\ + ,\r\n \"40.126.43.64/27\",\r\n \"40.126.43.96/28\",\r\n\ + \ \"40.126.44.0/28\",\r\n \"40.126.44.16/29\",\r\n \ + \ \"40.126.44.64/27\",\r\n \"40.126.44.96/28\",\r\n \ + \ \"40.126.45.0/28\",\r\n \"40.126.45.16/29\",\r\n \"40.126.45.64/28\"\ + ,\r\n \"40.126.45.80/29\",\r\n \"40.126.45.128/28\",\r\n\ + \ \"40.126.45.144/29\",\r\n \"40.126.46.0/28\",\r\n \ + \ \"40.126.46.16/29\",\r\n \"40.126.46.64/27\",\r\n \ + \ \"40.126.46.96/28\",\r\n \"40.126.47.0/28\",\r\n \"40.126.47.16/29\"\ + ,\r\n \"40.126.47.64/28\",\r\n \"40.126.47.80/29\",\r\n\ + \ \"40.126.47.128/28\",\r\n \"40.126.47.144/29\",\r\n \ + \ \"40.126.48.0/28\",\r\n \"40.126.48.16/29\",\r\n \ + \ \"40.126.48.64/27\",\r\n \"40.126.48.96/28\",\r\n \"\ + 40.126.49.0/28\",\r\n \"40.126.49.16/29\",\r\n \"40.126.49.64/28\"\ + ,\r\n \"40.126.49.80/29\",\r\n \"40.126.49.128/28\",\r\n\ + \ \"40.126.49.144/29\",\r\n \"40.126.50.0/28\",\r\n \ + \ \"40.126.50.16/29\",\r\n \"40.126.50.64/27\",\r\n \ + \ \"40.126.50.96/28\",\r\n \"40.126.51.0/28\",\r\n \"40.126.51.16/29\"\ + ,\r\n \"40.126.51.64/27\",\r\n \"40.126.51.96/28\",\r\n\ + \ \"40.126.52.0/28\",\r\n \"40.126.52.16/29\",\r\n \ + \ \"40.126.52.64/28\",\r\n \"40.126.52.80/29\",\r\n \ + \ \"40.126.52.128/28\",\r\n \"40.126.52.144/29\",\r\n \"\ + 40.126.53.0/28\",\r\n \"40.126.53.16/29\",\r\n \"40.126.53.64/27\"\ + ,\r\n \"40.126.53.96/28\",\r\n \"40.126.54.0/28\",\r\n \ + \ \"40.126.54.16/29\",\r\n \"40.126.54.64/27\",\r\n \ + \ \"40.126.54.96/28\",\r\n \"40.126.55.0/28\",\r\n \"\ + 40.126.55.16/29\",\r\n \"40.126.55.64/27\",\r\n \"40.126.55.96/28\"\ + ,\r\n \"40.126.56.0/28\",\r\n \"40.126.56.16/29\",\r\n \ + \ \"40.126.56.64/27\",\r\n \"40.126.56.96/28\",\r\n \ + \ \"40.126.58.0/28\",\r\n \"40.126.58.16/29\",\r\n \"\ + 40.126.58.64/27\",\r\n \"40.126.58.96/28\",\r\n \"40.126.59.0/28\"\ + ,\r\n \"40.126.59.16/29\",\r\n \"40.126.59.64/27\",\r\n\ + \ \"40.126.59.96/28\",\r\n \"40.126.60.0/28\",\r\n \ + \ \"40.126.60.16/29\",\r\n \"40.126.60.64/27\",\r\n \ + \ \"40.126.60.96/28\",\r\n \"2603:1006:2000::/121\",\r\n \ + \ \"2603:1006:2000:20::/121\",\r\n \"2603:1007:200::/121\",\r\n\ + \ \"2603:1007:200:20::/121\",\r\n \"2603:1016:1400::/121\"\ + ,\r\n \"2603:1016:1400:20::/121\",\r\n \"2603:1016:1400:40::/121\"\ + ,\r\n \"2603:1016:1400:60::/121\",\r\n \"2603:1016:1400:68::/121\"\ + ,\r\n \"2603:1016:1400:70::/121\",\r\n \"2603:1016:1400:78::/121\"\ + ,\r\n \"2603:1017::/121\",\r\n \"2603:1017:0:20::/121\"\ + ,\r\n \"2603:1017:0:40::/121\",\r\n \"2603:1017:0:60::/121\"\ + ,\r\n \"2603:1017:0:68::/121\",\r\n \"2603:1017:0:70::/121\"\ + ,\r\n \"2603:1017:0:78::/121\",\r\n \"2603:1026:3000::/121\"\ + ,\r\n \"2603:1026:3000:20::/121\",\r\n \"2603:1026:3000:40::/121\"\ + ,\r\n \"2603:1026:3000:60::/121\",\r\n \"2603:1026:3000:80::/121\"\ + ,\r\n \"2603:1026:3000:a0::/121\",\r\n \"2603:1026:3000:c0::/121\"\ + ,\r\n \"2603:1026:3000:c8::/121\",\r\n \"2603:1026:3000:d0::/121\"\ + ,\r\n \"2603:1026:3000:d8::/121\",\r\n \"2603:1026:3000:e0::/121\"\ + ,\r\n \"2603:1026:3000:e8::/121\",\r\n \"2603:1026:3000:f0::/121\"\ + ,\r\n \"2603:1026:3000:f8::/121\",\r\n \"2603:1026:3000:100::/121\"\ + ,\r\n \"2603:1026:3000:108::/121\",\r\n \"2603:1026:3000:110::/121\"\ + ,\r\n \"2603:1026:3000:118::/121\",\r\n \"2603:1026:3000:120::/121\"\ + ,\r\n \"2603:1026:3000:140::/121\",\r\n \"2603:1026:3000:148::/121\"\ + ,\r\n \"2603:1026:3000:150::/121\",\r\n \"2603:1026:3000:158::/121\"\ + ,\r\n \"2603:1026:3000:160::/121\",\r\n \"2603:1026:3000:1a0::/121\"\ + ,\r\n \"2603:1026:3000:1c0::/121\",\r\n \"2603:1026:3000:1e0::/121\"\ + ,\r\n \"2603:1026:3000:200::/121\",\r\n \"2603:1026:3000:220::/121\"\ + ,\r\n \"2603:1027:1::/121\",\r\n \"2603:1027:1:20::/121\"\ + ,\r\n \"2603:1027:1:40::/121\",\r\n \"2603:1027:1:60::/121\"\ + ,\r\n \"2603:1027:1:80::/121\",\r\n \"2603:1027:1:a0::/121\"\ + ,\r\n \"2603:1027:1:c0::/121\",\r\n \"2603:1027:1:c8::/121\"\ + ,\r\n \"2603:1027:1:d0::/121\",\r\n \"2603:1027:1:d8::/121\"\ + ,\r\n \"2603:1027:1:e0::/121\",\r\n \"2603:1027:1:e8::/121\"\ + ,\r\n \"2603:1027:1:f0::/121\",\r\n \"2603:1027:1:f8::/121\"\ + ,\r\n \"2603:1027:1:100::/121\",\r\n \"2603:1027:1:108::/121\"\ + ,\r\n \"2603:1027:1:110::/121\",\r\n \"2603:1027:1:118::/121\"\ + ,\r\n \"2603:1027:1:120::/121\",\r\n \"2603:1027:1:140::/121\"\ + ,\r\n \"2603:1027:1:148::/121\",\r\n \"2603:1027:1:150::/121\"\ + ,\r\n \"2603:1027:1:158::/121\",\r\n \"2603:1027:1:160::/121\"\ + ,\r\n \"2603:1027:1:1a0::/121\",\r\n \"2603:1027:1:1c0::/121\"\ + ,\r\n \"2603:1027:1:1e0::/121\",\r\n \"2603:1027:1:200::/121\"\ + ,\r\n \"2603:1027:1:220::/121\",\r\n \"2603:1036:3000::/121\"\ + ,\r\n \"2603:1036:3000:8::/121\",\r\n \"2603:1036:3000:10::/121\"\ + ,\r\n \"2603:1036:3000:18::/121\",\r\n \"2603:1036:3000:20::/121\"\ + ,\r\n \"2603:1036:3000:28::/121\",\r\n \"2603:1036:3000:30::/121\"\ + ,\r\n \"2603:1036:3000:38::/121\",\r\n \"2603:1036:3000:40::/121\"\ + ,\r\n \"2603:1036:3000:48::/121\",\r\n \"2603:1036:3000:50::/121\"\ + ,\r\n \"2603:1036:3000:58::/121\",\r\n \"2603:1036:3000:60::/121\"\ + ,\r\n \"2603:1036:3000:80::/121\",\r\n \"2603:1036:3000:a0::/121\"\ + ,\r\n \"2603:1036:3000:c0::/121\",\r\n \"2603:1036:3000:c8::/121\"\ + ,\r\n \"2603:1036:3000:d0::/121\",\r\n \"2603:1036:3000:d8::/121\"\ + ,\r\n \"2603:1036:3000:e0::/121\",\r\n \"2603:1036:3000:100::/121\"\ + ,\r\n \"2603:1036:3000:108::/121\",\r\n \"2603:1036:3000:110::/121\"\ + ,\r\n \"2603:1036:3000:118::/121\",\r\n \"2603:1036:3000:120::/121\"\ + ,\r\n \"2603:1036:3000:128::/121\",\r\n \"2603:1036:3000:130::/121\"\ + ,\r\n \"2603:1036:3000:138::/121\",\r\n \"2603:1036:3000:140::/121\"\ + ,\r\n \"2603:1036:3000:148::/121\",\r\n \"2603:1036:3000:150::/121\"\ + ,\r\n \"2603:1036:3000:158::/121\",\r\n \"2603:1036:3000:160::/121\"\ + ,\r\n \"2603:1036:3000:180::/121\",\r\n \"2603:1036:3000:1a0::/121\"\ + ,\r\n \"2603:1036:3000:1c0::/121\",\r\n \"2603:1037:1::/121\"\ + ,\r\n \"2603:1037:1:8::/121\",\r\n \"2603:1037:1:10::/121\"\ + ,\r\n \"2603:1037:1:18::/121\",\r\n \"2603:1037:1:20::/121\"\ + ,\r\n \"2603:1037:1:28::/121\",\r\n \"2603:1037:1:30::/121\"\ + ,\r\n \"2603:1037:1:38::/121\",\r\n \"2603:1037:1:40::/121\"\ + ,\r\n \"2603:1037:1:48::/121\",\r\n \"2603:1037:1:50::/121\"\ + ,\r\n \"2603:1037:1:58::/121\",\r\n \"2603:1037:1:60::/121\"\ + ,\r\n \"2603:1037:1:80::/121\",\r\n \"2603:1037:1:a0::/121\"\ + ,\r\n \"2603:1037:1:c0::/121\",\r\n \"2603:1037:1:c8::/121\"\ + ,\r\n \"2603:1037:1:d0::/121\",\r\n \"2603:1037:1:d8::/121\"\ + ,\r\n \"2603:1037:1:e0::/121\",\r\n \"2603:1037:1:100::/121\"\ + ,\r\n \"2603:1037:1:108::/121\",\r\n \"2603:1037:1:110::/121\"\ + ,\r\n \"2603:1037:1:118::/121\",\r\n \"2603:1037:1:120::/121\"\ + ,\r\n \"2603:1037:1:128::/121\",\r\n \"2603:1037:1:130::/121\"\ + ,\r\n \"2603:1037:1:138::/121\",\r\n \"2603:1037:1:140::/121\"\ + ,\r\n \"2603:1037:1:148::/121\",\r\n \"2603:1037:1:150::/121\"\ + ,\r\n \"2603:1037:1:158::/121\",\r\n \"2603:1037:1:160::/121\"\ + ,\r\n \"2603:1037:1:180::/121\",\r\n \"2603:1037:1:1a0::/121\"\ + ,\r\n \"2603:1037:1:1c0::/121\",\r\n \"2603:1046:2000:20::/121\"\ + ,\r\n \"2603:1046:2000:40::/121\",\r\n \"2603:1046:2000:60::/121\"\ + ,\r\n \"2603:1046:2000:80::/121\",\r\n \"2603:1046:2000:88::/121\"\ + ,\r\n \"2603:1046:2000:90::/121\",\r\n \"2603:1046:2000:98::/121\"\ + ,\r\n \"2603:1046:2000:a0::/121\",\r\n \"2603:1046:2000:e0::/121\"\ + ,\r\n \"2603:1046:2000:100::/121\",\r\n \"2603:1046:2000:120::/121\"\ + ,\r\n \"2603:1046:2000:140::/121\",\r\n \"2603:1046:2000:148::/121\"\ + ,\r\n \"2603:1046:2000:150::/121\",\r\n \"2603:1046:2000:158::/121\"\ + ,\r\n \"2603:1046:2000:160::/121\",\r\n \"2603:1046:2000:168::/121\"\ + ,\r\n \"2603:1046:2000:170::/121\",\r\n \"2603:1046:2000:178::/121\"\ + ,\r\n \"2603:1046:2000:180::/121\",\r\n \"2603:1046:2000:188::/121\"\ + ,\r\n \"2603:1046:2000:190::/121\",\r\n \"2603:1046:2000:198::/121\"\ + ,\r\n \"2603:1047:1:20::/121\",\r\n \"2603:1047:1:40::/121\"\ + ,\r\n \"2603:1047:1:60::/121\",\r\n \"2603:1047:1:80::/121\"\ + ,\r\n \"2603:1047:1:88::/121\",\r\n \"2603:1047:1:90::/121\"\ + ,\r\n \"2603:1047:1:98::/121\",\r\n \"2603:1047:1:a0::/121\"\ + ,\r\n \"2603:1047:1:e0::/121\",\r\n \"2603:1047:1:100::/121\"\ + ,\r\n \"2603:1047:1:120::/121\",\r\n \"2603:1047:1:140::/121\"\ + ,\r\n \"2603:1047:1:148::/121\",\r\n \"2603:1047:1:150::/121\"\ + ,\r\n \"2603:1047:1:158::/121\",\r\n \"2603:1047:1:160::/121\"\ + ,\r\n \"2603:1047:1:168::/121\",\r\n \"2603:1047:1:170::/121\"\ + ,\r\n \"2603:1047:1:178::/121\",\r\n \"2603:1047:1:180::/121\"\ + ,\r\n \"2603:1047:1:188::/121\",\r\n \"2603:1047:1:190::/121\"\ + ,\r\n \"2603:1047:1:198::/121\",\r\n \"2603:1056:2000::/121\"\ + ,\r\n \"2603:1056:2000:20::/121\",\r\n \"2603:1056:2000:28::/121\"\ + ,\r\n \"2603:1056:2000:30::/121\",\r\n \"2603:1056:2000:38::/121\"\ + ,\r\n \"2603:1056:2000:60::/121\",\r\n \"2603:1057:2::/121\"\ + ,\r\n \"2603:1057:2:20::/121\",\r\n \"2603:1057:2:28::/121\"\ + ,\r\n \"2603:1057:2:30::/121\",\r\n \"2603:1057:2:38::/121\"\ + ,\r\n \"2603:1057:2:60::/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureActiveDirectoryDomainServices\",\r\n \ + \ \"id\": \"AzureActiveDirectoryDomainServices\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureIdentity\",\r\n \"addressPrefixes\": [\r\n \"13.64.151.161/32\"\ + ,\r\n \"13.66.141.64/27\",\r\n \"13.67.9.224/27\",\r\n \ + \ \"13.69.66.160/27\",\r\n \"13.69.229.96/27\",\r\n \ + \ \"13.70.73.32/27\",\r\n \"13.71.172.160/27\",\r\n \ + \ \"13.71.195.224/27\",\r\n \"13.73.240.32/27\",\r\n \"\ + 13.74.249.156/32\",\r\n \"13.75.38.32/27\",\r\n \"13.75.105.168/32\"\ + ,\r\n \"13.77.52.160/27\",\r\n \"13.78.108.192/27\",\r\n\ + \ \"13.78.172.246/32\",\r\n \"13.79.37.247/32\",\r\n \ + \ \"13.86.219.0/27\",\r\n \"13.87.57.160/27\",\r\n \ + \ \"13.87.123.160/27\",\r\n \"13.89.174.0/27\",\r\n \"\ + 20.36.107.192/27\",\r\n \"20.36.115.64/27\",\r\n \"20.37.75.96/27\"\ + ,\r\n \"20.43.120.32/27\",\r\n \"20.44.3.160/27\",\r\n \ + \ \"20.44.16.32/27\",\r\n \"23.101.0.70/32\",\r\n \ + \ \"23.101.6.190/32\",\r\n \"40.68.160.142/32\",\r\n \"\ + 40.69.107.160/27\",\r\n \"40.71.13.0/27\",\r\n \"40.74.101.64/27\"\ + ,\r\n \"40.74.146.192/27\",\r\n \"40.78.195.160/27\",\r\n\ + \ \"40.78.203.64/27\",\r\n \"40.79.131.128/27\",\r\n \ + \ \"40.79.179.128/27\",\r\n \"40.83.144.56/32\",\r\n \ + \ \"51.140.148.192/27\",\r\n \"51.140.211.192/27\",\r\n \ + \ \"52.138.65.157/32\",\r\n \"52.138.68.41/32\",\r\n \ + \ \"52.161.13.71/32\",\r\n \"52.161.13.95/32\",\r\n \"52.161.110.169/32\"\ + ,\r\n \"52.162.110.96/27\",\r\n \"52.169.125.119/32\",\r\ + \n \"52.169.218.0/32\",\r\n \"52.174.189.149/32\",\r\n \ + \ \"52.175.18.134/32\",\r\n \"52.178.27.112/32\",\r\n \ + \ \"52.179.122.218/32\",\r\n \"52.179.126.223/32\",\r\n \ + \ \"52.180.177.87/32\",\r\n \"52.180.179.108/32\",\r\n \ + \ \"52.180.181.61/32\",\r\n \"52.180.183.8/32\",\r\n \ + \ \"52.187.19.1/32\",\r\n \"52.187.113.48/32\",\r\n \"\ + 52.187.117.83/32\",\r\n \"52.187.120.237/32\",\r\n \"52.225.184.198/32\"\ + ,\r\n \"52.225.188.89/32\",\r\n \"52.231.19.128/27\",\r\n\ + \ \"52.231.147.192/27\",\r\n \"65.52.251.96/27\",\r\n \ + \ \"104.40.84.19/32\",\r\n \"104.40.87.209/32\",\r\n \ + \ \"104.40.156.18/32\",\r\n \"104.41.159.212/32\",\r\n \ + \ \"104.45.138.161/32\",\r\n \"104.211.147.160/27\",\r\n \ + \ \"191.233.204.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureAdvancedThreatProtection\",\r\n \"id\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.72.105.31/32\",\r\n\ + \ \"13.72.105.76/32\",\r\n \"13.93.176.195/32\",\r\n \ + \ \"13.93.176.215/32\",\r\n \"20.36.120.112/29\",\r\n \ + \ \"20.37.64.112/29\",\r\n \"20.37.156.192/29\",\r\n \ + \ \"20.37.195.8/29\",\r\n \"20.37.224.112/29\",\r\n \"\ + 20.38.84.96/29\",\r\n \"20.38.136.112/29\",\r\n \"20.39.11.16/29\"\ + ,\r\n \"20.41.4.96/29\",\r\n \"20.41.65.128/29\",\r\n \ + \ \"20.41.192.112/29\",\r\n \"20.42.4.192/29\",\r\n \ + \ \"20.42.129.176/29\",\r\n \"20.42.224.112/29\",\r\n \ + \ \"20.43.41.144/29\",\r\n \"20.43.65.136/29\",\r\n \"\ + 20.43.130.88/29\",\r\n \"20.45.112.112/29\",\r\n \"20.45.192.112/29\"\ + ,\r\n \"20.150.160.112/29\",\r\n \"20.184.13.55/32\",\r\n\ + \ \"20.184.14.129/32\",\r\n \"20.189.106.120/29\",\r\n \ + \ \"20.192.160.24/29\",\r\n \"20.192.225.16/29\",\r\n \ + \ \"40.65.107.78/32\",\r\n \"40.65.111.206/32\",\r\n \ + \ \"40.67.48.112/29\",\r\n \"40.74.30.96/29\",\r\n \"\ + 40.80.56.112/29\",\r\n \"40.80.168.112/29\",\r\n \"40.80.188.16/29\"\ + ,\r\n \"40.82.253.64/29\",\r\n \"40.85.133.119/32\",\r\n\ + \ \"40.85.133.178/32\",\r\n \"40.87.44.77/32\",\r\n \ + \ \"40.87.45.222/32\",\r\n \"40.89.16.112/29\",\r\n \ + \ \"40.119.9.224/29\",\r\n \"51.104.25.144/29\",\r\n \"\ + 51.105.80.112/29\",\r\n \"51.105.88.112/29\",\r\n \"51.107.48.112/29\"\ + ,\r\n \"51.107.144.112/29\",\r\n \"51.120.40.112/29\",\r\ + \n \"51.120.224.112/29\",\r\n \"51.137.161.128/29\",\r\n\ + \ \"51.143.183.3/32\",\r\n \"51.143.183.52/32\",\r\n \ + \ \"51.143.192.112/29\",\r\n \"52.136.48.112/29\",\r\n \ + \ \"52.140.104.112/29\",\r\n \"52.150.139.64/29\",\r\n \ + \ \"52.170.0.116/32\",\r\n \"52.170.1.228/32\",\r\n \ + \ \"52.170.249.197/32\",\r\n \"52.174.66.179/32\",\r\n \"\ + 52.174.66.180/32\",\r\n \"52.225.176.98/32\",\r\n \"52.225.181.34/32\"\ + ,\r\n \"52.225.183.206/32\",\r\n \"52.228.81.128/29\",\r\ + \n \"104.42.25.10/32\",\r\n \"104.42.29.8/32\",\r\n \ + \ \"168.63.46.233/32\",\r\n \"168.63.46.241/32\",\r\n \ + \ \"191.233.8.24/29\",\r\n \"191.235.225.136/29\",\r\n \ + \ \"2603:1000:104:1::140/123\",\r\n \"2603:1010:6:1::140/123\"\ + ,\r\n \"2603:1020:5:1::140/123\",\r\n \"2603:1020:206:1::140/123\"\ + ,\r\n \"2603:1020:705:1::140/123\",\r\n \"2603:1020:805:1::140/123\"\ + ,\r\n \"2603:1020:a04:1::140/123\",\r\n \"2603:1020:c04:1::140/123\"\ + ,\r\n \"2603:1020:e04:1::140/123\",\r\n \"2603:1020:1004::140/123\"\ + ,\r\n \"2603:1030:10:1::140/123\",\r\n \"2603:1030:104:1::140/123\"\ + ,\r\n \"2603:1030:210:1::140/123\",\r\n \"2603:1030:40b:1::140/123\"\ + ,\r\n \"2603:1030:40c:1::140/123\",\r\n \"2603:1030:504:1::140/123\"\ + ,\r\n \"2603:1030:807:1::140/123\",\r\n \"2603:1030:c06:1::140/123\"\ + ,\r\n \"2603:1030:f05:1::140/123\",\r\n \"2603:1040:5:1::140/123\"\ + ,\r\n \"2603:1040:407:1::140/123\",\r\n \"2603:1040:904:1::140/123\"\ + ,\r\n \"2603:1040:a06:1::140/123\",\r\n \"2603:1040:d04::140/123\"\ + ,\r\n \"2603:1040:f05:1::140/123\",\r\n \"2603:1050:6:1::140/123\"\ + ,\r\n \"2603:1050:403::140/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureAdvancedThreatProtection.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.AustraliaCentral\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.37.224.112/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.CanadaEast\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.CanadaEast\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.89.16.112/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.JapanWest\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.JapanWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.56.112/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.KoreaSouth\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.KoreaSouth\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.168.112/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.NorwayWest\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.NorwayWest\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.224.112/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.SouthIndia\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.SouthIndia\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.192.112/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.UKNorth\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.UKNorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.105.80.112/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAdvancedThreatProtection.WestUS2\"\ + ,\r\n \"id\": \"AzureAdvancedThreatProtection.WestUS2\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureAdvancedThreatProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.129.176/29\",\r\n\ + \ \"40.65.107.78/32\",\r\n \"40.65.111.206/32\",\r\n \ + \ \"2603:1030:c06:1::140/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureAPIForFHIR.CentralUS\",\r\n \"id\":\ + \ \"AzureAPIForFHIR.CentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"52.182.141.14/31\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.FranceSouth\"\ + ,\r\n \"id\": \"AzureAPIForFHIR.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": [\r\n \"51.138.160.0/31\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureAPIForFHIR.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": [\r\n \"13.67.40.183/32\"\ + ,\r\n \"40.78.238.58/31\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureAPIForFHIR.UKNorth\",\r\n \"id\": \"\ + AzureAPIForFHIR.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.124.136/31\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.UKSouth2\"\ + ,\r\n \"id\": \"AzureAPIForFHIR.UKSouth2\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": [\r\n \"13.87.58.136/31\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureAPIForFHIR.WestEurope\"\ + ,\r\n \"id\": \"AzureAPIForFHIR.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAPIForFHIR\",\r\n \"addressPrefixes\": [\r\n \"13.80.124.132/32\"\ + ,\r\n \"52.178.17.0/31\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureAPIForFHIR.WestIndia\",\r\n \"id\": \"\ + AzureAPIForFHIR.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureAPIForFHIR\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.38.128.170/31\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup\",\r\ + \n \"id\": \"AzureBackup\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.140.192/26\",\r\n\ + \ \"13.66.141.0/27\",\r\n \"13.67.12.0/24\",\r\n \ + \ \"13.67.13.0/25\",\r\n \"13.69.65.32/27\",\r\n \"13.69.65.128/25\"\ + ,\r\n \"13.69.107.0/27\",\r\n \"13.69.107.128/25\",\r\n\ + \ \"13.69.228.128/25\",\r\n \"13.69.229.0/27\",\r\n \ + \ \"13.70.73.192/27\",\r\n \"13.70.74.0/26\",\r\n \"\ + 13.71.172.0/26\",\r\n \"13.71.172.64/27\",\r\n \"13.71.195.64/26\"\ + ,\r\n \"13.71.195.128/27\",\r\n \"13.74.107.192/27\",\r\n\ + \ \"13.74.108.0/25\",\r\n \"13.75.36.128/25\",\r\n \ + \ \"13.75.37.0/24\",\r\n \"13.77.52.32/27\",\r\n \"\ + 13.77.52.64/26\",\r\n \"13.78.108.32/27\",\r\n \"13.78.108.64/26\"\ + ,\r\n \"13.86.218.0/25\",\r\n \"13.86.218.128/26\",\r\n\ + \ \"13.87.57.0/26\",\r\n \"13.87.57.64/27\",\r\n \ + \ \"13.87.123.0/26\",\r\n \"13.87.123.64/27\",\r\n \"\ + 13.89.171.128/26\",\r\n \"13.89.171.192/27\",\r\n \"20.36.107.32/27\"\ + ,\r\n \"20.36.107.64/26\",\r\n \"20.36.114.224/27\",\r\n\ + \ \"20.36.115.0/26\",\r\n \"20.37.75.0/26\",\r\n \ + \ \"20.37.75.64/27\",\r\n \"20.38.147.0/27\",\r\n \"20.38.147.64/26\"\ + ,\r\n \"20.44.3.64/26\",\r\n \"20.44.3.128/27\",\r\n \ + \ \"20.44.8.32/27\",\r\n \"20.44.8.64/26\",\r\n \"\ + 20.44.16.128/27\",\r\n \"20.44.16.192/26\",\r\n \"20.44.27.128/27\"\ + ,\r\n \"20.45.123.0/26\",\r\n \"20.45.123.64/28\",\r\n \ + \ \"20.45.125.192/27\",\r\n \"20.49.82.192/26\",\r\n \ + \ \"20.49.83.0/27\",\r\n \"20.49.90.192/26\",\r\n \"\ + 20.49.91.0/27\",\r\n \"20.150.171.96/27\",\r\n \"20.150.171.128/26\"\ + ,\r\n \"20.150.179.80/28\",\r\n \"20.150.179.128/26\",\r\ + \n \"20.150.181.64/27\",\r\n \"20.150.187.80/28\",\r\n \ + \ \"20.150.187.128/26\",\r\n \"20.192.99.80/28\",\r\n \ + \ \"20.192.99.128/26\",\r\n \"20.192.235.32/27\",\r\n \ + \ \"20.192.235.64/26\",\r\n \"20.193.203.0/26\",\r\n \ + \ \"20.193.203.64/27\",\r\n \"20.194.66.192/26\",\r\n \"\ + 20.194.67.0/27\",\r\n \"23.98.83.0/27\",\r\n \"23.98.83.128/25\"\ + ,\r\n \"23.98.84.0/24\",\r\n \"40.67.59.96/27\",\r\n \ + \ \"40.67.59.128/26\",\r\n \"40.69.107.32/27\",\r\n \ + \ \"40.69.107.64/26\",\r\n \"40.70.147.128/26\",\r\n \"\ + 40.70.147.192/27\",\r\n \"40.71.12.0/25\",\r\n \"40.71.12.128/26\"\ + ,\r\n \"40.74.98.64/26\",\r\n \"40.74.98.128/27\",\r\n \ + \ \"40.74.146.96/27\",\r\n \"40.74.146.128/26\",\r\n \ + \ \"40.75.34.96/27\",\r\n \"40.75.34.192/26\",\r\n \ + \ \"40.78.195.32/27\",\r\n \"40.78.195.64/26\",\r\n \"40.78.202.160/27\"\ + ,\r\n \"40.78.202.192/26\",\r\n \"40.78.227.64/26\",\r\n\ + \ \"40.78.227.128/25\",\r\n \"40.78.234.192/27\",\r\n \ + \ \"40.78.235.0/24\",\r\n \"40.78.236.0/25\",\r\n \ + \ \"40.78.243.32/27\",\r\n \"40.78.243.64/26\",\r\n \"\ + 40.78.250.224/27\",\r\n \"40.78.251.0/26\",\r\n \"40.79.131.0/26\"\ + ,\r\n \"40.79.131.64/27\",\r\n \"40.79.155.64/26\",\r\n\ + \ \"40.79.155.128/25\",\r\n \"40.79.162.128/27\",\r\n \ + \ \"40.79.162.192/26\",\r\n \"40.79.170.64/26\",\r\n \ + \ \"40.79.170.128/27\",\r\n \"40.79.171.32/27\",\r\n \ + \ \"40.79.179.32/27\",\r\n \"40.79.179.64/26\",\r\n \"\ + 40.79.187.32/27\",\r\n \"40.79.187.64/26\",\r\n \"40.79.195.32/27\"\ + ,\r\n \"40.79.195.64/26\",\r\n \"40.80.51.0/27\",\r\n \ + \ \"40.120.74.192/26\",\r\n \"40.120.75.0/27\",\r\n \ + \ \"51.12.99.96/27\",\r\n \"51.12.99.128/26\",\r\n \"\ + 51.12.203.96/27\",\r\n \"51.12.203.128/26\",\r\n \"51.12.227.80/28\"\ + ,\r\n \"51.12.227.128/26\",\r\n \"51.12.235.80/28\",\r\n\ + \ \"51.12.235.128/26\",\r\n \"51.105.67.32/27\",\r\n \ + \ \"51.105.67.64/26\",\r\n \"51.105.75.0/27\",\r\n \ + \ \"51.105.75.64/26\",\r\n \"51.107.59.64/26\",\r\n \"\ + 51.107.59.128/27\",\r\n \"51.107.155.64/26\",\r\n \"51.107.155.128/27\"\ + ,\r\n \"51.116.59.64/26\",\r\n \"51.116.59.128/27\",\r\n\ + \ \"51.116.155.128/26\",\r\n \"51.116.155.192/27\",\r\n\ + \ \"51.116.156.144/28\",\r\n \"51.116.156.192/26\",\r\n\ + \ \"51.116.245.0/26\",\r\n \"51.116.245.64/27\",\r\n \ + \ \"51.116.250.240/28\",\r\n \"51.116.251.64/26\",\r\n \ + \ \"51.116.253.0/27\",\r\n \"51.120.99.96/27\",\r\n \ + \ \"51.120.99.128/26\",\r\n \"51.120.107.80/28\",\r\n \"\ + 51.120.107.128/26\",\r\n \"51.120.211.80/28\",\r\n \"51.120.211.128/26\"\ + ,\r\n \"51.120.219.96/27\",\r\n \"51.120.219.128/26\",\r\ + \n \"51.140.148.64/26\",\r\n \"51.140.148.128/27\",\r\n\ + \ \"51.140.211.32/27\",\r\n \"51.140.211.64/26\",\r\n \ + \ \"52.138.90.160/27\",\r\n \"52.138.90.192/26\",\r\n \ + \ \"52.138.226.192/27\",\r\n \"52.138.227.0/25\",\r\n \ + \ \"52.162.107.192/26\",\r\n \"52.162.110.0/27\",\r\n \ + \ \"52.167.106.192/27\",\r\n \"52.167.107.0/26\",\r\n \"\ + 52.182.139.64/27\",\r\n \"52.182.139.128/26\",\r\n \"52.231.19.0/26\"\ + ,\r\n \"52.231.19.64/27\",\r\n \"52.231.147.32/27\",\r\n\ + \ \"52.231.147.64/26\",\r\n \"52.236.187.0/27\",\r\n \ + \ \"52.236.187.128/25\",\r\n \"52.246.155.0/27\",\r\n \ + \ \"52.246.155.64/26\",\r\n \"65.52.251.0/26\",\r\n \ + \ \"65.52.251.64/27\",\r\n \"102.133.27.64/26\",\r\n \"\ + 102.133.27.128/27\",\r\n \"102.133.123.96/27\",\r\n \"102.133.155.64/26\"\ + ,\r\n \"102.133.155.128/27\",\r\n \"102.133.251.0/27\",\r\ + \n \"104.211.82.0/26\",\r\n \"104.211.82.64/27\",\r\n \ + \ \"104.211.147.0/26\",\r\n \"104.211.147.64/27\",\r\n \ + \ \"104.214.19.96/27\",\r\n \"104.214.19.128/26\",\r\n \ + \ \"191.233.50.224/27\",\r\n \"191.233.51.64/26\",\r\n \ + \ \"191.233.204.0/26\",\r\n \"191.233.204.64/27\",\r\n \ + \ \"191.234.147.80/28\",\r\n \"191.234.147.128/26\",\r\n \ + \ \"191.234.149.160/27\",\r\n \"191.234.155.80/28\",\r\n \ + \ \"191.234.155.128/26\",\r\n \"191.234.157.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureBackup.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.36.107.32/27\"\ + ,\r\n \"20.36.107.64/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.AustraliaCentral2\",\r\n \"id\"\ + : \"AzureBackup.AustraliaCentral2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.224/27\"\ + ,\r\n \"20.36.115.0/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.AustraliaEast\",\r\n \"id\": \"\ + AzureBackup.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.70.73.192/27\",\r\n \ + \ \"13.70.74.0/26\",\r\n \"40.79.162.128/27\",\r\n \ + \ \"40.79.162.192/26\",\r\n \"40.79.170.64/26\",\r\n \"\ + 40.79.170.128/27\",\r\n \"40.79.171.32/27\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureBackup.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.77.52.32/27\"\ + ,\r\n \"13.77.52.64/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.BrazilSouth\",\r\n \"id\": \"AzureBackup.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"191.233.204.0/26\",\r\n \"191.233.204.64/27\"\ + ,\r\n \"191.234.147.80/28\",\r\n \"191.234.147.128/26\"\ + ,\r\n \"191.234.149.160/27\",\r\n \"191.234.155.80/28\"\ + ,\r\n \"191.234.155.128/26\",\r\n \"191.234.157.64/27\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.CanadaCentral\"\ + ,\r\n \"id\": \"AzureBackup.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.71.172.0/26\"\ + ,\r\n \"13.71.172.64/27\",\r\n \"20.38.147.0/27\",\r\n \ + \ \"20.38.147.64/26\",\r\n \"52.246.155.0/27\",\r\n \ + \ \"52.246.155.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.CanadaEast\",\r\n \"id\": \"AzureBackup.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.69.107.32/27\",\r\n \"40.69.107.64/26\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.CentralIndia\"\ + ,\r\n \"id\": \"AzureBackup.CentralIndia\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.192.99.80/28\"\ + ,\r\n \"20.192.99.128/26\",\r\n \"40.80.51.0/27\",\r\n \ + \ \"104.211.82.0/26\",\r\n \"104.211.82.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.CentralUS\"\ + ,\r\n \"id\": \"AzureBackup.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.128/26\"\ + ,\r\n \"13.89.171.192/27\",\r\n \"20.44.8.32/27\",\r\n \ + \ \"20.44.8.64/26\",\r\n \"52.182.139.64/27\",\r\n \ + \ \"52.182.139.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.CentralUSEUAP\",\r\n \"id\": \"AzureBackup.CentralUSEUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.78.202.160/27\",\r\n \"40.78.202.192/26\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.EastAsia\"\ + ,\r\n \"id\": \"AzureBackup.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.75.36.128/25\"\ + ,\r\n \"13.75.37.0/24\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.EastUS\",\r\n \"id\": \"AzureBackup.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.71.12.0/25\",\r\n \"40.71.12.128/26\",\r\n \ + \ \"40.78.227.64/26\",\r\n \"40.78.227.128/25\",\r\n \"\ + 40.79.155.64/26\",\r\n \"40.79.155.128/25\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureBackup.EastUS2\",\r\n \ + \ \"id\": \"AzureBackup.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.44.16.128/27\",\r\n\ + \ \"20.44.16.192/26\",\r\n \"40.70.147.128/26\",\r\n \ + \ \"40.70.147.192/27\",\r\n \"52.167.106.192/27\",\r\n \ + \ \"52.167.107.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.EastUS2EUAP\",\r\n \"id\": \"AzureBackup.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.146.96/27\",\r\n \"40.74.146.128/26\",\r\ + \n \"40.75.34.96/27\",\r\n \"40.75.34.192/26\",\r\n \ + \ \"52.138.90.160/27\",\r\n \"52.138.90.192/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.FranceCentral\"\ + ,\r\n \"id\": \"AzureBackup.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"40.79.131.0/26\"\ + ,\r\n \"40.79.131.64/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.FranceSouth\",\r\n \"id\": \"\ + AzureBackup.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.79.179.32/27\",\r\n \ + \ \"40.79.179.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.GermanyNorth\",\r\n \"id\": \"AzureBackup.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.59.64/26\",\r\n \"51.116.59.128/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureBackup.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.116.155.128/26\"\ + ,\r\n \"51.116.155.192/27\",\r\n \"51.116.156.144/28\",\r\ + \n \"51.116.156.192/26\",\r\n \"51.116.245.0/26\",\r\n \ + \ \"51.116.245.64/27\",\r\n \"51.116.250.240/28\",\r\n \ + \ \"51.116.251.64/26\",\r\n \"51.116.253.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.JapanEast\"\ + ,\r\n \"id\": \"AzureBackup.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.78.108.32/27\"\ + ,\r\n \"13.78.108.64/26\",\r\n \"40.79.187.32/27\",\r\n\ + \ \"40.79.187.64/26\",\r\n \"40.79.195.32/27\",\r\n \ + \ \"40.79.195.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.JapanWest\",\r\n \"id\": \"AzureBackup.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.98.64/26\",\r\n \"40.74.98.128/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.KoreaCentral\"\ + ,\r\n \"id\": \"AzureBackup.KoreaCentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.44.27.128/27\"\ + ,\r\n \"20.194.66.192/26\",\r\n \"20.194.67.0/27\",\r\n\ + \ \"52.231.19.0/26\",\r\n \"52.231.19.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.KoreaSouth\"\ + ,\r\n \"id\": \"AzureBackup.KoreaSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"52.231.147.32/27\"\ + ,\r\n \"52.231.147.64/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.NorthCentralUS\",\r\n \"id\"\ + : \"AzureBackup.NorthCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"52.162.107.192/26\"\ + ,\r\n \"52.162.110.0/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.NorthEurope\",\r\n \"id\": \"\ + AzureBackup.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.69.228.128/25\",\r\n \ + \ \"13.69.229.0/27\",\r\n \"13.74.107.192/27\",\r\n \ + \ \"13.74.108.0/25\",\r\n \"52.138.226.192/27\",\r\n \"\ + 52.138.227.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureBackup.NorwayEast\",\r\n \"id\": \"AzureBackup.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.99.96/27\",\r\n \"51.120.99.128/26\",\r\n \ + \ \"51.120.107.80/28\",\r\n \"51.120.107.128/26\",\r\n \ + \ \"51.120.211.80/28\",\r\n \"51.120.211.128/26\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.NorwayWest\"\ + ,\r\n \"id\": \"AzureBackup.NorwayWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.120.219.96/27\"\ + ,\r\n \"51.120.219.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.SouthAfricaNorth\",\r\n \"id\"\ + : \"AzureBackup.SouthAfricaNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"102.133.123.96/27\"\ + ,\r\n \"102.133.155.64/26\",\r\n \"102.133.155.128/27\"\ + ,\r\n \"102.133.251.0/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.SouthAfricaWest\",\r\n \"id\"\ + : \"AzureBackup.SouthAfricaWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"102.133.27.64/26\"\ + ,\r\n \"102.133.27.128/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.SouthCentralUS\",\r\n \"id\"\ + : \"AzureBackup.SouthCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"20.45.123.0/26\"\ + ,\r\n \"20.45.123.64/28\",\r\n \"20.45.125.192/27\",\r\n\ + \ \"20.49.90.192/26\",\r\n \"20.49.91.0/27\",\r\n \ + \ \"104.214.19.96/27\",\r\n \"104.214.19.128/26\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureBackup.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.67.12.0/24\"\ + ,\r\n \"13.67.13.0/25\",\r\n \"23.98.83.0/27\",\r\n \ + \ \"23.98.83.128/25\",\r\n \"23.98.84.0/24\",\r\n \"\ + 40.78.234.192/27\",\r\n \"40.78.235.0/24\",\r\n \"40.78.236.0/25\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.SouthIndia\"\ + ,\r\n \"id\": \"AzureBackup.SouthIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"40.78.195.32/27\"\ + ,\r\n \"40.78.195.64/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.SwitzerlandNorth\",\r\n \"id\"\ + : \"AzureBackup.SwitzerlandNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.107.59.64/26\"\ + ,\r\n \"51.107.59.128/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.SwitzerlandWest\",\r\n \"id\"\ + : \"AzureBackup.SwitzerlandWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.155.64/26\",\r\n\ + \ \"51.107.155.128/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBackup.UAECentral\",\r\n \"id\": \"AzureBackup.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.75.0/26\",\r\n \"20.37.75.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UAENorth\"\ + ,\r\n \"id\": \"AzureBackup.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.192/26\"\ + ,\r\n \"40.120.75.0/27\",\r\n \"65.52.251.0/26\",\r\n \ + \ \"65.52.251.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.UKNorth\",\r\n \"id\": \"AzureBackup.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.87.123.0/26\",\r\n \"13.87.123.64/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UKSouth\",\r\ + \n \"id\": \"AzureBackup.UKSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.105.67.32/27\"\ + ,\r\n \"51.105.67.64/26\",\r\n \"51.105.75.0/27\",\r\n \ + \ \"51.105.75.64/26\",\r\n \"51.140.148.64/26\",\r\n \ + \ \"51.140.148.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBackup.UKSouth2\",\r\n \"id\": \"AzureBackup.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.87.57.0/26\",\r\n \"13.87.57.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.UKWest\"\ + ,\r\n \"id\": \"AzureBackup.UKWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"51.140.211.32/27\"\ + ,\r\n \"51.140.211.64/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.WestCentralUS\",\r\n \"id\":\ + \ \"AzureBackup.WestCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBackup\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.195.64/26\",\r\n\ + \ \"13.71.195.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureBackup.WestEurope\",\r\n \"id\": \"AzureBackup.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBackup\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.65.32/27\",\r\n \"13.69.65.128/25\",\r\n\ + \ \"13.69.107.0/27\",\r\n \"13.69.107.128/25\",\r\n \ + \ \"52.236.187.0/27\",\r\n \"52.236.187.128/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.WestIndia\"\ + ,\r\n \"id\": \"AzureBackup.WestIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"104.211.147.0/26\"\ + ,\r\n \"104.211.147.64/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBackup.WestUS\",\r\n \"id\": \"AzureBackup.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.86.218.0/25\",\r\n \"13.86.218.128/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBackup.WestUS2\"\ + ,\r\n \"id\": \"AzureBackup.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBackup\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.192/26\"\ + ,\r\n \"13.66.141.0/27\",\r\n \"40.78.243.32/27\",\r\n \ + \ \"40.78.243.64/26\",\r\n \"40.78.250.224/27\",\r\n \ + \ \"40.78.251.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureBotService\",\r\n \"id\": \"AzureBotService\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.66.142.64/30\",\r\n \"13.67.10.88/30\",\r\n \ + \ \"13.69.67.56/30\",\r\n \"13.69.227.252/30\",\r\n \ + \ \"13.70.74.112/30\",\r\n \"13.71.173.240/30\",\r\n \"\ + 13.71.196.160/30\",\r\n \"13.73.248.0/30\",\r\n \"13.75.39.72/30\"\ + ,\r\n \"13.77.53.80/30\",\r\n \"13.78.108.172/30\",\r\n\ + \ \"13.86.219.168/30\",\r\n \"13.87.58.40/30\",\r\n \ + \ \"13.87.124.40/30\",\r\n \"13.89.171.116/30\",\r\n \ + \ \"20.36.108.112/30\",\r\n \"20.36.115.240/30\",\r\n \ + \ \"20.36.120.64/30\",\r\n \"20.37.64.64/30\",\r\n \"20.37.76.104/30\"\ + ,\r\n \"20.37.152.64/30\",\r\n \"20.37.192.64/30\",\r\n\ + \ \"20.37.224.64/30\",\r\n \"20.38.80.64/30\",\r\n \ + \ \"20.38.128.72/30\",\r\n \"20.38.136.64/30\",\r\n \ + \ \"20.39.8.64/30\",\r\n \"20.41.0.64/30\",\r\n \"20.41.64.64/30\"\ + ,\r\n \"20.41.192.64/30\",\r\n \"20.42.0.64/30\",\r\n \ + \ \"20.42.128.64/30\",\r\n \"20.42.224.64/30\",\r\n \ + \ \"20.43.40.64/30\",\r\n \"20.43.64.64/30\",\r\n \"\ + 20.43.121.8/30\",\r\n \"20.43.128.64/30\",\r\n \"20.44.4.72/30\"\ + ,\r\n \"20.44.17.24/30\",\r\n \"20.44.27.208/30\",\r\n \ + \ \"20.45.112.64/30\",\r\n \"20.45.123.112/30\",\r\n \ + \ \"20.45.192.64/30\",\r\n \"20.150.160.120/30\",\r\n \ + \ \"20.189.104.64/30\",\r\n \"20.192.160.16/30\",\r\n \ + \ \"20.192.224.64/26\",\r\n \"40.67.48.64/30\",\r\n \"\ + 40.67.58.4/30\",\r\n \"40.69.108.56/30\",\r\n \"40.71.12.244/30\"\ + ,\r\n \"40.74.24.64/30\",\r\n \"40.74.147.168/30\",\r\n\ + \ \"40.78.196.56/30\",\r\n \"40.78.202.132/30\",\r\n \ + \ \"40.79.132.56/30\",\r\n \"40.79.180.24/30\",\r\n \ + \ \"40.80.56.64/30\",\r\n \"40.80.168.64/30\",\r\n \"\ + 40.80.176.32/30\",\r\n \"40.80.184.64/30\",\r\n \"40.82.248.64/30\"\ + ,\r\n \"40.89.16.64/30\",\r\n \"51.12.40.64/26\",\r\n \ + \ \"51.12.192.64/26\",\r\n \"51.104.8.248/30\",\r\n \ + \ \"51.104.24.64/30\",\r\n \"51.105.80.64/30\",\r\n \"\ + 51.105.88.64/30\",\r\n \"51.107.48.64/30\",\r\n \"51.107.58.4/30\"\ + ,\r\n \"51.107.144.64/30\",\r\n \"51.107.154.4/30\",\r\n\ + \ \"51.116.48.64/30\",\r\n \"51.116.144.64/30\",\r\n \ + \ \"51.120.40.64/30\",\r\n \"51.120.98.12/30\",\r\n \ + \ \"51.120.218.4/30\",\r\n \"51.120.224.64/30\",\r\n \"\ + 51.137.160.64/30\",\r\n \"51.140.212.72/30\",\r\n \"51.143.192.64/30\"\ + ,\r\n \"52.136.48.64/30\",\r\n \"52.140.104.64/30\",\r\n\ + \ \"52.150.136.64/30\",\r\n \"52.162.111.16/30\",\r\n \ + \ \"52.228.80.64/30\",\r\n \"52.231.148.88/30\",\r\n \ + \ \"65.52.252.104/30\",\r\n \"102.133.28.88/30\",\r\n \ + \ \"102.133.56.64/30\",\r\n \"102.133.124.8/30\",\r\n \ + \ \"102.133.216.64/30\",\r\n \"191.233.8.16/30\",\r\n \"\ + 191.233.205.96/30\",\r\n \"191.235.224.64/30\",\r\n \"2603:1000:104:1::20/123\"\ + ,\r\n \"2603:1010:6:1::20/123\",\r\n \"2603:1020:5:1::20/123\"\ + ,\r\n \"2603:1020:206:1::20/123\",\r\n \"2603:1020:705:1::20/123\"\ + ,\r\n \"2603:1020:805:1::20/123\",\r\n \"2603:1020:a04:1::20/123\"\ + ,\r\n \"2603:1020:c04:1::20/123\",\r\n \"2603:1020:e04:1::20/123\"\ + ,\r\n \"2603:1020:1004::20/123\",\r\n \"2603:1030:10:1::20/123\"\ + ,\r\n \"2603:1030:104:1::20/123\",\r\n \"2603:1030:210:1::20/123\"\ + ,\r\n \"2603:1030:40b:1::20/123\",\r\n \"2603:1030:40c:1::20/123\"\ + ,\r\n \"2603:1030:504:1::20/123\",\r\n \"2603:1030:807:1::20/123\"\ + ,\r\n \"2603:1030:c06:1::20/123\",\r\n \"2603:1030:f05:1::20/123\"\ + ,\r\n \"2603:1040:5:1::20/123\",\r\n \"2603:1040:407:1::20/123\"\ + ,\r\n \"2603:1040:904:1::20/123\",\r\n \"2603:1040:a06:1::20/123\"\ + ,\r\n \"2603:1040:d04::20/123\",\r\n \"2603:1040:f05:1::20/123\"\ + ,\r\n \"2603:1050:6:1::20/123\",\r\n \"2603:1050:403::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureBotService.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.36.108.112/30\"\ + ,\r\n \"20.37.224.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.AustraliaCentral2\",\r\n \"\ + id\": \"AzureBotService.AustraliaCentral2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.36.115.240/30\"\ + ,\r\n \"20.36.120.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.AustraliaEast\",\r\n \"id\"\ + : \"AzureBotService.AustraliaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.70.74.112/30\"\ + ,\r\n \"20.37.192.64/30\",\r\n \"2603:1010:6:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureBotService.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.77.53.80/30\"\ + ,\r\n \"20.42.224.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.BrazilSouth\",\r\n \"id\"\ + : \"AzureBotService.BrazilSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"191.233.205.96/30\",\r\n\ + \ \"191.235.224.64/30\",\r\n \"2603:1050:6:1::20/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CanadaCentral\"\ + ,\r\n \"id\": \"AzureBotService.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.71.173.240/30\"\ + ,\r\n \"52.228.80.64/30\",\r\n \"2603:1030:f05:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CanadaEast\"\ + ,\r\n \"id\": \"AzureBotService.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.69.108.56/30\"\ + ,\r\n \"40.89.16.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.CentralIndia\",\r\n \"id\"\ + : \"AzureBotService.CentralIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.43.121.8/30\"\ + ,\r\n \"52.140.104.64/30\",\r\n \"2603:1040:a06:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CentralUS\"\ + ,\r\n \"id\": \"AzureBotService.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.116/30\"\ + ,\r\n \"20.37.152.64/30\",\r\n \"2603:1030:10:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureBotService.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.45.192.64/30\"\ + ,\r\n \"40.78.202.132/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.EastAsia\",\r\n \"id\": \"\ + AzureBotService.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.75.39.72/30\",\r\n \ + \ \"20.189.104.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBotService.EastUS\",\r\n \"id\": \"AzureBotService.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.42.0.64/30\",\r\n \"40.71.12.244/30\",\r\n \ + \ \"2603:1030:210:1::20/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.EastUS2\",\r\n \"id\": \"AzureBotService.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.41.0.64/30\",\r\n \"20.44.17.24/30\",\r\n \ + \ \"2603:1030:40c:1::20/123\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureBotService.EastUS2EUAP\",\r\n \"id\": \"AzureBotService.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"\ + addressPrefixes\": [\r\n \"20.39.8.64/30\",\r\n \"40.74.147.168/30\"\ + ,\r\n \"2603:1030:40b:1::20/123\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureBotService.FranceCentral\",\r\n \ + \ \"id\": \"AzureBotService.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.43.40.64/30\"\ + ,\r\n \"40.79.132.56/30\",\r\n \"2603:1020:805:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.FranceSouth\"\ + ,\r\n \"id\": \"AzureBotService.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.79.180.24/30\"\ + ,\r\n \"51.105.88.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.GermanyNorth\",\r\n \"id\"\ + : \"AzureBotService.GermanyNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.48.64/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureBotService.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.116.144.64/30\"\ + ,\r\n \"2603:1020:c04:1::20/123\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureBotService.JapanEast\",\r\n \"\ + id\": \"AzureBotService.JapanEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.78.108.172/30\"\ + ,\r\n \"20.43.64.64/30\",\r\n \"2603:1040:407:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.JapanWest\"\ + ,\r\n \"id\": \"AzureBotService.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.80.56.64/30\"\ + ,\r\n \"40.80.176.32/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.KoreaCentral\",\r\n \"id\"\ + : \"AzureBotService.KoreaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.41.64.64/30\"\ + ,\r\n \"20.44.27.208/30\",\r\n \"2603:1040:f05:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.KoreaSouth\"\ + ,\r\n \"id\": \"AzureBotService.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.80.168.64/30\"\ + ,\r\n \"52.231.148.88/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.NorthCentralUS\",\r\n \"\ + id\": \"AzureBotService.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"40.80.184.64/30\"\ + ,\r\n \"52.162.111.16/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.NorthEurope\",\r\n \"id\"\ + : \"AzureBotService.NorthEurope\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.227.252/30\",\r\n\ + \ \"20.38.80.64/30\",\r\n \"2603:1020:5:1::20/123\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.NorwayEast\"\ + ,\r\n \"id\": \"AzureBotService.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.120.40.64/30\"\ + ,\r\n \"51.120.98.12/30\",\r\n \"2603:1020:e04:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.NorwayWest\"\ + ,\r\n \"id\": \"AzureBotService.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.4/30\"\ + ,\r\n \"51.120.224.64/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.SouthAfricaNorth\",\r\n \"\ + id\": \"AzureBotService.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"102.133.124.8/30\"\ + ,\r\n \"102.133.216.64/30\",\r\n \"2603:1000:104:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureBotService.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"102.133.28.88/30\"\ + ,\r\n \"102.133.56.64/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.SouthCentralUS\",\r\n \"\ + id\": \"AzureBotService.SouthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.73.248.0/30\"\ + ,\r\n \"20.45.123.112/30\",\r\n \"2603:1030:807:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureBotService.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.67.10.88/30\"\ + ,\r\n \"20.43.128.64/30\",\r\n \"2603:1040:5:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SouthIndia\"\ + ,\r\n \"id\": \"AzureBotService.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.41.192.64/30\"\ + ,\r\n \"40.78.196.56/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.SwitzerlandNorth\",\r\n \"\ + id\": \"AzureBotService.SwitzerlandNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.107.48.64/30\"\ + ,\r\n \"51.107.58.4/30\",\r\n \"2603:1020:a04:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureBotService.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"51.107.144.64/30\"\ + ,\r\n \"51.107.154.4/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.UAECentral\",\r\n \"id\":\ + \ \"AzureBotService.UAECentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.37.64.64/30\",\r\n \ + \ \"20.37.76.104/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureBotService.UAENorth\",\r\n \"id\": \"AzureBotService.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureBotService\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.136.64/30\",\r\n \"65.52.252.104/30\",\r\ + \n \"2603:1040:904:1::20/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureBotService.UKNorth\",\r\n \"id\": \"\ + AzureBotService.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.124.40/30\",\r\n \ + \ \"51.105.80.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBotService.UKSouth\",\r\n \"id\": \"AzureBotService.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.104.8.248/30\",\r\n \"51.104.24.64/30\",\r\n \ + \ \"2603:1020:705:1::20/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.UKSouth2\",\r\n \"id\": \"\ + AzureBotService.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.58.40/30\",\r\n \ + \ \"51.143.192.64/30\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureBotService.UKWest\",\r\n \"id\": \"AzureBotService.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.137.160.64/30\",\r\n \"51.140.212.72/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.WestCentralUS\"\ + ,\r\n \"id\": \"AzureBotService.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.71.196.160/30\"\ + ,\r\n \"52.150.136.64/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureBotService.WestEurope\",\r\n \"id\"\ + : \"AzureBotService.WestEurope\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureBotService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.67.56/30\",\r\n \ + \ \"40.74.24.64/30\",\r\n \"2603:1020:206:1::20/123\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.WestIndia\"\ + ,\r\n \"id\": \"AzureBotService.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"20.38.128.72/30\"\ + ,\r\n \"52.136.48.64/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureBotService.WestUS\",\r\n \"id\": \"AzureBotService.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.86.219.168/30\",\r\n \"40.82.248.64/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureBotService.WestUS2\"\ + ,\r\n \"id\": \"AzureBotService.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureBotService\",\r\n \"addressPrefixes\": [\r\n \"13.66.142.64/30\"\ + ,\r\n \"20.42.128.64/30\",\r\n \"2603:1030:c06:1::20/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch\"\ + ,\r\n \"id\": \"AzureCognitiveSearch\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.64.32.141/32\",\r\n \"13.83.22.45/32\",\r\n \"13.83.22.74/32\"\ + ,\r\n \"13.83.22.119/32\",\r\n \"13.86.5.51/32\",\r\n \ + \ \"20.36.120.128/26\",\r\n \"20.37.64.128/26\",\r\n \ + \ \"20.37.156.128/26\",\r\n \"20.37.193.192/26\",\r\n \ + \ \"20.37.224.128/26\",\r\n \"20.38.84.0/26\",\r\n \"\ + 20.38.136.128/26\",\r\n \"20.39.8.192/26\",\r\n \"20.40.123.36/32\"\ + ,\r\n \"20.40.123.39/32\",\r\n \"20.40.123.46/32\",\r\n\ + \ \"20.40.123.72/32\",\r\n \"20.41.4.128/26\",\r\n \ + \ \"20.41.65.64/26\",\r\n \"20.41.193.64/26\",\r\n \"\ + 20.42.4.128/26\",\r\n \"20.42.24.90/32\",\r\n \"20.42.29.212/32\"\ + ,\r\n \"20.42.30.105/32\",\r\n \"20.42.34.190/32\",\r\n\ + \ \"20.42.35.204/32\",\r\n \"20.42.129.192/26\",\r\n \ + \ \"20.42.225.192/26\",\r\n \"20.43.41.64/26\",\r\n \ + \ \"20.43.65.64/26\",\r\n \"20.43.130.128/26\",\r\n \"\ + 20.44.74.182/32\",\r\n \"20.44.76.53/32\",\r\n \"20.44.76.61/32\"\ + ,\r\n \"20.44.76.86/32\",\r\n \"20.45.0.49/32\",\r\n \ + \ \"20.45.2.122/32\",\r\n \"20.45.112.128/26\",\r\n \ + \ \"20.45.192.128/26\",\r\n \"20.150.160.128/26\",\r\n \ + \ \"20.185.110.199/32\",\r\n \"20.189.106.128/26\",\r\n \ + \ \"20.189.129.94/32\",\r\n \"20.192.161.0/26\",\r\n \"\ + 20.192.225.64/26\",\r\n \"23.100.238.27/32\",\r\n \"23.100.238.34/31\"\ + ,\r\n \"23.100.238.37/32\",\r\n \"40.65.173.157/32\",\r\n\ + \ \"40.65.175.212/32\",\r\n \"40.65.175.228/32\",\r\n \ + \ \"40.66.56.233/32\",\r\n \"40.67.48.128/26\",\r\n \ + \ \"40.74.18.154/32\",\r\n \"40.74.30.0/26\",\r\n \"\ + 40.80.57.64/26\",\r\n \"40.80.169.64/26\",\r\n \"40.80.186.192/26\"\ + ,\r\n \"40.80.216.231/32\",\r\n \"40.80.217.38/32\",\r\n\ + \ \"40.80.219.46/32\",\r\n \"40.81.9.100/32\",\r\n \ + \ \"40.81.9.131/32\",\r\n \"40.81.9.203/32\",\r\n \"\ + 40.81.9.209/32\",\r\n \"40.81.9.213/32\",\r\n \"40.81.9.221/32\"\ + ,\r\n \"40.81.10.36/32\",\r\n \"40.81.12.133/32\",\r\n \ + \ \"40.81.15.8/32\",\r\n \"40.81.15.39/32\",\r\n \ + \ \"40.81.29.152/32\",\r\n \"40.81.188.130/32\",\r\n \"\ + 40.81.191.58/32\",\r\n \"40.81.253.154/32\",\r\n \"40.82.155.65/32\"\ + ,\r\n \"40.82.253.0/26\",\r\n \"40.89.17.64/26\",\r\n \ + \ \"40.90.190.180/32\",\r\n \"40.90.240.17/32\",\r\n \ + \ \"40.91.93.84/32\",\r\n \"40.91.127.116/32\",\r\n \ + \ \"40.91.127.241/32\",\r\n \"40.119.11.0/26\",\r\n \"51.12.41.64/26\"\ + ,\r\n \"51.12.193.64/26\",\r\n \"51.104.25.64/26\",\r\n\ + \ \"51.105.80.128/26\",\r\n \"51.105.88.128/26\",\r\n \ + \ \"51.107.48.128/26\",\r\n \"51.107.144.128/26\",\r\n \ + \ \"51.116.48.96/28\",\r\n \"51.116.144.96/28\",\r\n \ + \ \"51.120.40.128/26\",\r\n \"51.120.224.128/26\",\r\n \ + \ \"51.132.43.66/32\",\r\n \"51.137.161.64/26\",\r\n \"\ + 51.143.104.54/32\",\r\n \"51.143.104.90/32\",\r\n \"51.143.192.128/26\"\ + ,\r\n \"51.145.124.157/32\",\r\n \"51.145.124.158/32\",\r\ + \n \"51.145.176.249/32\",\r\n \"51.145.177.212/32\",\r\n\ + \ \"51.145.178.138/32\",\r\n \"51.145.178.140/32\",\r\n\ + \ \"52.136.48.128/26\",\r\n \"52.137.24.236/32\",\r\n \ + \ \"52.137.26.114/32\",\r\n \"52.137.26.155/32\",\r\n \ + \ \"52.137.26.198/32\",\r\n \"52.137.27.49/32\",\r\n \ + \ \"52.137.56.115/32\",\r\n \"52.137.60.208/32\",\r\n \ + \ \"52.139.0.47/32\",\r\n \"52.139.0.49/32\",\r\n \"52.140.105.64/26\"\ + ,\r\n \"52.140.233.105/32\",\r\n \"52.150.139.0/26\",\r\n\ + \ \"52.151.235.150/32\",\r\n \"52.151.235.242/32\",\r\n\ + \ \"52.151.235.244/32\",\r\n \"52.155.216.245/32\",\r\n\ + \ \"52.155.217.84/32\",\r\n \"52.155.221.242/32\",\r\n \ + \ \"52.155.221.250/32\",\r\n \"52.155.222.35/32\",\r\n \ + \ \"52.155.222.56/32\",\r\n \"52.157.22.233/32\",\r\n \ + \ \"52.157.231.64/32\",\r\n \"52.158.28.181/32\",\r\n \ + \ \"52.158.30.241/32\",\r\n \"52.158.208.11/32\",\r\n \ + \ \"52.184.80.221/32\",\r\n \"52.185.224.13/32\",\r\n \"\ + 52.185.224.38/32\",\r\n \"52.188.217.235/32\",\r\n \"52.188.218.228/32\"\ + ,\r\n \"52.188.218.239/32\",\r\n \"52.228.81.64/26\",\r\n\ + \ \"52.242.214.45/32\",\r\n \"52.253.133.74/32\",\r\n \ + \ \"52.253.229.120/32\",\r\n \"102.133.128.33/32\",\r\n \ + \ \"102.133.217.128/26\",\r\n \"104.45.64.0/32\",\r\n \ + \ \"104.45.64.147/32\",\r\n \"104.45.64.224/32\",\r\n \ + \ \"104.45.65.30/32\",\r\n \"104.45.65.89/32\",\r\n \"\ + 191.233.9.0/26\",\r\n \"191.233.26.156/32\",\r\n \"191.235.225.64/26\"\ + ,\r\n \"2603:1000:104:1::180/121\",\r\n \"2603:1010:6:1::180/121\"\ + ,\r\n \"2603:1020:5:1::180/121\",\r\n \"2603:1020:206:1::180/121\"\ + ,\r\n \"2603:1020:705:1::180/121\",\r\n \"2603:1020:805:1::180/121\"\ + ,\r\n \"2603:1020:a04:1::180/121\",\r\n \"2603:1020:c04:1::180/121\"\ + ,\r\n \"2603:1020:e04:1::180/121\",\r\n \"2603:1020:1004::180/121\"\ + ,\r\n \"2603:1030:10:1::180/121\",\r\n \"2603:1030:104:1::180/121\"\ + ,\r\n \"2603:1030:210:1::180/121\",\r\n \"2603:1030:40b:1::180/121\"\ + ,\r\n \"2603:1030:40c:1::180/121\",\r\n \"2603:1030:504:1::180/121\"\ + ,\r\n \"2603:1030:807:1::180/121\",\r\n \"2603:1030:c06:1::180/121\"\ + ,\r\n \"2603:1030:f05:1::180/121\",\r\n \"2603:1040:5:1::180/121\"\ + ,\r\n \"2603:1040:407:1::180/121\",\r\n \"2603:1040:904:1::180/121\"\ + ,\r\n \"2603:1040:a06:1::180/121\",\r\n \"2603:1040:d04::180/121\"\ + ,\r\n \"2603:1040:f05:1::180/121\",\r\n \"2603:1050:6:1::180/121\"\ + ,\r\n \"2603:1050:403::180/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureCognitiveSearch.AustraliaCentral\",\r\n\ + \ \"id\": \"AzureCognitiveSearch.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.224.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.AustraliaCentral2\",\r\n \"id\"\ + : \"AzureCognitiveSearch.AustraliaCentral2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.36.120.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.AustraliaEast\",\r\n \"id\": \"\ + AzureCognitiveSearch.AustraliaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.193.192/26\",\r\n \"20.40.123.36/32\",\r\n \"\ + 20.40.123.39/32\",\r\n \"20.40.123.46/32\",\r\n \"20.40.123.72/32\"\ + ,\r\n \"2603:1010:6:1::180/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureCognitiveSearch.AustraliaSoutheast\",\r\n\ + \ \"id\": \"AzureCognitiveSearch.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.42.225.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.BrazilSouth\",\r\n \"id\": \"AzureCognitiveSearch.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \ + \ \"addressPrefixes\": [\r\n \"191.233.26.156/32\",\r\n \ + \ \"191.235.225.64/26\",\r\n \"2603:1050:6:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CanadaCentral\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.139.0.47/32\",\r\n \"52.139.0.49/32\",\r\n \"52.228.81.64/26\"\ + ,\r\n \"2603:1030:f05:1::180/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CanadaEast\",\r\n\ + \ \"id\": \"AzureCognitiveSearch.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.89.17.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.CentralIndia\",\r\n \"id\": \"AzureCognitiveSearch.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.81.253.154/32\",\r\n \ + \ \"52.140.105.64/26\",\r\n \"2603:1040:a06:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CentralUS\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.86.5.51/32\",\r\n \"20.37.156.128/26\",\r\n \"52.158.208.11/32\"\ + ,\r\n \"52.242.214.45/32\",\r\n \"2603:1030:10:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.45.192.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.EastAsia\",\r\n \"id\": \"AzureCognitiveSearch.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"\ + addressPrefixes\": [\r\n \"20.189.106.128/26\",\r\n \"40.81.29.152/32\"\ + ,\r\n \"52.184.80.221/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureCognitiveSearch.EastUS\",\r\n \"id\"\ + : \"AzureCognitiveSearch.EastUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.4.128/26\",\r\n \ + \ \"20.42.24.90/32\",\r\n \"20.42.29.212/32\",\r\n \ + \ \"20.42.30.105/32\",\r\n \"20.42.34.190/32\",\r\n \"\ + 20.42.35.204/32\",\r\n \"20.185.110.199/32\",\r\n \"40.90.240.17/32\"\ + ,\r\n \"52.151.235.150/32\",\r\n \"52.151.235.242/32\",\r\ + \n \"52.151.235.244/32\",\r\n \"52.188.217.235/32\",\r\n\ + \ \"52.188.218.228/32\",\r\n \"52.188.218.239/32\",\r\n\ + \ \"2603:1030:210:1::180/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureCognitiveSearch.EastUS2\",\r\n \"id\"\ + : \"AzureCognitiveSearch.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.4.128/26\",\r\n \ + \ \"20.44.74.182/32\",\r\n \"20.44.76.53/32\",\r\n \ + \ \"20.44.76.61/32\",\r\n \"20.44.76.86/32\",\r\n \"\ + 2603:1030:40c:1::180/121\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureCognitiveSearch.EastUS2EUAP\",\r\n \"id\": \"\ + AzureCognitiveSearch.EastUS2EUAP\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.39.8.192/26\",\r\n \"52.253.229.120/32\",\r\n \"2603:1030:40b:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.FranceCentral\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.43.41.64/26\",\r\n \"40.66.56.233/32\",\r\n \"2603:1020:805:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.FranceSouth\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.105.88.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.GermanyNorth\",\r\n \"id\": \"AzureCognitiveSearch.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"\ + addressPrefixes\": [\r\n \"51.116.48.96/28\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.GermanyWestCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.144.96/28\",\r\n \"2603:1020:c04:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.JapanEast\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.43.65.64/26\",\r\n \"52.140.233.105/32\",\r\n \"\ + 2603:1040:407:1::180/121\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureCognitiveSearch.JapanWest\",\r\n \"id\": \"AzureCognitiveSearch.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"\ + addressPrefixes\": [\r\n \"40.80.57.64/26\",\r\n \"40.81.188.130/32\"\ + ,\r\n \"40.81.191.58/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCognitiveSearch.KoreaCentral\",\r\n \"\ + id\": \"AzureCognitiveSearch.KoreaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.41.65.64/26\",\r\n \"40.82.155.65/32\",\r\n \"2603:1040:f05:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.KoreaSouth\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.80.169.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.NorthCentralUS\",\r\n \"id\": \"\ + AzureCognitiveSearch.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.100.238.27/32\",\r\n \"23.100.238.34/31\",\r\n \"\ + 23.100.238.37/32\",\r\n \"40.80.186.192/26\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorthEurope\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.84.0/26\",\r\n \"52.155.216.245/32\",\r\n \"\ + 52.155.217.84/32\",\r\n \"52.155.221.242/32\",\r\n \"52.155.221.250/32\"\ + ,\r\n \"52.155.222.35/32\",\r\n \"52.155.222.56/32\",\r\n\ + \ \"52.158.28.181/32\",\r\n \"52.158.30.241/32\",\r\n \ + \ \"2603:1020:5:1::180/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureCognitiveSearch.NorwayEast\",\r\n \"\ + id\": \"AzureCognitiveSearch.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.40.128/26\",\r\n \"2603:1020:e04:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.NorwayWest\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.224.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.SouthAfricaNorth\",\r\n \"id\"\ + : \"AzureCognitiveSearch.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"102.133.128.33/32\",\r\n \"102.133.217.128/26\",\r\n \ + \ \"2603:1000:104:1::180/121\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCognitiveSearch.SouthCentralUS\",\r\n \"\ + id\": \"AzureCognitiveSearch.SouthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.45.0.49/32\",\r\n \"20.45.2.122/32\",\r\n \"40.80.216.231/32\"\ + ,\r\n \"40.80.217.38/32\",\r\n \"40.80.219.46/32\",\r\n\ + \ \"40.119.11.0/26\",\r\n \"52.185.224.13/32\",\r\n \ + \ \"52.185.224.38/32\",\r\n \"2603:1030:807:1::180/121\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.43.130.128/26\",\r\n \"40.65.173.157/32\",\r\n \"\ + 40.65.175.212/32\",\r\n \"40.65.175.228/32\",\r\n \"40.90.190.180/32\"\ + ,\r\n \"2603:1040:5:1::180/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureCognitiveSearch.SouthIndia\",\r\n \"\ + id\": \"AzureCognitiveSearch.SouthIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.41.193.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.SwitzerlandNorth\",\r\n \"id\": \"\ + AzureCognitiveSearch.SwitzerlandNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.48.128/26\",\r\n \"2603:1020:a04:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.144.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.UAECentral\",\r\n \"id\": \"AzureCognitiveSearch.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCognitiveSearch\",\r\n \"\ + addressPrefixes\": [\r\n \"20.37.64.128/26\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UAENorth\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.UAENorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.136.128/26\",\r\n \"2603:1040:904:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.UKNorth\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.105.80.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.UKSouth\",\r\n \"id\": \"AzureCognitiveSearch.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.104.25.64/26\",\r\n \"51.132.43.66/32\",\r\n\ + \ \"51.145.124.157/32\",\r\n \"51.145.124.158/32\",\r\n\ + \ \"2603:1020:705:1::180/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureCognitiveSearch.UKSouth2\",\r\n \"\ + id\": \"AzureCognitiveSearch.UKSouth2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.143.192.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.UKWest\",\r\n \"id\": \"AzureCognitiveSearch.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.137.161.64/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureCognitiveSearch.WestCentralUS\",\r\n \ + \ \"id\": \"AzureCognitiveSearch.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.150.139.0/26\",\r\n \"52.253.133.74/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestEurope\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.18.154/32\",\r\n \"40.74.30.0/26\",\r\n \"51.145.176.249/32\"\ + ,\r\n \"51.145.177.212/32\",\r\n \"51.145.178.138/32\",\r\ + \n \"51.145.178.140/32\",\r\n \"52.137.24.236/32\",\r\n\ + \ \"52.137.26.114/32\",\r\n \"52.137.26.155/32\",\r\n \ + \ \"52.137.26.198/32\",\r\n \"52.137.27.49/32\",\r\n \ + \ \"52.137.56.115/32\",\r\n \"52.137.60.208/32\",\r\n \ + \ \"52.157.231.64/32\",\r\n \"104.45.64.0/32\",\r\n \"\ + 104.45.64.147/32\",\r\n \"104.45.64.224/32\",\r\n \"104.45.65.30/32\"\ + ,\r\n \"104.45.65.89/32\",\r\n \"2603:1020:206:1::180/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCognitiveSearch.WestIndia\"\ + ,\r\n \"id\": \"AzureCognitiveSearch.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCognitiveSearch\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.136.48.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCognitiveSearch.WestUS\",\r\n \"id\": \"AzureCognitiveSearch.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCognitiveSearch\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.64.32.141/32\",\r\n \"13.83.22.45/32\",\r\n\ + \ \"13.83.22.74/32\",\r\n \"13.83.22.119/32\",\r\n \ + \ \"20.189.129.94/32\",\r\n \"40.81.9.100/32\",\r\n \ + \ \"40.81.9.131/32\",\r\n \"40.81.9.203/32\",\r\n \"40.81.9.209/32\"\ + ,\r\n \"40.81.9.213/32\",\r\n \"40.81.9.221/32\",\r\n \ + \ \"40.81.10.36/32\",\r\n \"40.81.12.133/32\",\r\n \ + \ \"40.81.15.8/32\",\r\n \"40.81.15.39/32\",\r\n \"40.82.253.0/26\"\ + ,\r\n \"52.157.22.233/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureCognitiveSearch.WestUS2\",\r\n \"id\"\ + : \"AzureCognitiveSearch.WestUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCognitiveSearch\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.129.192/26\",\r\n\ + \ \"40.91.93.84/32\",\r\n \"40.91.127.116/32\",\r\n \ + \ \"40.91.127.241/32\",\r\n \"51.143.104.54/32\",\r\n \ + \ \"51.143.104.90/32\",\r\n \"2603:1030:c06:1::180/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors\"\ + ,\r\n \"id\": \"AzureConnectors\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.65.86.57/32\"\ + ,\r\n \"13.66.140.128/28\",\r\n \"13.66.145.96/27\",\r\n\ + \ \"13.66.210.166/32\",\r\n \"13.66.213.29/32\",\r\n \ + \ \"13.66.213.240/32\",\r\n \"13.66.214.51/32\",\r\n \ + \ \"13.67.8.240/28\",\r\n \"13.67.15.32/27\",\r\n \"\ + 13.69.64.208/28\",\r\n \"13.69.71.192/27\",\r\n \"13.69.227.208/28\"\ + ,\r\n \"13.69.231.192/27\",\r\n \"13.70.72.192/28\",\r\n\ + \ \"13.70.78.224/27\",\r\n \"13.70.82.210/32\",\r\n \ + \ \"13.70.136.174/32\",\r\n \"13.70.187.251/32\",\r\n \ + \ \"13.70.189.7/32\",\r\n \"13.70.191.49/32\",\r\n \"\ + 13.71.125.22/32\",\r\n \"13.71.127.26/32\",\r\n \"13.71.153.19/32\"\ + ,\r\n \"13.71.170.208/28\",\r\n \"13.71.175.160/27\",\r\n\ + \ \"13.71.195.32/28\",\r\n \"13.71.199.192/27\",\r\n \ + \ \"13.72.243.10/32\",\r\n \"13.73.21.230/32\",\r\n \ + \ \"13.73.203.158/32\",\r\n \"13.73.205.35/32\",\r\n \"\ + 13.73.207.42/32\",\r\n \"13.73.244.224/27\",\r\n \"13.75.36.64/28\"\ + ,\r\n \"13.75.89.9/32\",\r\n \"13.75.91.198/32\",\r\n \ + \ \"13.75.92.124/32\",\r\n \"13.75.92.202/32\",\r\n \ + \ \"13.75.110.131/32\",\r\n \"13.76.231.68/32\",\r\n \ + \ \"13.77.7.172/32\",\r\n \"13.77.50.240/28\",\r\n \"13.77.55.160/27\"\ + ,\r\n \"13.78.84.73/32\",\r\n \"13.78.85.193/32\",\r\n \ + \ \"13.78.85.200/32\",\r\n \"13.78.86.229/32\",\r\n \ + \ \"13.78.108.0/28\",\r\n \"13.78.132.82/32\",\r\n \"\ + 13.86.223.32/27\",\r\n \"13.87.56.224/28\",\r\n \"13.87.122.224/28\"\ + ,\r\n \"13.89.171.80/28\",\r\n \"13.89.178.64/27\",\r\n\ + \ \"13.93.148.62/32\",\r\n \"20.36.107.0/28\",\r\n \ + \ \"20.36.114.176/28\",\r\n \"20.36.117.160/27\",\r\n \ + \ \"20.37.74.192/28\",\r\n \"20.38.128.224/27\",\r\n \"\ + 20.43.123.0/27\",\r\n \"20.44.3.0/28\",\r\n \"20.44.29.64/27\"\ + ,\r\n \"20.53.0.0/27\",\r\n \"20.150.170.240/28\",\r\n \ + \ \"20.150.173.64/26\",\r\n \"20.192.32.64/26\",\r\n \ + \ \"20.192.184.32/27\",\r\n \"20.193.206.192/26\",\r\n \ + \ \"23.99.116.181/32\",\r\n \"23.100.208.0/27\",\r\n \ + \ \"40.67.58.240/28\",\r\n \"40.67.60.224/27\",\r\n \"\ + 40.69.42.254/32\",\r\n \"40.69.45.11/32\",\r\n \"40.69.45.93/32\"\ + ,\r\n \"40.69.45.126/32\",\r\n \"40.69.106.240/28\",\r\n\ + \ \"40.69.111.0/27\",\r\n \"40.70.146.208/28\",\r\n \ + \ \"40.70.151.96/27\",\r\n \"40.71.11.80/28\",\r\n \ + \ \"40.71.15.160/27\",\r\n \"40.71.249.139/32\",\r\n \"\ + 40.71.249.205/32\",\r\n \"40.74.100.224/28\",\r\n \"40.74.130.77/32\"\ + ,\r\n \"40.74.146.64/28\",\r\n \"40.78.194.240/28\",\r\n\ + \ \"40.78.202.96/28\",\r\n \"40.79.130.208/28\",\r\n \ + \ \"40.79.148.96/27\",\r\n \"40.79.178.240/28\",\r\n \ + \ \"40.79.180.224/27\",\r\n \"40.79.189.64/27\",\r\n \ + \ \"40.80.180.64/27\",\r\n \"40.89.135.2/32\",\r\n \"40.89.186.239/32\"\ + ,\r\n \"40.91.208.65/32\",\r\n \"40.112.195.87/32\",\r\n\ + \ \"40.112.243.160/28\",\r\n \"40.114.40.132/32\",\r\n \ + \ \"40.115.50.13/32\",\r\n \"40.115.186.96/32\",\r\n \ + \ \"40.117.98.246/32\",\r\n \"40.117.100.191/32\",\r\n \ + \ \"40.117.101.91/32\",\r\n \"40.117.101.120/32\",\r\n \ + \ \"40.120.8.0/27\",\r\n \"40.120.64.64/27\",\r\n \"\ + 40.122.49.51/32\",\r\n \"40.126.251.213/32\",\r\n \"40.127.80.34/32\"\ + ,\r\n \"51.12.98.240/28\",\r\n \"51.12.202.240/28\",\r\n\ + \ \"51.105.77.96/27\",\r\n \"51.107.59.16/28\",\r\n \ + \ \"51.107.60.224/27\",\r\n \"51.107.155.16/28\",\r\n \ + \ \"51.107.156.224/27\",\r\n \"51.116.59.16/28\",\r\n \ + \ \"51.116.60.192/27\",\r\n \"51.116.155.80/28\",\r\n \"\ + 51.116.158.96/27\",\r\n \"51.120.98.224/28\",\r\n \"51.120.100.192/27\"\ + ,\r\n \"51.120.218.240/28\",\r\n \"51.120.220.192/27\",\r\ + \n \"51.140.61.124/32\",\r\n \"51.140.74.150/32\",\r\n \ + \ \"51.140.80.51/32\",\r\n \"51.140.148.0/28\",\r\n \ + \ \"51.140.211.0/28\",\r\n \"51.140.212.224/27\",\r\n \ + \ \"51.141.47.105/32\",\r\n \"51.141.52.185/32\",\r\n \ + \ \"51.141.124.13/32\",\r\n \"52.136.133.184/32\",\r\n \"\ + 52.136.142.154/32\",\r\n \"52.138.92.192/27\",\r\n \"52.141.1.104/32\"\ + ,\r\n \"52.141.36.214/32\",\r\n \"52.160.91.66/32\",\r\n\ + \ \"52.160.92.131/32\",\r\n \"52.160.93.247/32\",\r\n \ + \ \"52.160.95.100/32\",\r\n \"52.161.26.33/32\",\r\n \ + \ \"52.161.26.191/32\",\r\n \"52.161.27.42/32\",\r\n \ + \ \"52.161.29.40/32\",\r\n \"52.161.101.204/32\",\r\n \"\ + 52.161.102.22/32\",\r\n \"52.162.107.160/28\",\r\n \"52.162.111.192/27\"\ + ,\r\n \"52.162.126.4/32\",\r\n \"52.162.242.161/32\",\r\n\ + \ \"52.163.89.40/32\",\r\n \"52.163.89.65/32\",\r\n \ + \ \"52.163.91.227/32\",\r\n \"52.163.95.29/32\",\r\n \ + \ \"52.166.78.89/32\",\r\n \"52.166.241.149/32\",\r\n \ + \ \"52.166.243.169/32\",\r\n \"52.166.244.232/32\",\r\n \ + \ \"52.166.245.173/32\",\r\n \"52.169.28.181/32\",\r\n \"\ + 52.171.130.92/32\",\r\n \"52.172.51.70/32\",\r\n \"52.172.54.172/32\"\ + ,\r\n \"52.172.55.84/32\",\r\n \"52.172.55.107/32\",\r\n\ + \ \"52.172.155.245/32\",\r\n \"52.172.158.2/32\",\r\n \ + \ \"52.172.158.185/32\",\r\n \"52.172.159.100/32\",\r\n \ + \ \"52.172.211.12/32\",\r\n \"52.172.212.129/32\",\r\n \ + \ \"52.173.241.27/32\",\r\n \"52.173.245.164/32\",\r\n \ + \ \"52.174.88.118/32\",\r\n \"52.175.23.169/32\",\r\n \ + \ \"52.178.150.68/32\",\r\n \"52.183.78.157/32\",\r\n \ + \ \"52.187.68.19/32\",\r\n \"52.187.115.69/32\",\r\n \"\ + 52.191.164.250/32\",\r\n \"52.225.129.144/32\",\r\n \"52.228.33.76/32\"\ + ,\r\n \"52.228.34.13/32\",\r\n \"52.228.42.205/32\",\r\n\ + \ \"52.229.120.52/32\",\r\n \"52.229.120.178/32\",\r\n \ + \ \"52.229.123.56/32\",\r\n \"52.229.123.98/32\",\r\n \ + \ \"52.229.126.28/32\",\r\n \"52.229.126.118/32\",\r\n \ + \ \"52.229.126.202/32\",\r\n \"52.231.18.208/28\",\r\n \ + \ \"52.231.147.0/28\",\r\n \"52.231.148.224/27\",\r\n \ + \ \"52.231.163.10/32\",\r\n \"52.231.201.173/32\",\r\n \ + \ \"52.232.130.205/32\",\r\n \"52.232.188.154/32\",\r\n \ + \ \"52.233.29.254/32\",\r\n \"52.233.30.148/32\",\r\n \"\ + 52.233.30.199/32\",\r\n \"52.233.30.222/32\",\r\n \"52.233.31.197/32\"\ + ,\r\n \"52.237.24.126/32\",\r\n \"52.237.32.212/32\",\r\n\ + \ \"52.237.214.72/32\",\r\n \"52.242.30.112/32\",\r\n \ + \ \"52.242.35.152/32\",\r\n \"52.255.48.202/32\",\r\n \ + \ \"65.52.218.230/32\",\r\n \"65.52.250.208/28\",\r\n \ + \ \"94.245.91.93/32\",\r\n \"102.37.64.0/27\",\r\n \"\ + 102.133.27.0/28\",\r\n \"102.133.72.85/32\",\r\n \"102.133.155.0/28\"\ + ,\r\n \"102.133.168.167/32\",\r\n \"102.133.253.0/27\",\r\ + \n \"104.40.51.248/32\",\r\n \"104.41.59.51/32\",\r\n \ + \ \"104.42.122.49/32\",\r\n \"104.43.232.28/32\",\r\n \ + \ \"104.43.232.242/32\",\r\n \"104.43.234.211/32\",\r\n \ + \ \"104.43.235.249/32\",\r\n \"104.45.93.9/32\",\r\n \ + \ \"104.208.233.100/32\",\r\n \"104.209.247.23/32\",\r\n \ + \ \"104.211.81.192/28\",\r\n \"104.211.98.164/32\",\r\n \ + \ \"104.211.146.224/28\",\r\n \"104.211.161.203/32\",\r\n \ + \ \"104.211.189.124/32\",\r\n \"104.211.189.218/32\",\r\n \ + \ \"104.211.227.225/32\",\r\n \"104.214.19.48/28\",\r\n \ + \ \"104.214.70.191/32\",\r\n \"104.214.137.186/32\",\r\n \ + \ \"104.214.138.174/32\",\r\n \"104.214.139.29/32\",\r\n\ + \ \"104.214.140.23/32\",\r\n \"104.214.164.0/27\",\r\n \ + \ \"104.215.27.24/32\",\r\n \"104.215.61.248/32\",\r\n \ + \ \"168.61.140.0/27\",\r\n \"191.232.38.129/32\",\r\n \ + \ \"191.232.191.157/32\",\r\n \"191.233.51.0/26\",\r\n \ + \ \"191.233.203.192/28\",\r\n \"191.233.207.160/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureConnectors.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"20.36.107.0/28\"\ + ,\r\n \"20.53.0.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureConnectors.AustraliaCentral2\",\r\n \"id\":\ + \ \"AzureConnectors.AustraliaCentral2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.176/28\"\ + ,\r\n \"20.36.117.160/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.AustraliaEast\",\r\n \"id\"\ + : \"AzureConnectors.AustraliaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.192/28\"\ + ,\r\n \"13.70.78.224/27\",\r\n \"13.70.82.210/32\",\r\n\ + \ \"13.72.243.10/32\",\r\n \"13.73.203.158/32\",\r\n \ + \ \"13.73.205.35/32\",\r\n \"13.73.207.42/32\",\r\n \ + \ \"40.126.251.213/32\",\r\n \"52.237.214.72/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureConnectors.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.70.136.174/32\"\ + ,\r\n \"13.70.187.251/32\",\r\n \"13.70.189.7/32\",\r\n\ + \ \"13.70.191.49/32\",\r\n \"13.77.7.172/32\",\r\n \ + \ \"13.77.50.240/28\",\r\n \"13.77.55.160/27\",\r\n \ + \ \"40.127.80.34/32\",\r\n \"52.255.48.202/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.BrazilSouth\"\ + ,\r\n \"id\": \"AzureConnectors.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"104.41.59.51/32\"\ + ,\r\n \"191.232.38.129/32\",\r\n \"191.232.191.157/32\"\ + ,\r\n \"191.233.203.192/28\",\r\n \"191.233.207.160/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CanadaCentral\"\ + ,\r\n \"id\": \"AzureConnectors.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.208/28\"\ + ,\r\n \"13.71.175.160/27\",\r\n \"52.228.33.76/32\",\r\n\ + \ \"52.228.34.13/32\",\r\n \"52.228.42.205/32\",\r\n \ + \ \"52.233.29.254/32\",\r\n \"52.233.30.148/32\",\r\n \ + \ \"52.233.30.199/32\",\r\n \"52.233.30.222/32\",\r\n \ + \ \"52.233.31.197/32\",\r\n \"52.237.24.126/32\",\r\n \ + \ \"52.237.32.212/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureConnectors.CanadaEast\",\r\n \"id\": \"AzureConnectors.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.69.106.240/28\",\r\n \"40.69.111.0/27\",\r\n\ + \ \"52.229.120.52/32\",\r\n \"52.229.120.178/32\",\r\n \ + \ \"52.229.123.56/32\",\r\n \"52.229.123.98/32\",\r\n \ + \ \"52.229.126.28/32\",\r\n \"52.229.126.118/32\",\r\n \ + \ \"52.229.126.202/32\",\r\n \"52.232.130.205/32\",\r\n \ + \ \"52.242.30.112/32\",\r\n \"52.242.35.152/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CentralIndia\"\ + ,\r\n \"id\": \"AzureConnectors.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"20.43.123.0/27\"\ + ,\r\n \"52.172.155.245/32\",\r\n \"52.172.158.2/32\",\r\n\ + \ \"52.172.158.185/32\",\r\n \"52.172.159.100/32\",\r\n\ + \ \"52.172.211.12/32\",\r\n \"52.172.212.129/32\",\r\n \ + \ \"104.211.81.192/28\",\r\n \"104.211.98.164/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CentralUS\"\ + ,\r\n \"id\": \"AzureConnectors.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.80/28\"\ + ,\r\n \"13.89.178.64/27\",\r\n \"40.122.49.51/32\",\r\n\ + \ \"52.173.241.27/32\",\r\n \"52.173.245.164/32\",\r\n \ + \ \"104.43.232.28/32\",\r\n \"104.43.232.242/32\",\r\n \ + \ \"104.43.234.211/32\",\r\n \"104.43.235.249/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureConnectors.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.96/28\"\ + ,\r\n \"168.61.140.0/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureConnectors.EastAsia\",\r\n \"id\": \"\ + AzureConnectors.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.75.36.64/28\",\r\n \ + \ \"13.75.89.9/32\",\r\n \"13.75.91.198/32\",\r\n \"\ + 13.75.92.124/32\",\r\n \"13.75.92.202/32\",\r\n \"13.75.110.131/32\"\ + ,\r\n \"23.99.116.181/32\",\r\n \"52.175.23.169/32\",\r\n\ + \ \"104.214.164.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureConnectors.EastUS\",\r\n \"id\": \"AzureConnectors.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.71.11.80/28\",\r\n \"40.71.15.160/27\",\r\n \ + \ \"40.71.249.139/32\",\r\n \"40.71.249.205/32\",\r\n \ + \ \"40.114.40.132/32\",\r\n \"40.117.98.246/32\",\r\n \ + \ \"40.117.100.191/32\",\r\n \"40.117.101.91/32\",\r\n \"\ + 40.117.101.120/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureConnectors.EastUS2\",\r\n \"id\": \"AzureConnectors.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.70.146.208/28\",\r\n \"40.70.151.96/27\",\r\n \ + \ \"52.225.129.144/32\",\r\n \"52.232.188.154/32\",\r\n \ + \ \"104.208.233.100/32\",\r\n \"104.209.247.23/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureConnectors.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.64/28\"\ + ,\r\n \"52.138.92.192/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.FranceCentral\",\r\n \"id\"\ + : \"AzureConnectors.FranceCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"40.79.130.208/28\"\ + ,\r\n \"40.79.148.96/27\",\r\n \"40.89.135.2/32\",\r\n \ + \ \"40.89.186.239/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureConnectors.FranceSouth\",\r\n \"id\": \"AzureConnectors.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"\ + addressPrefixes\": [\r\n \"40.79.178.240/28\",\r\n \"40.79.180.224/27\"\ + ,\r\n \"52.136.133.184/32\",\r\n \"52.136.142.154/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.GermanyNorth\"\ + ,\r\n \"id\": \"AzureConnectors.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.116.59.16/28\"\ + ,\r\n \"51.116.60.192/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.GermanyWestCentral\",\r\n \ + \ \"id\": \"AzureConnectors.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.116.155.80/28\"\ + ,\r\n \"51.116.158.96/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.JapanEast\",\r\n \"id\":\ + \ \"AzureConnectors.JapanEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.153.19/32\",\r\n\ + \ \"13.73.21.230/32\",\r\n \"13.78.84.73/32\",\r\n \ + \ \"13.78.85.193/32\",\r\n \"13.78.85.200/32\",\r\n \ + \ \"13.78.86.229/32\",\r\n \"13.78.108.0/28\",\r\n \"40.79.189.64/27\"\ + ,\r\n \"40.115.186.96/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.JapanWest\",\r\n \"id\":\ + \ \"AzureConnectors.JapanWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.74.100.224/28\",\r\n\ + \ \"40.74.130.77/32\",\r\n \"40.80.180.64/27\",\r\n \ + \ \"104.214.137.186/32\",\r\n \"104.214.138.174/32\",\r\n \ + \ \"104.214.139.29/32\",\r\n \"104.214.140.23/32\",\r\n \ + \ \"104.215.27.24/32\",\r\n \"104.215.61.248/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.KoreaCentral\"\ + ,\r\n \"id\": \"AzureConnectors.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"20.44.29.64/27\"\ + ,\r\n \"52.141.1.104/32\",\r\n \"52.141.36.214/32\",\r\n\ + \ \"52.231.18.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureConnectors.KoreaSouth\",\r\n \"id\": \"AzureConnectors.KoreaSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.231.147.0/28\",\r\n \"52.231.148.224/27\",\r\ + \n \"52.231.163.10/32\",\r\n \"52.231.201.173/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorthCentralUS\"\ + ,\r\n \"id\": \"AzureConnectors.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"52.162.107.160/28\"\ + ,\r\n \"52.162.111.192/27\",\r\n \"52.162.126.4/32\",\r\n\ + \ \"52.162.242.161/32\",\r\n \"65.52.218.230/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorthEurope\"\ + ,\r\n \"id\": \"AzureConnectors.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.69.227.208/28\"\ + ,\r\n \"13.69.231.192/27\",\r\n \"40.69.42.254/32\",\r\n\ + \ \"40.69.45.11/32\",\r\n \"40.69.45.93/32\",\r\n \ + \ \"40.69.45.126/32\",\r\n \"52.169.28.181/32\",\r\n \ + \ \"52.178.150.68/32\",\r\n \"94.245.91.93/32\",\r\n \"\ + 104.45.93.9/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureConnectors.NorwayEast\",\r\n \"id\": \"AzureConnectors.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.98.224/28\",\r\n \"51.120.100.192/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.NorwayWest\"\ + ,\r\n \"id\": \"AzureConnectors.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.240/28\"\ + ,\r\n \"51.120.220.192/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.SouthAfricaNorth\",\r\n \"\ + id\": \"AzureConnectors.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"102.133.155.0/28\"\ + ,\r\n \"102.133.168.167/32\",\r\n \"102.133.253.0/27\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureConnectors.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"102.37.64.0/27\"\ + ,\r\n \"102.133.27.0/28\",\r\n \"102.133.72.85/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureConnectors.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.65.86.57/32\"\ + ,\r\n \"13.73.244.224/27\",\r\n \"52.171.130.92/32\",\r\n\ + \ \"104.214.19.48/28\",\r\n \"104.214.70.191/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureConnectors.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.240/28\"\ + ,\r\n \"13.67.15.32/27\",\r\n \"13.76.231.68/32\",\r\n \ + \ \"52.163.89.40/32\",\r\n \"52.163.89.65/32\",\r\n \ + \ \"52.163.91.227/32\",\r\n \"52.163.95.29/32\",\r\n \ + \ \"52.187.68.19/32\",\r\n \"52.187.115.69/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SouthIndia\"\ + ,\r\n \"id\": \"AzureConnectors.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.71.125.22/32\"\ + ,\r\n \"13.71.127.26/32\",\r\n \"20.192.184.32/27\",\r\n\ + \ \"40.78.194.240/28\",\r\n \"52.172.51.70/32\",\r\n \ + \ \"52.172.54.172/32\",\r\n \"52.172.55.84/32\",\r\n \ + \ \"52.172.55.107/32\",\r\n \"104.211.227.225/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.SwitzerlandNorth\"\ + ,\r\n \"id\": \"AzureConnectors.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.107.59.16/28\"\ + ,\r\n \"51.107.60.224/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.SwitzerlandWest\",\r\n \"\ + id\": \"AzureConnectors.SwitzerlandWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.107.155.16/28\"\ + ,\r\n \"51.107.156.224/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.UAECentral\",\r\n \"id\"\ + : \"AzureConnectors.UAECentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureConnectors\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.37.74.192/28\",\r\n\ + \ \"40.120.8.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureConnectors.UAENorth\",\r\n \"id\": \"AzureConnectors.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.120.64.64/27\",\r\n \"65.52.250.208/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKNorth\"\ + ,\r\n \"id\": \"AzureConnectors.UKNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureConnectors\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.224/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKSouth\"\ + ,\r\n \"id\": \"AzureConnectors.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.105.77.96/27\"\ + ,\r\n \"51.140.61.124/32\",\r\n \"51.140.74.150/32\",\r\n\ + \ \"51.140.80.51/32\",\r\n \"51.140.148.0/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKSouth2\"\ + ,\r\n \"id\": \"AzureConnectors.UKSouth2\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureConnectors\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.56.224/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.UKWest\"\ + ,\r\n \"id\": \"AzureConnectors.UKWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"51.140.211.0/28\"\ + ,\r\n \"51.140.212.224/27\",\r\n \"51.141.47.105/32\",\r\ + \n \"51.141.52.185/32\",\r\n \"51.141.124.13/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestCentralUS\"\ + ,\r\n \"id\": \"AzureConnectors.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.71.195.32/28\"\ + ,\r\n \"13.71.199.192/27\",\r\n \"13.78.132.82/32\",\r\n\ + \ \"52.161.26.33/32\",\r\n \"52.161.26.191/32\",\r\n \ + \ \"52.161.27.42/32\",\r\n \"52.161.29.40/32\",\r\n \ + \ \"52.161.101.204/32\",\r\n \"52.161.102.22/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestEurope\"\ + ,\r\n \"id\": \"AzureConnectors.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.208/28\"\ + ,\r\n \"13.69.71.192/27\",\r\n \"40.91.208.65/32\",\r\n\ + \ \"40.115.50.13/32\",\r\n \"52.166.78.89/32\",\r\n \ + \ \"52.166.241.149/32\",\r\n \"52.166.243.169/32\",\r\n \ + \ \"52.166.244.232/32\",\r\n \"52.166.245.173/32\",\r\n \ + \ \"52.174.88.118/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureConnectors.WestIndia\",\r\n \"id\": \"AzureConnectors.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureConnectors\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.128.224/27\",\r\n \"104.211.146.224/28\"\ + ,\r\n \"104.211.161.203/32\",\r\n \"104.211.189.124/32\"\ + ,\r\n \"104.211.189.218/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureConnectors.WestUS\",\r\n \"id\": \"\ + AzureConnectors.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureConnectors\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.86.223.32/27\",\r\n \ + \ \"13.93.148.62/32\",\r\n \"40.112.195.87/32\",\r\n \"\ + 40.112.243.160/28\",\r\n \"52.160.91.66/32\",\r\n \"52.160.92.131/32\"\ + ,\r\n \"52.160.93.247/32\",\r\n \"52.160.95.100/32\",\r\n\ + \ \"104.40.51.248/32\",\r\n \"104.42.122.49/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureConnectors.WestUS2\"\ + ,\r\n \"id\": \"AzureConnectors.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureConnectors\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.128/28\"\ + ,\r\n \"13.66.145.96/27\",\r\n \"13.66.210.166/32\",\r\n\ + \ \"13.66.213.29/32\",\r\n \"13.66.213.240/32\",\r\n \ + \ \"13.66.214.51/32\",\r\n \"52.183.78.157/32\",\r\n \ + \ \"52.191.164.250/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureContainerRegistry\",\r\n \"id\": \"AzureContainerRegistry\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.140.72/29\",\r\n\ + \ \"13.67.8.120/29\",\r\n \"13.67.14.0/24\",\r\n \ + \ \"13.69.64.88/29\",\r\n \"13.69.106.80/29\",\r\n \"\ + 13.69.110.0/24\",\r\n \"13.69.227.88/29\",\r\n \"13.70.72.136/29\"\ + ,\r\n \"13.70.78.0/25\",\r\n \"13.71.170.56/29\",\r\n \ + \ \"13.71.194.224/29\",\r\n \"13.74.107.80/29\",\r\n \ + \ \"13.74.110.0/24\",\r\n \"13.75.36.0/29\",\r\n \"\ + 13.77.50.80/29\",\r\n \"13.78.106.200/29\",\r\n \"13.78.111.0/25\"\ + ,\r\n \"13.87.56.96/29\",\r\n \"13.87.122.96/29\",\r\n \ + \ \"13.89.170.216/29\",\r\n \"13.89.175.0/25\",\r\n \ + \ \"20.37.74.72/29\",\r\n \"20.38.146.144/29\",\r\n \ + \ \"20.38.149.0/25\",\r\n \"20.43.121.128/26\",\r\n \"20.44.2.24/29\"\ + ,\r\n \"20.44.26.144/29\",\r\n \"20.45.122.144/29\",\r\n\ + \ \"20.45.125.0/25\",\r\n \"20.49.82.16/29\",\r\n \ + \ \"20.49.90.16/29\",\r\n \"20.150.170.24/29\",\r\n \"\ + 20.150.173.128/26\",\r\n \"20.150.178.144/29\",\r\n \"20.150.186.144/29\"\ + ,\r\n \"20.189.169.0/24\",\r\n \"20.192.32.0/26\",\r\n \ + \ \"20.192.98.144/29\",\r\n \"20.192.234.24/29\",\r\n \ + \ \"20.193.202.16/29\",\r\n \"20.193.206.64/26\",\r\n \ + \ \"20.194.66.16/29\",\r\n \"23.98.82.112/29\",\r\n \ + \ \"40.67.58.24/29\",\r\n \"40.67.121.0/25\",\r\n \"40.69.106.80/29\"\ + ,\r\n \"40.69.110.0/25\",\r\n \"40.70.146.88/29\",\r\n \ + \ \"40.70.150.0/24\",\r\n \"40.71.10.216/29\",\r\n \ + \ \"40.74.100.160/29\",\r\n \"40.74.146.48/29\",\r\n \ + \ \"40.74.149.128/25\",\r\n \"40.75.34.32/29\",\r\n \"40.78.194.80/29\"\ + ,\r\n \"40.78.196.192/26\",\r\n \"40.78.202.72/29\",\r\n\ + \ \"40.78.226.208/29\",\r\n \"40.78.231.0/24\",\r\n \ + \ \"40.78.234.48/29\",\r\n \"40.78.242.160/29\",\r\n \ + \ \"40.78.246.0/24\",\r\n \"40.78.250.96/29\",\r\n \"\ + 40.79.130.56/29\",\r\n \"40.79.132.192/26\",\r\n \"40.79.138.32/29\"\ + ,\r\n \"40.79.146.32/29\",\r\n \"40.79.154.104/29\",\r\n\ + \ \"40.79.162.32/29\",\r\n \"40.79.170.0/29\",\r\n \ + \ \"40.79.178.80/29\",\r\n \"40.79.186.8/29\",\r\n \"\ + 40.79.194.96/29\",\r\n \"40.80.50.144/29\",\r\n \"40.80.51.192/26\"\ + ,\r\n \"40.80.176.128/25\",\r\n \"40.112.242.160/29\",\r\ + \n \"40.120.8.64/26\",\r\n \"40.120.74.16/29\",\r\n \ + \ \"51.12.98.24/29\",\r\n \"51.12.100.192/26\",\r\n \ + \ \"51.12.101.0/26\",\r\n \"51.12.202.24/29\",\r\n \"51.12.226.144/29\"\ + ,\r\n \"51.12.234.144/29\",\r\n \"51.104.9.128/25\",\r\n\ + \ \"51.105.66.144/29\",\r\n \"51.105.74.144/29\",\r\n \ + \ \"51.107.56.192/26\",\r\n \"51.107.58.24/29\",\r\n \ + \ \"51.107.152.192/26\",\r\n \"51.107.154.24/29\",\r\n \ + \ \"51.107.192.0/26\",\r\n \"51.116.58.24/29\",\r\n \"\ + 51.116.154.88/29\",\r\n \"51.116.158.128/25\",\r\n \"51.116.242.144/29\"\ + ,\r\n \"51.116.250.144/29\",\r\n \"51.120.98.160/29\",\r\ + \n \"51.120.106.144/29\",\r\n \"51.120.210.144/29\",\r\n\ + \ \"51.120.218.24/29\",\r\n \"51.140.146.200/29\",\r\n \ + \ \"51.140.210.192/29\",\r\n \"51.140.215.0/25\",\r\n \ + \ \"52.138.90.32/29\",\r\n \"52.138.226.80/29\",\r\n \ + \ \"52.162.104.192/26\",\r\n \"52.162.106.160/29\",\r\n \ + \ \"52.167.106.80/29\",\r\n \"52.182.138.208/29\",\r\n \ + \ \"52.231.18.56/29\",\r\n \"52.231.20.128/26\",\r\n \"\ + 52.231.146.192/29\",\r\n \"52.236.186.80/29\",\r\n \"52.246.154.144/29\"\ + ,\r\n \"65.52.248.192/26\",\r\n \"65.52.250.16/29\",\r\n\ + \ \"102.133.26.24/29\",\r\n \"102.133.122.144/29\",\r\n\ + \ \"102.133.154.24/29\",\r\n \"102.133.156.192/26\",\r\n\ + \ \"102.133.250.144/29\",\r\n \"104.46.161.128/25\",\r\n\ + \ \"104.208.16.80/29\",\r\n \"104.208.144.80/29\",\r\n \ + \ \"104.211.81.136/29\",\r\n \"104.211.146.80/29\",\r\n \ + \ \"104.214.18.184/29\",\r\n \"104.214.161.128/25\",\r\n\ + \ \"191.233.50.16/29\",\r\n \"191.233.54.64/26\",\r\n \ + \ \"191.233.54.128/26\",\r\n \"191.233.203.136/29\",\r\n \ + \ \"191.233.205.192/26\",\r\n \"191.234.146.144/29\",\r\n\ + \ \"191.234.154.144/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureContainerRegistry.AustraliaEast\",\r\n \ + \ \"id\": \"AzureContainerRegistry.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.70.72.136/29\",\r\n \"13.70.78.0/25\",\r\n \"\ + 40.79.162.32/29\",\r\n \"40.79.170.0/29\"\r\n ]\r\n }\r\ + \n },\r\n {\r\n \"name\": \"AzureContainerRegistry.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureContainerRegistry.AustraliaSoutheast\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.50.80/29\",\r\n \"104.46.161.128/25\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.BrazilSouth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"191.233.203.136/29\",\r\n \"191.233.205.192/26\",\r\n \ + \ \"191.234.146.144/29\",\r\n \"191.234.154.144/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CanadaCentral\"\ + ,\r\n \"id\": \"AzureContainerRegistry.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.170.56/29\",\r\n \"20.38.146.144/29\",\r\n \ + \ \"20.38.149.0/25\",\r\n \"52.246.154.144/29\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CanadaEast\"\ + ,\r\n \"id\": \"AzureContainerRegistry.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.106.80/29\",\r\n \"40.69.110.0/25\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.CentralIndia\"\ + ,\r\n \"id\": \"AzureContainerRegistry.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.43.121.128/26\",\r\n \"20.192.98.144/29\",\r\n \ + \ \"40.80.50.144/29\",\r\n \"40.80.51.192/26\",\r\n \"\ + 104.211.81.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureContainerRegistry.CentralUS\",\r\n \"id\": \"AzureContainerRegistry.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.89.170.216/29\",\r\n \ + \ \"13.89.175.0/25\",\r\n \"52.182.138.208/29\",\r\n \"\ + 104.208.16.80/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureContainerRegistry.CentralUSEUAP\",\r\n \"id\": \"AzureContainerRegistry.CentralUSEUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.78.202.72/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastAsia\"\ + ,\r\n \"id\": \"AzureContainerRegistry.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.75.36.0/29\",\r\n \"104.214.161.128/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS\"\ + ,\r\n \"id\": \"AzureContainerRegistry.EastUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.71.10.216/29\",\r\n \"40.78.226.208/29\",\r\n \ + \ \"40.78.231.0/24\",\r\n \"40.79.154.104/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS2\"\ + ,\r\n \"id\": \"AzureContainerRegistry.EastUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.70.146.88/29\",\r\n \"40.70.150.0/24\",\r\n \"\ + 52.167.106.80/29\",\r\n \"104.208.144.80/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureContainerRegistry.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.146.48/29\",\r\n \"40.74.149.128/25\",\r\n \ + \ \"40.75.34.32/29\",\r\n \"52.138.90.32/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.FranceCentral\"\ + ,\r\n \"id\": \"AzureContainerRegistry.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.79.130.56/29\",\r\n \"40.79.132.192/26\",\r\n \ + \ \"40.79.138.32/29\",\r\n \"40.79.146.32/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.FranceSouth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.79.178.80/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureContainerRegistry.GermanyNorth\",\r\n \"id\": \"\ + AzureContainerRegistry.GermanyNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.116.58.24/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureContainerRegistry.GermanyWestCentral\",\r\n \"id\": \"AzureContainerRegistry.GermanyWestCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureContainerRegistry\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.116.154.88/29\",\r\n \ + \ \"51.116.158.128/26\",\r\n \"51.116.158.192/26\",\r\n \ + \ \"51.116.242.144/29\",\r\n \"51.116.250.144/29\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.JapanEast\"\ + ,\r\n \"id\": \"AzureContainerRegistry.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.78.106.200/29\",\r\n \"13.78.111.0/25\",\r\n \"\ + 40.79.186.8/29\",\r\n \"40.79.194.96/29\"\r\n ]\r\n }\r\ + \n },\r\n {\r\n \"name\": \"AzureContainerRegistry.JapanWest\"\ + ,\r\n \"id\": \"AzureContainerRegistry.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.100.160/29\",\r\n \"40.80.176.128/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.KoreaCentral\"\ + ,\r\n \"id\": \"AzureContainerRegistry.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.44.26.144/29\",\r\n \"20.194.66.16/29\",\r\n \"\ + 52.231.18.56/29\",\r\n \"52.231.20.128/26\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.KoreaSouth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.231.146.192/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureContainerRegistry.NorthCentralUS\",\r\n \"id\"\ + : \"AzureContainerRegistry.NorthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.162.104.192/26\",\r\n \"52.162.106.160/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.NorthEurope\"\ + ,\r\n \"id\": \"AzureContainerRegistry.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.227.88/29\",\r\n \"13.74.107.80/29\",\r\n \"\ + 13.74.110.0/24\",\r\n \"52.138.226.80/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.NorwayEast\"\ + ,\r\n \"id\": \"AzureContainerRegistry.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.98.160/29\",\r\n \"51.120.106.144/29\",\r\n \ + \ \"51.120.210.144/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureContainerRegistry.NorwayWest\",\r\n \"id\": \"\ + AzureContainerRegistry.NorwayWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.218.24/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthAfricaNorth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SouthAfricaNorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.122.144/29\",\r\n \"102.133.154.24/29\"\ + ,\r\n \"102.133.156.192/26\",\r\n \"102.133.250.144/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SouthAfricaWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.26.24/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureContainerRegistry.SouthCentralUS\",\r\n \ + \ \"id\": \"AzureContainerRegistry.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.45.122.144/29\",\r\n \"20.45.125.0/25\",\r\n \"\ + 20.49.90.16/29\",\r\n \"104.214.18.184/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.8.120/29\",\r\n \"13.67.14.0/25\",\r\n \"13.67.14.128/25\"\ + ,\r\n \"23.98.82.112/29\",\r\n \"40.78.234.48/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SouthIndia\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.78.194.80/29\",\r\n \"40.78.196.192/26\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SwitzerlandNorth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SwitzerlandNorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.56.192/26\",\r\n \"51.107.58.24/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureContainerRegistry.SwitzerlandWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.152.192/26\",\r\n \"51.107.154.24/29\"\ + ,\r\n \"51.107.192.0/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureContainerRegistry.UAECentral\",\r\n \"\ + id\": \"AzureContainerRegistry.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.74.72/29\",\r\n \"40.120.8.64/26\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UAENorth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.UAENorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.120.74.16/29\",\r\n \"65.52.248.192/26\",\r\n \ + \ \"65.52.250.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureContainerRegistry.UKNorth\",\r\n \"id\": \"AzureContainerRegistry.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.96/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UKSouth\"\ + ,\r\n \"id\": \"AzureContainerRegistry.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.104.9.128/25\",\r\n \"51.105.66.144/29\",\r\n \ + \ \"51.105.74.144/29\",\r\n \"51.140.146.200/29\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UKSouth2\"\ + ,\r\n \"id\": \"AzureContainerRegistry.UKSouth2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.56.96/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.UKWest\"\ + ,\r\n \"id\": \"AzureContainerRegistry.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.140.210.192/29\",\r\n \"51.140.215.0/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestCentralUS\"\ + ,\r\n \"id\": \"AzureContainerRegistry.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.194.224/29\",\r\n \"40.67.121.0/25\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestEurope\"\ + ,\r\n \"id\": \"AzureContainerRegistry.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.64.88/29\",\r\n \"13.69.106.80/29\",\r\n \"\ + 13.69.110.0/24\",\r\n \"52.236.186.80/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestIndia\"\ + ,\r\n \"id\": \"AzureContainerRegistry.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"104.211.146.80/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureContainerRegistry.WestUS\",\r\n \"id\": \"AzureContainerRegistry.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.189.169.0/24\",\r\n \"40.112.242.160/29\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureContainerRegistry.WestUS2\"\ + ,\r\n \"id\": \"AzureContainerRegistry.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.140.72/29\",\r\n \"40.78.242.160/29\",\r\n \ + \ \"40.78.246.0/24\",\r\n \"40.78.250.96/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB\",\r\n \"\ + id\": \"AzureCosmosDB\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.64.69.151/32\"\ + ,\r\n \"13.64.113.68/32\",\r\n \"13.64.114.48/32\",\r\n\ + \ \"13.64.194.140/32\",\r\n \"13.65.145.92/32\",\r\n \ + \ \"13.66.26.107/32\",\r\n \"13.66.138.0/26\",\r\n \ + \ \"13.67.8.0/26\",\r\n \"13.68.28.135/32\",\r\n \"13.69.66.0/25\"\ + ,\r\n \"13.69.66.128/29\",\r\n \"13.69.112.0/25\",\r\n \ + \ \"13.69.226.0/25\",\r\n \"13.70.74.136/29\",\r\n \ + \ \"13.71.115.125/32\",\r\n \"13.71.124.81/32\",\r\n \ + \ \"13.71.170.0/28\",\r\n \"13.71.194.0/26\",\r\n \"13.72.255.150/32\"\ + ,\r\n \"13.73.100.183/32\",\r\n \"13.74.106.0/25\",\r\n\ + \ \"13.75.34.0/26\",\r\n \"13.75.134.84/32\",\r\n \ + \ \"13.76.161.130/32\",\r\n \"13.77.50.0/28\",\r\n \"\ + 13.78.51.35/32\",\r\n \"13.78.106.0/26\",\r\n \"13.78.188.25/32\"\ + ,\r\n \"13.79.34.236/32\",\r\n \"13.81.51.99/32\",\r\n \ + \ \"13.82.53.191/32\",\r\n \"13.84.150.178/32\",\r\n \ + \ \"13.84.157.70/32\",\r\n \"13.85.16.188/32\",\r\n \ + \ \"13.87.56.0/27\",\r\n \"13.87.122.0/27\",\r\n \"13.88.30.39/32\"\ + ,\r\n \"13.88.253.180/32\",\r\n \"13.89.41.245/32\",\r\n\ + \ \"13.89.170.0/25\",\r\n \"13.89.190.186/32\",\r\n \ + \ \"13.89.224.229/32\",\r\n \"13.90.199.155/32\",\r\n \ + \ \"13.91.246.52/32\",\r\n \"13.93.153.80/32\",\r\n \"\ + 13.93.156.125/32\",\r\n \"13.93.207.66/32\",\r\n \"13.94.201.5/32\"\ + ,\r\n \"13.95.234.68/32\",\r\n \"20.36.26.132/32\",\r\n\ + \ \"20.36.42.8/32\",\r\n \"20.36.75.163/32\",\r\n \ + \ \"20.36.106.0/26\",\r\n \"20.36.114.0/28\",\r\n \"\ + 20.37.75.128/26\",\r\n \"20.38.146.0/26\",\r\n \"20.44.2.64/26\"\ + ,\r\n \"20.44.10.0/26\",\r\n \"20.44.26.0/26\",\r\n \ + \ \"20.45.122.0/26\",\r\n \"20.49.82.64/26\",\r\n \"\ + 20.49.90.64/26\",\r\n \"20.150.170.64/26\",\r\n \"20.150.178.0/26\"\ + ,\r\n \"20.150.186.0/26\",\r\n \"20.192.98.0/26\",\r\n \ + \ \"20.192.234.64/26\",\r\n \"20.193.202.64/26\",\r\n \ + \ \"20.194.66.64/26\",\r\n \"23.96.180.213/32\",\r\n \ + \ \"23.96.219.207/32\",\r\n \"23.96.242.234/32\",\r\n \ + \ \"23.98.82.0/26\",\r\n \"23.102.191.13/32\",\r\n \"23.102.239.134/32\"\ + ,\r\n \"40.65.106.154/32\",\r\n \"40.65.114.105/32\",\r\n\ + \ \"40.67.58.64/26\",\r\n \"40.68.44.85/32\",\r\n \ + \ \"40.69.106.0/28\",\r\n \"40.70.0.140/32\",\r\n \"\ + 40.70.220.202/32\",\r\n \"40.71.10.0/25\",\r\n \"40.71.17.19/32\"\ + ,\r\n \"40.71.203.37/32\",\r\n \"40.71.204.115/32\",\r\n\ + \ \"40.71.216.114/32\",\r\n \"40.74.98.0/26\",\r\n \ + \ \"40.74.143.235/32\",\r\n \"40.74.147.192/26\",\r\n \ + \ \"40.75.32.32/29\",\r\n \"40.75.34.128/26\",\r\n \"\ + 40.77.63.179/32\",\r\n \"40.78.194.0/28\",\r\n \"40.78.203.32/27\"\ + ,\r\n \"40.78.226.0/25\",\r\n \"40.78.236.192/26\",\r\n\ + \ \"40.78.243.192/26\",\r\n \"40.78.250.0/26\",\r\n \ + \ \"40.79.39.162/32\",\r\n \"40.79.59.92/32\",\r\n \ + \ \"40.79.67.136/32\",\r\n \"40.79.130.0/28\",\r\n \"40.79.138.48/28\"\ + ,\r\n \"40.79.146.48/28\",\r\n \"40.79.154.128/26\",\r\n\ + \ \"40.79.163.72/29\",\r\n \"40.79.163.192/26\",\r\n \ + \ \"40.79.170.48/28\",\r\n \"40.79.178.0/28\",\r\n \ + \ \"40.79.186.16/28\",\r\n \"40.79.194.128/26\",\r\n \"\ + 40.80.50.0/26\",\r\n \"40.83.137.191/32\",\r\n \"40.85.178.211/32\"\ + ,\r\n \"40.86.229.245/32\",\r\n \"40.89.67.208/32\",\r\n\ + \ \"40.89.132.238/32\",\r\n \"40.112.140.12/32\",\r\n \ + \ \"40.112.241.0/24\",\r\n \"40.112.249.60/32\",\r\n \ + \ \"40.113.90.91/32\",\r\n \"40.114.240.253/32\",\r\n \ + \ \"40.115.241.37/32\",\r\n \"40.118.245.44/32\",\r\n \ + \ \"40.118.245.251/32\",\r\n \"40.120.74.64/26\",\r\n \"\ + 40.122.132.89/32\",\r\n \"40.122.174.140/32\",\r\n \"40.126.244.209/32\"\ + ,\r\n \"51.12.98.64/26\",\r\n \"51.12.202.64/26\",\r\n \ + \ \"51.12.226.0/26\",\r\n \"51.12.234.0/26\",\r\n \ + \ \"51.105.66.0/26\",\r\n \"51.105.74.0/26\",\r\n \"51.107.58.64/26\"\ + ,\r\n \"51.107.154.64/26\",\r\n \"51.116.58.64/26\",\r\n\ + \ \"51.116.154.128/26\",\r\n \"51.116.242.0/26\",\r\n \ + \ \"51.116.250.0/26\",\r\n \"51.120.98.64/26\",\r\n \ + \ \"51.120.106.0/26\",\r\n \"51.120.210.0/26\",\r\n \"\ + 51.120.218.64/26\",\r\n \"51.140.52.73/32\",\r\n \"51.140.70.75/32\"\ + ,\r\n \"51.140.75.146/32\",\r\n \"51.140.83.56/32\",\r\n\ + \ \"51.140.99.233/32\",\r\n \"51.140.146.0/27\",\r\n \ + \ \"51.140.210.0/27\",\r\n \"51.141.11.34/32\",\r\n \ + \ \"51.141.25.77/32\",\r\n \"51.141.53.76/32\",\r\n \"\ + 51.141.55.229/32\",\r\n \"51.143.189.37/32\",\r\n \"51.144.177.166/32\"\ + ,\r\n \"51.144.182.233/32\",\r\n \"52.136.134.25/32\",\r\ + \n \"52.136.134.250/32\",\r\n \"52.136.136.70/32\",\r\n\ + \ \"52.138.66.90/32\",\r\n \"52.138.70.62/32\",\r\n \ + \ \"52.138.92.0/26\",\r\n \"52.138.141.112/32\",\r\n \ + \ \"52.138.197.33/32\",\r\n \"52.138.201.47/32\",\r\n \ + \ \"52.138.205.97/32\",\r\n \"52.138.206.153/32\",\r\n \"\ + 52.138.227.192/26\",\r\n \"52.143.136.41/32\",\r\n \"52.151.16.118/32\"\ + ,\r\n \"52.156.170.104/32\",\r\n \"52.158.234.203/32\",\r\ + \n \"52.161.13.67/32\",\r\n \"52.161.15.197/32\",\r\n \ + \ \"52.161.22.131/32\",\r\n \"52.161.100.126/32\",\r\n \ + \ \"52.162.106.0/26\",\r\n \"52.162.252.26/32\",\r\n \ + \ \"52.163.63.20/32\",\r\n \"52.163.249.82/32\",\r\n \ + \ \"52.164.250.188/32\",\r\n \"52.165.42.204/32\",\r\n \"\ + 52.165.46.249/32\",\r\n \"52.165.129.184/32\",\r\n \"52.165.229.112/32\"\ + ,\r\n \"52.165.229.184/32\",\r\n \"52.167.107.128/26\",\r\ + \n \"52.168.28.222/32\",\r\n \"52.169.122.37/32\",\r\n \ + \ \"52.169.219.183/32\",\r\n \"52.170.204.83/32\",\r\n \ + \ \"52.172.55.127/32\",\r\n \"52.172.206.130/32\",\r\n \ + \ \"52.173.148.217/32\",\r\n \"52.173.196.170/32\",\r\n \ + \ \"52.173.240.244/32\",\r\n \"52.174.253.239/32\",\r\n \ + \ \"52.175.25.211/32\",\r\n \"52.175.39.232/32\",\r\n \ + \ \"52.176.0.136/32\",\r\n \"52.176.7.71/32\",\r\n \"\ + 52.176.101.49/32\",\r\n \"52.176.155.127/32\",\r\n \"52.177.172.74/32\"\ + ,\r\n \"52.177.206.153/32\",\r\n \"52.178.108.222/32\",\r\ + \n \"52.179.141.33/32\",\r\n \"52.179.143.233/32\",\r\n\ + \ \"52.179.200.0/25\",\r\n \"52.180.160.251/32\",\r\n \ + \ \"52.180.161.1/32\",\r\n \"52.180.177.137/32\",\r\n \ + \ \"52.182.138.0/25\",\r\n \"52.183.42.252/32\",\r\n \ + \ \"52.183.66.36/32\",\r\n \"52.183.92.223/32\",\r\n \"\ + 52.183.119.101/32\",\r\n \"52.184.152.241/32\",\r\n \"52.186.69.224/32\"\ + ,\r\n \"52.187.11.8/32\",\r\n \"52.187.12.93/32\",\r\n \ + \ \"52.191.197.220/32\",\r\n \"52.226.18.140/32\",\r\n \ + \ \"52.226.21.178/32\",\r\n \"52.230.15.63/32\",\r\n \ + \ \"52.230.23.170/32\",\r\n \"52.230.70.94/32\",\r\n \ + \ \"52.230.87.21/32\",\r\n \"52.231.18.0/28\",\r\n \"52.231.25.123/32\"\ + ,\r\n \"52.231.39.143/32\",\r\n \"52.231.56.0/28\",\r\n\ + \ \"52.231.146.0/27\",\r\n \"52.231.206.234/32\",\r\n \ + \ \"52.231.207.31/32\",\r\n \"52.232.59.220/32\",\r\n \ + \ \"52.233.41.60/32\",\r\n \"52.233.128.86/32\",\r\n \ + \ \"52.235.40.247/32\",\r\n \"52.235.46.28/32\",\r\n \"\ + 52.236.189.0/26\",\r\n \"52.237.20.252/32\",\r\n \"52.246.154.0/26\"\ + ,\r\n \"52.255.52.19/32\",\r\n \"52.255.58.221/32\",\r\n\ + \ \"65.52.210.9/32\",\r\n \"65.52.251.128/26\",\r\n \ + \ \"102.133.26.64/26\",\r\n \"102.133.122.0/26\",\r\n \ + \ \"102.133.154.64/26\",\r\n \"102.133.250.0/26\",\r\n \ + \ \"104.41.52.61/32\",\r\n \"104.41.54.69/32\",\r\n \"\ + 104.41.177.93/32\",\r\n \"104.45.16.183/32\",\r\n \"104.45.131.193/32\"\ + ,\r\n \"104.45.144.73/32\",\r\n \"104.208.231.0/25\",\r\n\ + \ \"104.210.89.99/32\",\r\n \"104.210.217.251/32\",\r\n\ + \ \"104.211.84.0/28\",\r\n \"104.211.102.50/32\",\r\n \ + \ \"104.211.146.0/28\",\r\n \"104.211.162.94/32\",\r\n \ + \ \"104.211.184.117/32\",\r\n \"104.211.188.174/32\",\r\n \ + \ \"104.211.227.84/32\",\r\n \"104.214.18.0/25\",\r\n \ + \ \"104.214.23.192/27\",\r\n \"104.214.26.177/32\",\r\n \ + \ \"104.215.1.53/32\",\r\n \"104.215.21.39/32\",\r\n \ + \ \"104.215.55.227/32\",\r\n \"137.117.9.157/32\",\r\n \ + \ \"157.55.170.133/32\",\r\n \"191.232.51.175/32\",\r\n \ + \ \"191.232.53.203/32\",\r\n \"191.233.50.64/26\",\r\n \ + \ \"191.233.204.128/27\",\r\n \"191.234.146.0/26\",\r\n \ + \ \"191.234.154.0/26\",\r\n \"191.234.179.157/32\",\r\n \ + \ \"191.239.179.124/32\",\r\n \"207.46.150.252/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureCosmosDB.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"20.36.42.8/32\"\ + ,\r\n \"20.36.106.0/26\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCosmosDB.AustraliaCentral2\",\r\n \"id\"\ + : \"AzureCosmosDB.AustraliaCentral2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"20.36.75.163/32\"\ + ,\r\n \"20.36.114.0/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCosmosDB.AustraliaEast\",\r\n \"id\":\ + \ \"AzureCosmosDB.AustraliaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.74.136/29\",\r\n\ + \ \"13.72.255.150/32\",\r\n \"13.75.134.84/32\",\r\n \ + \ \"40.79.163.72/29\",\r\n \"40.79.163.192/26\",\r\n \ + \ \"40.79.170.48/28\",\r\n \"40.126.244.209/32\",\r\n \ + \ \"52.156.170.104/32\",\r\n \"104.210.89.99/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureCosmosDB.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.73.100.183/32\"\ + ,\r\n \"13.77.50.0/28\",\r\n \"52.255.52.19/32\",\r\n \ + \ \"52.255.58.221/32\",\r\n \"191.239.179.124/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.BrazilSouth\"\ + ,\r\n \"id\": \"AzureCosmosDB.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"104.41.52.61/32\"\ + ,\r\n \"104.41.54.69/32\",\r\n \"191.232.51.175/32\",\r\n\ + \ \"191.232.53.203/32\",\r\n \"191.233.204.128/27\",\r\n\ + \ \"191.234.146.0/26\",\r\n \"191.234.154.0/26\",\r\n \ + \ \"191.234.179.157/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.CanadaCentral\",\r\n \"id\": \"AzureCosmosDB.CanadaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"\ + addressPrefixes\": [\r\n \"13.71.170.0/28\",\r\n \"13.88.253.180/32\"\ + ,\r\n \"20.38.146.0/26\",\r\n \"52.233.41.60/32\",\r\n \ + \ \"52.237.20.252/32\",\r\n \"52.246.154.0/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.CanadaEast\"\ + ,\r\n \"id\": \"AzureCosmosDB.CanadaEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.0/28\"\ + ,\r\n \"40.86.229.245/32\",\r\n \"52.235.40.247/32\",\r\n\ + \ \"52.235.46.28/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.CentralIndia\",\r\n \"id\": \"AzureCosmosDB.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"\ + addressPrefixes\": [\r\n \"20.192.98.0/26\",\r\n \"40.80.50.0/26\"\ + ,\r\n \"52.172.206.130/32\",\r\n \"104.211.84.0/28\",\r\n\ + \ \"104.211.102.50/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCosmosDB.CentralUS\",\r\n \"id\": \"AzureCosmosDB.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.89.41.245/32\",\r\n \"13.89.170.0/25\",\r\n\ + \ \"13.89.190.186/32\",\r\n \"13.89.224.229/32\",\r\n \ + \ \"20.44.10.0/26\",\r\n \"40.77.63.179/32\",\r\n \ + \ \"40.122.132.89/32\",\r\n \"40.122.174.140/32\",\r\n \ + \ \"52.165.42.204/32\",\r\n \"52.165.46.249/32\",\r\n \"\ + 52.165.129.184/32\",\r\n \"52.165.229.112/32\",\r\n \"52.165.229.184/32\"\ + ,\r\n \"52.173.148.217/32\",\r\n \"52.173.196.170/32\",\r\ + \n \"52.173.240.244/32\",\r\n \"52.176.0.136/32\",\r\n \ + \ \"52.176.7.71/32\",\r\n \"52.176.101.49/32\",\r\n \ + \ \"52.176.155.127/32\",\r\n \"52.182.138.0/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureCosmosDB.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"40.78.203.32/27\"\ + ,\r\n \"52.180.160.251/32\",\r\n \"52.180.161.1/32\",\r\n\ + \ \"52.180.177.137/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureCosmosDB.EastAsia\",\r\n \"id\": \"AzureCosmosDB.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.75.34.0/26\",\r\n \"23.102.239.134/32\",\r\n\ + \ \"52.175.25.211/32\",\r\n \"52.175.39.232/32\",\r\n \ + \ \"207.46.150.252/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.EastUS\",\r\n \"id\": \"AzureCosmosDB.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.82.53.191/32\",\r\n \"13.90.199.155/32\",\r\n \ + \ \"40.71.10.0/25\",\r\n \"40.71.17.19/32\",\r\n \"\ + 40.71.203.37/32\",\r\n \"40.71.204.115/32\",\r\n \"40.71.216.114/32\"\ + ,\r\n \"40.78.226.0/25\",\r\n \"40.79.154.128/26\",\r\n\ + \ \"40.85.178.211/32\",\r\n \"52.168.28.222/32\",\r\n \ + \ \"52.170.204.83/32\",\r\n \"52.186.69.224/32\",\r\n \ + \ \"52.191.197.220/32\",\r\n \"52.226.18.140/32\",\r\n \ + \ \"52.226.21.178/32\",\r\n \"104.45.131.193/32\",\r\n \ + \ \"104.45.144.73/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCosmosDB.EastUS2\",\r\n \"id\": \"AzureCosmosDB.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.68.28.135/32\",\r\n \"40.70.0.140/32\",\r\n \ + \ \"40.70.220.202/32\",\r\n \"40.79.39.162/32\",\r\n \ + \ \"40.79.59.92/32\",\r\n \"40.79.67.136/32\",\r\n \"52.167.107.128/26\"\ + ,\r\n \"52.177.172.74/32\",\r\n \"52.177.206.153/32\",\r\ + \n \"52.179.141.33/32\",\r\n \"52.179.143.233/32\",\r\n\ + \ \"52.179.200.0/25\",\r\n \"52.184.152.241/32\",\r\n \ + \ \"104.208.231.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.EastUS2EUAP\",\r\n \"id\": \"AzureCosmosDB.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.147.192/26\",\r\n \"40.75.32.32/29\",\r\n\ + \ \"40.75.34.128/26\",\r\n \"40.89.67.208/32\",\r\n \ + \ \"52.138.66.90/32\",\r\n \"52.138.70.62/32\",\r\n \ + \ \"52.138.92.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureCosmosDB.FranceCentral\",\r\n \"id\": \"AzureCosmosDB.FranceCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"\ + addressPrefixes\": [\r\n \"40.79.130.0/28\",\r\n \"40.79.138.48/28\"\ + ,\r\n \"40.79.146.48/28\",\r\n \"40.89.132.238/32\",\r\n\ + \ \"52.143.136.41/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.FranceSouth\",\r\n \"id\": \"AzureCosmosDB.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.79.178.0/28\",\r\n \"52.136.134.25/32\",\r\n\ + \ \"52.136.134.250/32\",\r\n \"52.136.136.70/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.GermanyNorth\"\ + ,\r\n \"id\": \"AzureCosmosDB.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.116.58.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureCosmosDB.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.116.154.128/26\"\ + ,\r\n \"51.116.242.0/26\",\r\n \"51.116.250.0/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.JapanEast\"\ + ,\r\n \"id\": \"AzureCosmosDB.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.78.51.35/32\"\ + ,\r\n \"13.78.106.0/26\",\r\n \"40.79.186.16/28\",\r\n \ + \ \"40.79.194.128/26\",\r\n \"40.115.241.37/32\",\r\n \ + \ \"104.41.177.93/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureCosmosDB.JapanWest\",\r\n \"id\": \"AzureCosmosDB.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.98.0/26\",\r\n \"40.74.143.235/32\",\r\n\ + \ \"104.215.1.53/32\",\r\n \"104.215.21.39/32\",\r\n \ + \ \"104.215.55.227/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.KoreaCentral\",\r\n \"id\": \"AzureCosmosDB.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"\ + addressPrefixes\": [\r\n \"20.44.26.0/26\",\r\n \"20.194.66.64/26\"\ + ,\r\n \"52.231.18.0/28\",\r\n \"52.231.25.123/32\",\r\n\ + \ \"52.231.39.143/32\",\r\n \"52.231.56.0/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.KoreaSouth\"\ + ,\r\n \"id\": \"AzureCosmosDB.KoreaSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"52.231.146.0/27\"\ + ,\r\n \"52.231.206.234/32\",\r\n \"52.231.207.31/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorthCentralUS\"\ + ,\r\n \"id\": \"AzureCosmosDB.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"23.96.180.213/32\"\ + ,\r\n \"23.96.219.207/32\",\r\n \"23.96.242.234/32\",\r\n\ + \ \"52.162.106.0/26\",\r\n \"52.162.252.26/32\",\r\n \ + \ \"65.52.210.9/32\",\r\n \"157.55.170.133/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorthEurope\"\ + ,\r\n \"id\": \"AzureCosmosDB.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.69.226.0/25\"\ + ,\r\n \"13.74.106.0/25\",\r\n \"13.79.34.236/32\",\r\n \ + \ \"40.113.90.91/32\",\r\n \"52.138.141.112/32\",\r\n \ + \ \"52.138.197.33/32\",\r\n \"52.138.201.47/32\",\r\n \ + \ \"52.138.205.97/32\",\r\n \"52.138.206.153/32\",\r\n \ + \ \"52.138.227.192/26\",\r\n \"52.164.250.188/32\",\r\n \ + \ \"52.169.122.37/32\",\r\n \"52.169.219.183/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorwayEast\"\ + ,\r\n \"id\": \"AzureCosmosDB.NorwayEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.120.98.64/26\"\ + ,\r\n \"51.120.106.0/26\",\r\n \"51.120.210.0/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.NorwayWest\"\ + ,\r\n \"id\": \"AzureCosmosDB.NorwayWest\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.120.218.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthAfricaNorth\"\ + ,\r\n \"id\": \"AzureCosmosDB.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"102.133.122.0/26\"\ + ,\r\n \"102.133.154.64/26\",\r\n \"102.133.250.0/26\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureCosmosDB.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureCosmosDB.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.65.145.92/32\"\ + ,\r\n \"13.66.26.107/32\",\r\n \"13.84.150.178/32\",\r\n\ + \ \"13.84.157.70/32\",\r\n \"13.85.16.188/32\",\r\n \ + \ \"20.45.122.0/26\",\r\n \"20.49.90.64/26\",\r\n \"\ + 23.102.191.13/32\",\r\n \"104.210.217.251/32\",\r\n \"104.214.18.0/25\"\ + ,\r\n \"104.214.23.192/27\",\r\n \"104.214.26.177/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureCosmosDB.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.67.8.0/26\"\ + ,\r\n \"13.76.161.130/32\",\r\n \"23.98.82.0/26\",\r\n \ + \ \"40.78.236.192/26\",\r\n \"52.163.63.20/32\",\r\n \ + \ \"52.163.249.82/32\",\r\n \"52.187.11.8/32\",\r\n \ + \ \"52.187.12.93/32\",\r\n \"52.230.15.63/32\",\r\n \"\ + 52.230.23.170/32\",\r\n \"52.230.70.94/32\",\r\n \"52.230.87.21/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SouthIndia\"\ + ,\r\n \"id\": \"AzureCosmosDB.SouthIndia\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.71.115.125/32\"\ + ,\r\n \"13.71.124.81/32\",\r\n \"40.78.194.0/28\",\r\n \ + \ \"52.172.55.127/32\",\r\n \"104.211.227.84/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SwitzerlandNorth\"\ + ,\r\n \"id\": \"AzureCosmosDB.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.107.58.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureCosmosDB.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.107.154.64/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UAECentral\"\ + ,\r\n \"id\": \"AzureCosmosDB.UAECentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"20.37.75.128/26\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UAENorth\"\ + ,\r\n \"id\": \"AzureCosmosDB.UAENorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.64/26\"\ + ,\r\n \"65.52.251.128/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureCosmosDB.UKNorth\",\r\n \"id\": \"AzureCosmosDB.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKSouth\"\ + ,\r\n \"id\": \"AzureCosmosDB.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.105.66.0/26\"\ + ,\r\n \"51.105.74.0/26\",\r\n \"51.140.52.73/32\",\r\n \ + \ \"51.140.70.75/32\",\r\n \"51.140.75.146/32\",\r\n \ + \ \"51.140.83.56/32\",\r\n \"51.140.99.233/32\",\r\n \ + \ \"51.140.146.0/27\",\r\n \"51.143.189.37/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKSouth2\"\ + ,\r\n \"id\": \"AzureCosmosDB.UKSouth2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureCosmosDB\",\r\ + \n \"addressPrefixes\": [\r\n \"13.87.56.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.UKWest\"\ + ,\r\n \"id\": \"AzureCosmosDB.UKWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"51.140.210.0/27\"\ + ,\r\n \"51.141.11.34/32\",\r\n \"51.141.25.77/32\",\r\n\ + \ \"51.141.53.76/32\",\r\n \"51.141.55.229/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestCentralUS\"\ + ,\r\n \"id\": \"AzureCosmosDB.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.71.194.0/26\"\ + ,\r\n \"13.78.188.25/32\",\r\n \"52.161.13.67/32\",\r\n\ + \ \"52.161.15.197/32\",\r\n \"52.161.22.131/32\",\r\n \ + \ \"52.161.100.126/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureCosmosDB.WestEurope\",\r\n \"id\": \"AzureCosmosDB.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.66.0/25\",\r\n \"13.69.66.128/29\",\r\n\ + \ \"13.69.112.0/25\",\r\n \"13.81.51.99/32\",\r\n \ + \ \"13.94.201.5/32\",\r\n \"13.95.234.68/32\",\r\n \"\ + 40.68.44.85/32\",\r\n \"40.114.240.253/32\",\r\n \"51.144.177.166/32\"\ + ,\r\n \"51.144.182.233/32\",\r\n \"52.174.253.239/32\",\r\ + \n \"52.178.108.222/32\",\r\n \"52.232.59.220/32\",\r\n\ + \ \"52.233.128.86/32\",\r\n \"52.236.189.0/26\",\r\n \ + \ \"104.45.16.183/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureCosmosDB.WestIndia\",\r\n \"id\": \"AzureCosmosDB.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureCosmosDB\",\r\n \"addressPrefixes\"\ + : [\r\n \"104.211.146.0/28\",\r\n \"104.211.162.94/32\"\ + ,\r\n \"104.211.184.117/32\",\r\n \"104.211.188.174/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestUS\"\ + ,\r\n \"id\": \"AzureCosmosDB.WestUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.64.69.151/32\"\ + ,\r\n \"13.64.113.68/32\",\r\n \"13.64.114.48/32\",\r\n\ + \ \"13.64.194.140/32\",\r\n \"13.88.30.39/32\",\r\n \ + \ \"13.91.246.52/32\",\r\n \"13.93.153.80/32\",\r\n \ + \ \"13.93.156.125/32\",\r\n \"13.93.207.66/32\",\r\n \"\ + 40.83.137.191/32\",\r\n \"40.112.140.12/32\",\r\n \"40.112.241.0/24\"\ + ,\r\n \"40.112.249.60/32\",\r\n \"40.118.245.44/32\",\r\n\ + \ \"40.118.245.251/32\",\r\n \"137.117.9.157/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureCosmosDB.WestUS2\"\ + ,\r\n \"id\": \"AzureCosmosDB.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureCosmosDB\",\r\n \"addressPrefixes\": [\r\n \"13.66.138.0/26\"\ + ,\r\n \"20.36.26.132/32\",\r\n \"40.65.106.154/32\",\r\n\ + \ \"40.65.114.105/32\",\r\n \"40.78.243.192/26\",\r\n \ + \ \"40.78.250.0/26\",\r\n \"52.151.16.118/32\",\r\n \ + \ \"52.158.234.203/32\",\r\n \"52.183.42.252/32\",\r\n \ + \ \"52.183.66.36/32\",\r\n \"52.183.92.223/32\",\r\n \"\ + 52.183.119.101/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureDatabricks\",\r\n \"id\": \"AzureDatabricks\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n\ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\ + \n \"systemService\": \"AzureDatabricks\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.70.105.50/32\",\r\n \"13.70.107.141/32\",\r\ + \n \"13.71.184.74/32\",\r\n \"13.71.187.166/32\",\r\n \ + \ \"13.75.218.172/32\",\r\n \"13.78.18.152/32\",\r\n \ + \ \"13.78.19.235/32\",\r\n \"20.36.120.68/30\",\r\n \ + \ \"20.37.64.68/30\",\r\n \"20.37.156.208/28\",\r\n \"20.37.195.16/29\"\ + ,\r\n \"20.37.224.68/30\",\r\n \"20.38.84.80/28\",\r\n \ + \ \"20.38.136.120/29\",\r\n \"20.39.8.68/30\",\r\n \ + \ \"20.41.4.112/28\",\r\n \"20.41.65.136/29\",\r\n \"\ + 20.41.192.68/30\",\r\n \"20.42.4.208/28\",\r\n \"20.42.129.160/28\"\ + ,\r\n \"20.42.224.68/30\",\r\n \"20.43.41.152/29\",\r\n\ + \ \"20.43.65.144/29\",\r\n \"20.43.130.96/28\",\r\n \ + \ \"20.45.112.68/30\",\r\n \"20.45.192.68/30\",\r\n \ + \ \"20.150.160.104/30\",\r\n \"20.150.160.208/29\",\r\n \ + \ \"20.189.106.192/28\",\r\n \"20.192.160.32/29\",\r\n \ + \ \"20.192.225.24/29\",\r\n \"23.100.0.135/32\",\r\n \"\ + 23.101.147.147/32\",\r\n \"23.101.152.95/32\",\r\n \"40.67.48.68/30\"\ + ,\r\n \"40.70.58.221/32\",\r\n \"40.74.30.80/28\",\r\n \ + \ \"40.80.56.68/30\",\r\n \"40.80.168.68/30\",\r\n \ + \ \"40.80.188.0/28\",\r\n \"40.82.248.112/28\",\r\n \"\ + 40.83.176.199/32\",\r\n \"40.83.178.242/32\",\r\n \"40.85.223.25/32\"\ + ,\r\n \"40.89.16.68/30\",\r\n \"40.89.168.225/32\",\r\n\ + \ \"40.89.170.184/32\",\r\n \"40.89.171.101/32\",\r\n \ + \ \"40.118.174.12/32\",\r\n \"40.119.9.208/28\",\r\n \ + \ \"40.123.212.253/32\",\r\n \"40.123.218.63/32\",\r\n \ + \ \"40.123.219.125/32\",\r\n \"40.127.5.82/32\",\r\n \ + \ \"40.127.5.124/32\",\r\n \"51.12.41.16/30\",\r\n \"51.12.193.16/30\"\ + ,\r\n \"51.104.25.136/30\",\r\n \"51.105.80.68/30\",\r\n\ + \ \"51.105.88.68/30\",\r\n \"51.107.48.120/30\",\r\n \ + \ \"51.107.144.68/30\",\r\n \"51.120.40.120/30\",\r\n \ + \ \"51.120.224.68/30\",\r\n \"51.137.160.120/29\",\r\n \ + \ \"51.140.200.46/32\",\r\n \"51.140.203.27/32\",\r\n \ + \ \"51.140.204.4/32\",\r\n \"51.143.192.68/30\",\r\n \"\ + 52.136.48.68/30\",\r\n \"52.140.104.120/29\",\r\n \"52.141.6.71/32\"\ + ,\r\n \"52.141.6.181/32\",\r\n \"52.141.22.164/32\",\r\n\ + \ \"52.150.136.68/30\",\r\n \"52.187.0.85/32\",\r\n \ + \ \"52.187.3.203/32\",\r\n \"52.187.145.107/32\",\r\n \ + \ \"52.228.81.136/29\",\r\n \"52.232.19.246/32\",\r\n \ + \ \"52.246.160.72/32\",\r\n \"102.133.56.68/30\",\r\n \"\ + 102.133.216.96/29\",\r\n \"102.133.224.24/32\",\r\n \"104.41.54.118/32\"\ + ,\r\n \"104.45.7.191/32\",\r\n \"104.211.89.81/32\",\r\n\ + \ \"104.211.101.14/32\",\r\n \"104.211.103.82/32\",\r\n\ + \ \"191.232.53.223/32\",\r\n \"191.233.8.32/29\",\r\n \ + \ \"191.234.160.82/32\",\r\n \"191.235.225.144/29\",\r\n \ + \ \"2603:1000:104:1::160/123\",\r\n \"2603:1010:6:1::160/123\"\ + ,\r\n \"2603:1020:5:1::160/123\",\r\n \"2603:1020:206:1::160/123\"\ + ,\r\n \"2603:1020:705:1::160/123\",\r\n \"2603:1020:805:1::160/123\"\ + ,\r\n \"2603:1020:a04:1::160/123\",\r\n \"2603:1020:c04:1::160/123\"\ + ,\r\n \"2603:1020:e04:1::160/123\",\r\n \"2603:1020:1004::160/123\"\ + ,\r\n \"2603:1030:10:1::160/123\",\r\n \"2603:1030:104:1::160/123\"\ + ,\r\n \"2603:1030:210:1::160/123\",\r\n \"2603:1030:40b:1::160/123\"\ + ,\r\n \"2603:1030:40c:1::160/123\",\r\n \"2603:1030:504:1::160/123\"\ + ,\r\n \"2603:1030:807:1::160/123\",\r\n \"2603:1030:c06:1::160/123\"\ + ,\r\n \"2603:1030:f05:1::160/123\",\r\n \"2603:1040:5:1::160/123\"\ + ,\r\n \"2603:1040:407:1::160/123\",\r\n \"2603:1040:904:1::160/123\"\ + ,\r\n \"2603:1040:a06:1::160/123\",\r\n \"2603:1040:d04::160/123\"\ + ,\r\n \"2603:1040:f05:1::160/123\",\r\n \"2603:1050:6:1::160/123\"\ + ,\r\n \"2603:1050:403::160/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureDataExplorerManagement\",\r\n \"id\"\ + : \"AzureDataExplorerManagement\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureDataExplorerManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.64.38.225/32\",\r\n \"13.66.141.160/28\",\r\n \ + \ \"13.69.106.240/28\",\r\n \"13.69.229.176/28\",\r\n \ + \ \"13.70.73.112/28\",\r\n \"13.71.173.64/28\",\r\n \"\ + 13.71.196.64/28\",\r\n \"13.73.240.96/28\",\r\n \"13.75.39.0/28\"\ + ,\r\n \"13.77.52.240/28\",\r\n \"13.86.36.42/32\",\r\n \ + \ \"13.86.219.64/28\",\r\n \"13.87.57.224/28\",\r\n \ + \ \"13.87.123.224/28\",\r\n \"13.89.174.80/28\",\r\n \ + \ \"20.36.242.104/32\",\r\n \"20.37.24.1/32\",\r\n \"20.39.97.38/32\"\ + ,\r\n \"20.39.99.177/32\",\r\n \"20.40.114.21/32\",\r\n\ + \ \"20.40.161.39/32\",\r\n \"20.43.89.90/32\",\r\n \ + \ \"20.43.120.96/28\",\r\n \"20.44.16.96/28\",\r\n \"\ + 20.44.27.96/28\",\r\n \"20.45.3.60/32\",\r\n \"20.46.146.7/32\"\ + ,\r\n \"20.150.171.192/28\",\r\n \"20.185.100.27/32\",\r\ + \n \"20.189.74.103/32\",\r\n \"20.192.235.128/28\",\r\n\ + \ \"20.193.203.96/28\",\r\n \"23.98.82.240/28\",\r\n \ + \ \"40.66.57.57/32\",\r\n \"40.66.57.91/32\",\r\n \ + \ \"40.67.188.68/32\",\r\n \"40.69.107.240/28\",\r\n \"\ + 40.71.13.176/28\",\r\n \"40.74.101.208/28\",\r\n \"40.74.147.80/28\"\ + ,\r\n \"40.78.195.240/28\",\r\n \"40.78.203.176/28\",\r\n\ + \ \"40.79.131.224/28\",\r\n \"40.79.179.208/28\",\r\n \ + \ \"40.79.187.16/28\",\r\n \"40.80.234.9/32\",\r\n \ + \ \"40.80.250.168/32\",\r\n \"40.80.255.12/32\",\r\n \"\ + 40.81.28.50/32\",\r\n \"40.81.43.47/32\",\r\n \"40.81.56.122/32\"\ + ,\r\n \"40.81.72.110/32\",\r\n \"40.81.88.112/32\",\r\n\ + \ \"40.81.89.242/32\",\r\n \"40.81.122.39/32\",\r\n \ + \ \"40.81.154.254/32\",\r\n \"40.81.184.86/32\",\r\n \ + \ \"40.81.220.38/32\",\r\n \"40.81.248.53/32\",\r\n \"\ + 40.81.249.251/32\",\r\n \"40.82.154.174/32\",\r\n \"40.82.156.149/32\"\ + ,\r\n \"40.82.188.208/32\",\r\n \"40.82.217.84/32\",\r\n\ + \ \"40.82.236.24/32\",\r\n \"40.89.56.69/32\",\r\n \ + \ \"40.90.219.23/32\",\r\n \"40.91.74.95/32\",\r\n \"\ + 40.119.3.195/32\",\r\n \"40.119.203.252/32\",\r\n \"51.12.99.192/28\"\ + ,\r\n \"51.12.203.192/28\",\r\n \"51.104.8.112/28\",\r\n\ + \ \"51.107.59.160/28\",\r\n \"51.107.98.201/32\",\r\n \ + \ \"51.107.155.160/28\",\r\n \"51.116.59.160/28\",\r\n \ + \ \"51.116.98.150/32\",\r\n \"51.116.155.224/28\",\r\n \ + \ \"51.120.99.80/28\",\r\n \"51.120.219.192/28\",\r\n \ + \ \"51.140.212.0/28\",\r\n \"51.145.176.215/32\",\r\n \ + \ \"52.142.91.221/32\",\r\n \"52.159.55.120/32\",\r\n \"\ + 52.162.110.176/28\",\r\n \"52.224.146.56/32\",\r\n \"52.231.148.16/28\"\ + ,\r\n \"52.232.230.201/32\",\r\n \"52.253.159.186/32\",\r\ + \n \"52.253.225.186/32\",\r\n \"52.253.226.110/32\",\r\n\ + \ \"102.133.0.192/32\",\r\n \"102.133.28.112/28\",\r\n \ + \ \"102.133.130.206/32\",\r\n \"102.133.156.16/28\",\r\n\ + \ \"104.211.147.224/28\",\r\n \"191.233.25.183/32\",\r\n\ + \ \"191.233.50.208/28\",\r\n \"191.233.205.0/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.AustraliaCentral\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"australiacentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureDataExplorerManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.24.1/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureDataExplorerManagement.AustraliaCentral2\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.AustraliaCentral2\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.39.97.38/32\",\r\n \ + \ \"20.39.99.177/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.AustraliaEast\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.73.112/28\",\r\n\ + \ \"40.82.217.84/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.AustraliaSoutheast\",\r\n\ + \ \"id\": \"AzureDataExplorerManagement.AustraliaSoutheast\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.52.240/28\",\r\n\ + \ \"20.40.161.39/32\",\r\n \"40.81.56.122/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.BrazilSouth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.BrazilSouth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.40.114.21/32\",\r\n\ + \ \"191.233.25.183/32\",\r\n \"191.233.205.0/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.CanadaCentral\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.CanadaCentral\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.173.64/28\",\r\n\ + \ \"40.82.188.208/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.CanadaEast\",\r\n \"\ + id\": \"AzureDataExplorerManagement.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.69.107.240/28\",\r\n\ + \ \"40.80.250.168/32\",\r\n \"40.80.255.12/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.CentralIndia\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.CentralIndia\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"centralindia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.120.96/28\",\r\n\ + \ \"40.81.248.53/32\",\r\n \"40.81.249.251/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.CentralUS\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.CentralUS\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.86.36.42/32\",\r\n \ + \ \"13.89.174.80/28\",\r\n \"40.67.188.68/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.CentralUSEUAP\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.203.176/28\",\r\n\ + \ \"40.89.56.69/32\",\r\n \"52.253.159.186/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.EastAsia\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.75.39.0/28\",\r\n \ + \ \"20.189.74.103/32\",\r\n \"40.81.28.50/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.EastUS\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.EastUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.185.100.27/32\",\r\n\ + \ \"40.71.13.176/28\",\r\n \"52.224.146.56/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.EastUS2EUAP\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.74.147.80/28\",\r\n\ + \ \"52.253.225.186/32\",\r\n \"52.253.226.110/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.FranceCentral\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.FranceCentral\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"centralfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.66.57.57/32\",\r\n \ + \ \"40.66.57.91/32\",\r\n \"40.79.131.224/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.FranceSouth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.FranceSouth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southfrance\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.179.208/28\",\r\n\ + \ \"40.82.236.24/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.GermanyNorth\",\r\n \"\ + id\": \"AzureDataExplorerManagement.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.59.160/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.GermanyWestCentral\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.98.150/32\",\r\n\ + \ \"51.116.155.224/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDataExplorerManagement.JapanEast\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.89.90/32\",\r\n \ + \ \"40.79.187.16/28\",\r\n \"40.81.220.38/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.JapanWest\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.JapanWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"japanwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.74.101.208/28\",\r\n\ + \ \"40.81.184.86/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.KoreaCentral\",\r\n \"\ + id\": \"AzureDataExplorerManagement.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.44.27.96/28\",\r\n \ + \ \"40.82.154.174/32\",\r\n \"40.82.156.149/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.KoreaSouth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.KoreaSouth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.234.9/32\",\r\n \ + \ \"52.231.148.16/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.NorthCentralUS\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.81.43.47/32\",\r\n \ + \ \"52.162.110.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.NorthEurope\",\r\n \"\ + id\": \"AzureDataExplorerManagement.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.229.176/28\",\r\n\ + \ \"52.142.91.221/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.NorwayEast\",\r\n \"\ + id\": \"AzureDataExplorerManagement.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.99.80/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.NorwayWest\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.NorwayWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.219.192/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthAfricaNorth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.SouthAfricaNorth\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureDataExplorerManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"102.133.130.206/32\",\r\n \"102.133.156.16/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.SouthAfricaWest\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.0.192/32\",\r\n\ + \ \"102.133.28.112/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDataExplorerManagement.SouthCentralUS\",\r\n\ + \ \"id\": \"AzureDataExplorerManagement.SouthCentralUS\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.240.96/28\",\r\n\ + \ \"20.45.3.60/32\",\r\n \"40.119.3.195/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.SoutheastAsia\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southeastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"23.98.82.240/28\",\r\n\ + \ \"40.119.203.252/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDataExplorerManagement.SouthIndia\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.195.240/28\",\r\n\ + \ \"40.81.72.110/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.SwitzerlandNorth\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.SwitzerlandNorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.59.160/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.SwitzerlandWest\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.98.201/32\",\r\n\ + \ \"51.107.155.160/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDataExplorerManagement.UAENorth\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.UAENorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.46.146.7/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKNorth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.123.224/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKSouth\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.81.154.254/32\",\r\n\ + \ \"51.104.8.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.UKSouth2\",\r\n \"id\"\ + : \"AzureDataExplorerManagement.UKSouth2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.57.224/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.UKWest\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.81.122.39/32\",\r\n\ + \ \"51.140.212.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.WestCentralUS\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.196.64/28\",\r\n\ + \ \"52.159.55.120/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.WestEurope\",\r\n \"\ + id\": \"AzureDataExplorerManagement.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.106.240/28\",\r\n\ + \ \"51.145.176.215/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDataExplorerManagement.WestIndia\",\r\n \ + \ \"id\": \"AzureDataExplorerManagement.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.81.88.112/32\",\r\n\ + \ \"40.81.89.242/32\",\r\n \"104.211.147.224/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataExplorerManagement.WestUS\"\ + ,\r\n \"id\": \"AzureDataExplorerManagement.WestUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.64.38.225/32\",\r\n\ + \ \"13.86.219.64/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataExplorerManagement.WestUS2\",\r\n \"id\"\ + : \"AzureDataExplorerManagement.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataExplorerManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.141.160/28\",\r\n\ + \ \"40.90.219.23/32\",\r\n \"40.91.74.95/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake\",\r\ + \n \"id\": \"AzureDataLake\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureDataLake\",\r\n \"addressPrefixes\": [\r\n \"40.90.138.133/32\"\ + ,\r\n \"40.90.138.136/32\",\r\n \"40.90.141.128/29\",\r\n\ + \ \"40.90.141.167/32\",\r\n \"40.90.144.0/27\",\r\n \ + \ \"40.90.145.192/26\",\r\n \"65.52.108.31/32\",\r\n \ + \ \"65.52.108.38/32\",\r\n \"104.44.88.66/31\",\r\n \"\ + 104.44.88.106/31\",\r\n \"104.44.88.112/31\",\r\n \"104.44.88.176/31\"\ + ,\r\n \"104.44.88.184/29\",\r\n \"104.44.89.39/32\",\r\n\ + \ \"104.44.89.42/32\",\r\n \"104.44.90.128/27\",\r\n \ + \ \"104.44.90.194/31\",\r\n \"104.44.91.64/27\",\r\n \ + \ \"104.44.91.160/27\",\r\n \"104.44.93.192/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureDataLake.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataLake\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.90.138.133/32\",\r\n\ + \ \"40.90.138.136/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataLake.CentralUS\",\r\n \"id\": \"AzureDataLake.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureDataLake\",\r\n \"addressPrefixes\": [\r\n \"40.90.144.0/27\"\ + ,\r\n \"104.44.88.176/31\",\r\n \"104.44.88.184/29\",\r\n\ + \ \"104.44.91.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDataLake.EastUS2\",\r\n \"id\": \"AzureDataLake.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureDataLake\"\ + ,\r\n \"addressPrefixes\": [\r\n \"65.52.108.31/32\",\r\n\ + \ \"65.52.108.38/32\",\r\n \"104.44.88.106/31\",\r\n \ + \ \"104.44.88.112/31\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureDataLake.NorthEurope\",\r\n \"id\": \"AzureDataLake.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureDataLake\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.90.141.128/29\",\r\n \"40.90.145.224/27\",\r\n \ + \ \"104.44.88.66/31\",\r\n \"104.44.91.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureDataLake.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataLake\"\ + ,\r\n \"addressPrefixes\": [\r\n \"104.44.89.39/32\",\r\n\ + \ \"104.44.89.42/32\",\r\n \"104.44.90.128/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDataLake.WestEurope\"\ + ,\r\n \"id\": \"AzureDataLake.WestEurope\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureDataLake\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.90.141.167/32\",\r\n\ + \ \"40.90.145.192/27\",\r\n \"104.44.90.194/31\",\r\n \ + \ \"104.44.93.192/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDevSpaces\",\r\n \"id\": \"AzureDevSpaces\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"\ + addressPrefixes\": [\r\n \"13.69.71.144/28\",\r\n \"13.70.78.176/28\"\ + ,\r\n \"13.71.175.112/28\",\r\n \"13.71.199.96/28\",\r\n\ + \ \"13.73.244.128/28\",\r\n \"13.74.111.128/28\",\r\n \ + \ \"13.78.111.144/28\",\r\n \"13.86.221.224/28\",\r\n \ + \ \"20.37.157.64/28\",\r\n \"20.37.195.80/28\",\r\n \ + \ \"20.38.85.128/28\",\r\n \"20.39.11.64/28\",\r\n \"20.41.5.128/28\"\ + ,\r\n \"20.42.6.32/27\",\r\n \"20.42.6.128/28\",\r\n \ + \ \"20.42.64.64/26\",\r\n \"20.42.131.192/27\",\r\n \ + \ \"20.42.230.64/28\",\r\n \"20.43.65.208/28\",\r\n \"\ + 20.43.130.240/28\",\r\n \"20.189.108.32/28\",\r\n \"40.69.110.176/28\"\ + ,\r\n \"40.70.151.80/28\",\r\n \"40.74.30.144/28\",\r\n\ + \ \"40.75.35.224/28\",\r\n \"40.78.239.0/28\",\r\n \ + \ \"40.78.251.224/27\",\r\n \"40.82.253.112/28\",\r\n \ + \ \"40.89.17.192/28\",\r\n \"40.119.9.240/28\",\r\n \"\ + 51.104.25.208/28\",\r\n \"51.105.77.64/28\",\r\n \"52.150.139.144/28\"\ + ,\r\n \"52.182.141.128/28\",\r\n \"52.228.81.224/28\",\r\ + \n \"104.214.161.48/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDevSpaces.AustraliaEast\",\r\n \"id\"\ + : \"AzureDevSpaces.AustraliaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"13.70.78.176/28\"\ + ,\r\n \"20.37.195.80/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDevSpaces.AustraliaSoutheast\",\r\n \"\ + id\": \"AzureDevSpaces.AustraliaSoutheast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.42.230.64/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.CanadaCentral\"\ + ,\r\n \"id\": \"AzureDevSpaces.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"13.71.175.112/28\"\ + ,\r\n \"52.228.81.224/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureDevSpaces.CanadaEast\",\r\n \"id\":\ + \ \"AzureDevSpaces.CanadaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.69.110.176/28\",\r\n\ + \ \"40.89.17.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDevSpaces.CentralUS\",\r\n \"id\": \"AzureDevSpaces.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.157.64/28\",\r\n \"52.182.141.128/28\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastAsia\"\ + ,\r\n \"id\": \"AzureDevSpaces.EastAsia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.189.108.32/28\"\ + ,\r\n \"104.214.161.48/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureDevSpaces.EastUS\",\r\n \"id\": \"AzureDevSpaces.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.42.6.32/27\",\r\n \"20.42.6.128/28\",\r\n \ + \ \"20.42.64.64/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureDevSpaces.EastUS2\",\r\n \"id\": \"AzureDevSpaces.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.41.5.128/28\",\r\n \"40.70.151.80/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureDevSpaces.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.39.11.64/28\"\ + ,\r\n \"40.75.35.224/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDevSpaces.JapanEast\",\r\n \"id\": \"\ + AzureDevSpaces.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.78.111.144/28\",\r\n \ + \ \"20.43.65.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureDevSpaces.NorthEurope\",\r\n \"id\": \"AzureDevSpaces.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureDevSpaces\",\r\n \"\ + addressPrefixes\": [\r\n \"13.74.111.128/28\",\r\n \"20.38.85.128/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureDevSpaces.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"13.73.244.128/28\"\ + ,\r\n \"40.119.9.240/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDevSpaces.SoutheastAsia\",\r\n \"id\"\ + : \"AzureDevSpaces.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.43.130.240/28\"\ + ,\r\n \"40.78.239.0/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureDevSpaces.UKSouth\",\r\n \"id\": \"AzureDevSpaces.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.104.25.208/28\",\r\n \"51.105.77.64/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestCentralUS\"\ + ,\r\n \"id\": \"AzureDevSpaces.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"13.71.199.96/28\"\ + ,\r\n \"52.150.139.144/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureDevSpaces.WestEurope\",\r\n \"id\":\ + \ \"AzureDevSpaces.WestEurope\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureDevSpaces\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.71.144/28\",\r\n\ + \ \"40.74.30.144/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureDevSpaces.WestUS\",\r\n \"id\": \"AzureDevSpaces.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.86.221.224/28\",\r\n \"40.82.253.112/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureDevSpaces.WestUS2\"\ + ,\r\n \"id\": \"AzureDevSpaces.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureDevSpaces\",\r\n \"addressPrefixes\": [\r\n \"20.42.131.192/27\"\ + ,\r\n \"40.78.251.224/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid\",\r\n \"id\": \"AzureEventGrid\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"\ + addressPrefixes\": [\r\n \"13.71.56.240/28\",\r\n \"13.71.57.0/28\"\ + ,\r\n \"13.73.248.128/25\",\r\n \"13.86.56.32/27\",\r\n\ + \ \"13.86.56.160/27\",\r\n \"13.88.73.16/28\",\r\n \ + \ \"13.88.73.32/27\",\r\n \"13.88.135.208/28\",\r\n \ + \ \"13.91.193.0/28\",\r\n \"20.36.121.0/25\",\r\n \"20.37.55.32/27\"\ + ,\r\n \"20.37.65.0/25\",\r\n \"20.37.82.224/27\",\r\n \ + \ \"20.37.157.128/25\",\r\n \"20.37.196.0/25\",\r\n \ + \ \"20.37.225.0/25\",\r\n \"20.38.87.0/25\",\r\n \"20.38.137.0/25\"\ + ,\r\n \"20.39.11.128/25\",\r\n \"20.39.20.16/28\",\r\n \ + \ \"20.39.80.112/28\",\r\n \"20.39.80.128/28\",\r\n \ + \ \"20.39.99.64/28\",\r\n \"20.39.99.240/28\",\r\n \"\ + 20.40.152.128/27\",\r\n \"20.40.175.48/28\",\r\n \"20.40.175.64/28\"\ + ,\r\n \"20.41.66.0/25\",\r\n \"20.41.136.240/28\",\r\n \ + \ \"20.41.195.0/25\",\r\n \"20.42.7.0/25\",\r\n \ + \ \"20.42.228.0/25\",\r\n \"20.43.42.128/25\",\r\n \"20.43.66.128/25\"\ + ,\r\n \"20.43.131.128/25\",\r\n \"20.43.165.144/28\",\r\n\ + \ \"20.43.172.128/27\",\r\n \"20.44.39.176/28\",\r\n \ + \ \"20.44.39.192/28\",\r\n \"20.44.168.64/28\",\r\n \ + \ \"20.44.205.112/28\",\r\n \"20.45.113.0/25\",\r\n \"\ + 20.45.195.0/25\",\r\n \"20.46.152.112/28\",\r\n \"20.46.152.128/28\"\ + ,\r\n \"20.49.96.0/25\",\r\n \"20.150.164.0/25\",\r\n \ + \ \"20.189.108.128/25\",\r\n \"20.189.115.80/28\",\r\n \ + \ \"20.189.123.80/28\",\r\n \"20.189.125.32/27\",\r\n \ + \ \"20.191.59.128/28\",\r\n \"20.191.59.176/28\",\r\n \ + \ \"20.192.164.0/25\",\r\n \"20.192.228.0/25\",\r\n \"\ + 20.193.34.0/28\",\r\n \"20.193.34.32/28\",\r\n \"40.64.128.0/25\"\ + ,\r\n \"40.67.49.0/25\",\r\n \"40.74.31.128/25\",\r\n \ + \ \"40.74.106.96/27\",\r\n \"40.80.58.0/25\",\r\n \ + \ \"40.80.170.0/25\",\r\n \"40.80.190.0/25\",\r\n \"40.80.236.192/27\"\ + ,\r\n \"40.81.93.240/28\",\r\n \"40.81.95.128/28\",\r\n\ + \ \"40.82.254.128/25\",\r\n \"40.89.18.0/25\",\r\n \ + \ \"40.89.240.144/28\",\r\n \"40.114.160.176/28\",\r\n \ + \ \"40.114.160.192/28\",\r\n \"40.114.169.0/28\",\r\n \ + \ \"40.127.155.192/28\",\r\n \"40.127.251.144/28\",\r\n \ + \ \"51.104.27.128/25\",\r\n \"51.105.81.0/25\",\r\n \"\ + 51.105.89.0/25\",\r\n \"51.107.4.128/27\",\r\n \"51.107.49.0/25\"\ + ,\r\n \"51.107.99.32/27\",\r\n \"51.107.145.0/25\",\r\n\ + \ \"51.116.3.32/27\",\r\n \"51.116.100.208/28\",\r\n \ + \ \"51.116.100.224/28\",\r\n \"51.120.4.0/27\",\r\n \ + \ \"51.120.41.0/25\",\r\n \"51.120.131.64/27\",\r\n \"\ + 51.120.225.0/25\",\r\n \"51.132.161.160/28\",\r\n \"51.132.170.64/28\"\ + ,\r\n \"51.137.16.224/28\",\r\n \"51.137.142.32/28\",\r\n\ + \ \"51.137.162.0/25\",\r\n \"51.143.193.0/25\",\r\n \ + \ \"52.136.49.0/25\",\r\n \"52.139.9.80/28\",\r\n \"\ + 52.139.11.16/28\",\r\n \"52.139.85.16/28\",\r\n \"52.139.85.32/28\"\ + ,\r\n \"52.140.106.0/25\",\r\n \"52.142.152.144/28\",\r\n\ + \ \"52.149.23.160/27\",\r\n \"52.149.48.80/28\",\r\n \ + \ \"52.149.48.96/27\",\r\n \"52.149.248.0/28\",\r\n \ + \ \"52.149.248.64/27\",\r\n \"52.149.248.96/28\",\r\n \ + \ \"52.150.140.0/25\",\r\n \"52.154.57.48/28\",\r\n \"52.154.57.80/28\"\ + ,\r\n \"52.154.68.16/28\",\r\n \"52.154.68.32/28\",\r\n\ + \ \"52.156.103.192/28\",\r\n \"52.159.49.144/28\",\r\n \ + \ \"52.159.51.160/28\",\r\n \"52.159.53.64/28\",\r\n \ + \ \"52.159.53.112/28\",\r\n \"52.160.136.16/28\",\r\n \ + \ \"52.160.136.32/28\",\r\n \"52.161.186.128/28\",\r\n \ + \ \"52.161.186.208/28\",\r\n \"52.167.21.160/27\",\r\n \ + \ \"52.167.21.208/28\",\r\n \"52.167.21.224/28\",\r\n \"\ + 52.170.171.192/28\",\r\n \"52.170.171.240/28\",\r\n \"52.177.38.160/27\"\ + ,\r\n \"52.185.176.112/28\",\r\n \"52.185.212.176/28\",\r\ + \n \"52.185.212.192/28\",\r\n \"52.186.36.16/28\",\r\n \ + \ \"52.228.83.0/25\",\r\n \"52.231.112.192/28\",\r\n \ + \ \"52.231.112.224/28\",\r\n \"52.250.28.176/28\",\r\n \ + \ \"52.250.32.160/28\",\r\n \"52.252.213.192/28\",\r\n \ + \ \"52.255.80.16/28\",\r\n \"52.255.82.160/28\",\r\n \ + \ \"102.133.0.240/28\",\r\n \"102.133.1.0/28\",\r\n \"102.133.57.0/25\"\ + ,\r\n \"102.133.135.16/28\",\r\n \"102.133.135.32/28\",\r\ + \n \"191.233.9.128/25\",\r\n \"191.235.126.0/28\",\r\n \ + \ \"191.235.126.144/28\",\r\n \"191.235.227.0/25\",\r\n \ + \ \"2603:1000:104:1::380/121\",\r\n \"2603:1010:6:1::380/121\"\ + ,\r\n \"2603:1020:5:1::380/121\",\r\n \"2603:1020:206:1::380/121\"\ + ,\r\n \"2603:1020:705:1::380/121\",\r\n \"2603:1020:805:1::380/121\"\ + ,\r\n \"2603:1020:a04:1::380/121\",\r\n \"2603:1020:c04:1::380/121\"\ + ,\r\n \"2603:1020:e04:1::380/121\",\r\n \"2603:1020:1004::380/121\"\ + ,\r\n \"2603:1030:10:1::380/121\",\r\n \"2603:1030:104:1::380/121\"\ + ,\r\n \"2603:1030:210:1::380/121\",\r\n \"2603:1030:40b:1::380/121\"\ + ,\r\n \"2603:1030:40c:1::380/121\",\r\n \"2603:1030:504:1::380/121\"\ + ,\r\n \"2603:1030:807:1::380/121\",\r\n \"2603:1030:c06:1::380/121\"\ + ,\r\n \"2603:1030:f05:1::380/121\",\r\n \"2603:1040:5:1::380/121\"\ + ,\r\n \"2603:1040:407:1::380/121\",\r\n \"2603:1040:904:1::380/121\"\ + ,\r\n \"2603:1040:a06:1::380/121\",\r\n \"2603:1040:d04::380/121\"\ + ,\r\n \"2603:1040:f05:1::380/121\",\r\n \"2603:1050:6:1::380/121\"\ + ,\r\n \"2603:1050:403::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.AustraliaCentral\",\r\n \"\ + id\": \"AzureEventGrid.AustraliaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.37.55.32/27\"\ + ,\r\n \"20.37.225.0/25\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureEventGrid.AustraliaCentral2\",\r\n \"\ + id\": \"AzureEventGrid.AustraliaCentral2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.36.121.0/25\"\ + ,\r\n \"20.39.99.64/28\",\r\n \"20.39.99.240/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.AustraliaEast\"\ + ,\r\n \"id\": \"AzureEventGrid.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.37.196.0/25\"\ + ,\r\n \"20.193.34.0/28\",\r\n \"20.193.34.32/28\",\r\n \ + \ \"2603:1010:6:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.AustraliaSoutheast\",\r\n \ + \ \"id\": \"AzureEventGrid.AustraliaSoutheast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.40.175.48/28\"\ + ,\r\n \"20.40.175.64/28\",\r\n \"20.42.228.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.BrazilSouth\"\ + ,\r\n \"id\": \"AzureEventGrid.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"191.235.126.0/28\"\ + ,\r\n \"191.235.126.144/28\",\r\n \"191.235.227.0/25\",\r\ + \n \"2603:1050:6:1::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.CanadaCentral\",\r\n \"id\"\ + : \"AzureEventGrid.CanadaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"52.139.9.80/28\"\ + ,\r\n \"52.139.11.16/28\",\r\n \"52.228.83.0/25\",\r\n \ + \ \"2603:1030:f05:1::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.CanadaEast\",\r\n \"id\"\ + : \"AzureEventGrid.CanadaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.89.18.0/25\",\r\n \ + \ \"52.139.85.16/28\",\r\n \"52.139.85.32/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CentralIndia\"\ + ,\r\n \"id\": \"AzureEventGrid.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"13.71.56.240/28\"\ + ,\r\n \"13.71.57.0/28\",\r\n \"52.140.106.0/25\",\r\n \ + \ \"2603:1040:a06:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.CentralUS\",\r\n \"id\": \"\ + AzureEventGrid.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.86.56.32/27\",\r\n \ + \ \"13.86.56.160/27\",\r\n \"20.37.157.128/25\",\r\n \ + \ \"40.89.240.144/28\",\r\n \"52.154.57.48/28\",\r\n \"\ + 52.154.57.80/28\",\r\n \"2603:1030:10:1::380/121\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureEventGrid.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.45.195.0/25\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.EastAsia\"\ + ,\r\n \"id\": \"AzureEventGrid.EastAsia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.189.108.128/25\"\ + ,\r\n \"20.189.115.80/28\",\r\n \"20.189.123.80/28\",\r\n\ + \ \"20.189.125.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureEventGrid.EastUS\",\r\n \"id\": \"AzureEventGrid.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.42.7.0/25\",\r\n \"52.149.248.0/28\",\r\n \ + \ \"52.149.248.64/27\",\r\n \"52.149.248.96/28\",\r\n \ + \ \"52.154.68.16/28\",\r\n \"52.154.68.32/28\",\r\n \"52.170.171.192/28\"\ + ,\r\n \"52.170.171.240/28\",\r\n \"52.186.36.16/28\",\r\n\ + \ \"2603:1030:210:1::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.EastUS2\",\r\n \"id\": \"\ + AzureEventGrid.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.49.96.0/25\",\r\n \ + \ \"52.167.21.160/27\",\r\n \"52.167.21.208/28\",\r\n \ + \ \"52.167.21.224/28\",\r\n \"52.177.38.160/27\",\r\n \"\ + 2603:1030:40c:1::380/121\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureEventGrid.EastUS2EUAP\",\r\n \"id\": \"AzureEventGrid.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"\ + addressPrefixes\": [\r\n \"20.39.11.128/25\",\r\n \"20.39.20.16/28\"\ + ,\r\n \"2603:1030:40b:1::380/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureEventGrid.FranceCentral\",\r\n \ + \ \"id\": \"AzureEventGrid.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.40.152.128/27\"\ + ,\r\n \"20.43.42.128/25\",\r\n \"2603:1020:805:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.FranceSouth\"\ + ,\r\n \"id\": \"AzureEventGrid.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.39.80.112/28\"\ + ,\r\n \"20.39.80.128/28\",\r\n \"51.105.89.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.GermanyNorth\"\ + ,\r\n \"id\": \"AzureEventGrid.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.116.3.32/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureEventGrid.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.116.100.208/28\"\ + ,\r\n \"51.116.100.224/28\",\r\n \"2603:1020:c04:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.JapanEast\"\ + ,\r\n \"id\": \"AzureEventGrid.JapanEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.43.66.128/25\"\ + ,\r\n \"20.44.168.64/28\",\r\n \"52.185.176.112/28\",\r\n\ + \ \"2603:1040:407:1::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.JapanWest\",\r\n \"id\":\ + \ \"AzureEventGrid.JapanWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"japanwest\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.74.106.96/27\",\r\n \ + \ \"40.80.58.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureEventGrid.KoreaCentral\",\r\n \"id\": \"AzureEventGrid.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"\ + addressPrefixes\": [\r\n \"20.41.66.0/25\",\r\n \"52.231.112.192/28\"\ + ,\r\n \"52.231.112.224/28\",\r\n \"2603:1040:f05:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.KoreaSouth\"\ + ,\r\n \"id\": \"AzureEventGrid.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"40.80.170.0/25\"\ + ,\r\n \"40.80.236.192/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.NorthCentralUS\",\r\n \"id\"\ + : \"AzureEventGrid.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.41.136.240/28\"\ + ,\r\n \"40.80.190.0/25\",\r\n \"52.252.213.192/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.NorthEurope\"\ + ,\r\n \"id\": \"AzureEventGrid.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.38.87.0/25\"\ + ,\r\n \"20.191.59.128/28\",\r\n \"20.191.59.176/28\",\r\n\ + \ \"40.127.155.192/28\",\r\n \"40.127.251.144/28\",\r\n\ + \ \"2603:1020:5:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.NorwayEast\",\r\n \"id\":\ + \ \"AzureEventGrid.NorwayEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.4.0/27\",\r\n \ + \ \"51.120.41.0/25\",\r\n \"2603:1020:e04:1::380/121\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.NorwayWest\"\ + ,\r\n \"id\": \"AzureEventGrid.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.120.131.64/27\"\ + ,\r\n \"51.120.225.0/25\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureEventGrid.SouthAfricaNorth\",\r\n \"\ + id\": \"AzureEventGrid.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"102.133.135.16/28\"\ + ,\r\n \"102.133.135.32/28\",\r\n \"2603:1000:104:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureEventGrid.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"102.133.0.240/28\"\ + ,\r\n \"102.133.1.0/28\",\r\n \"102.133.57.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureEventGrid.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"13.73.248.128/25\"\ + ,\r\n \"52.185.212.176/28\",\r\n \"52.185.212.192/28\",\r\ + \n \"52.255.80.16/28\",\r\n \"52.255.82.160/28\",\r\n \ + \ \"2603:1030:807:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.SoutheastAsia\",\r\n \"id\"\ + : \"AzureEventGrid.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.43.131.128/25\"\ + ,\r\n \"20.43.165.144/28\",\r\n \"20.43.172.128/27\",\r\n\ + \ \"20.44.205.112/28\",\r\n \"2603:1040:5:1::380/121\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SouthIndia\"\ + ,\r\n \"id\": \"AzureEventGrid.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"20.41.195.0/25\"\ + ,\r\n \"20.44.39.176/28\",\r\n \"20.44.39.192/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SwitzerlandNorth\"\ + ,\r\n \"id\": \"AzureEventGrid.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.107.4.128/27\"\ + ,\r\n \"51.107.49.0/25\",\r\n \"2603:1020:a04:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureEventGrid.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.107.99.32/27\"\ + ,\r\n \"51.107.145.0/25\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureEventGrid.UAECentral\",\r\n \"id\": \"\ + AzureEventGrid.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.37.65.0/25\",\r\n \ + \ \"20.37.82.224/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureEventGrid.UAENorth\",\r\n \"id\": \"AzureEventGrid.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventGrid\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.137.0/25\",\r\n \"20.46.152.112/28\",\r\n\ + \ \"20.46.152.128/28\",\r\n \"2603:1040:904:1::380/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKNorth\"\ + ,\r\n \"id\": \"AzureEventGrid.UKNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.105.81.0/25\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKSouth\"\ + ,\r\n \"id\": \"AzureEventGrid.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.104.27.128/25\"\ + ,\r\n \"51.132.161.160/28\",\r\n \"51.132.170.64/28\",\r\ + \n \"2603:1020:705:1::380/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureEventGrid.UKSouth2\",\r\n \"id\": \"\ + AzureEventGrid.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.143.193.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.UKWest\"\ + ,\r\n \"id\": \"AzureEventGrid.UKWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"51.137.142.32/28\"\ + ,\r\n \"51.137.162.0/25\",\r\n \"52.142.152.144/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestCentralUS\"\ + ,\r\n \"id\": \"AzureEventGrid.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"52.150.140.0/25\"\ + ,\r\n \"52.159.49.144/28\",\r\n \"52.159.51.160/28\",\r\n\ + \ \"52.159.53.64/28\",\r\n \"52.159.53.112/28\",\r\n \ + \ \"52.161.186.128/28\",\r\n \"52.161.186.208/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestEurope\"\ + ,\r\n \"id\": \"AzureEventGrid.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"40.74.31.128/25\"\ + ,\r\n \"40.114.160.176/28\",\r\n \"40.114.160.192/28\",\r\ + \n \"40.114.169.0/28\",\r\n \"51.137.16.224/28\",\r\n \ + \ \"2603:1020:206:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureEventGrid.WestIndia\",\r\n \"id\": \"\ + AzureEventGrid.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureEventGrid\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.81.93.240/28\",\r\n \ + \ \"40.81.95.128/28\",\r\n \"52.136.49.0/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestUS\"\ + ,\r\n \"id\": \"AzureEventGrid.WestUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"13.88.73.16/28\"\ + ,\r\n \"13.88.73.32/27\",\r\n \"13.88.135.208/28\",\r\n\ + \ \"13.91.193.0/28\",\r\n \"40.82.254.128/25\",\r\n \ + \ \"52.160.136.16/28\",\r\n \"52.160.136.32/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureEventGrid.WestUS2\"\ + ,\r\n \"id\": \"AzureEventGrid.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventGrid\",\r\n \"addressPrefixes\": [\r\n \"40.64.128.0/25\"\ + ,\r\n \"52.149.23.160/27\",\r\n \"52.149.48.80/28\",\r\n\ + \ \"52.149.48.96/27\",\r\n \"52.156.103.192/28\",\r\n \ + \ \"52.250.28.176/28\",\r\n \"52.250.32.160/28\",\r\n \ + \ \"2603:1030:c06:1::380/121\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureFrontDoor.Backend\",\r\n \"id\": \"\ + AzureFrontDoor.Backend\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.73.248.16/29\",\r\n \"20.36.120.104/29\",\r\ + \n \"20.37.64.104/29\",\r\n \"20.37.156.120/29\",\r\n \ + \ \"20.37.195.0/29\",\r\n \"20.37.224.104/29\",\r\n \ + \ \"20.38.84.72/29\",\r\n \"20.38.136.104/29\",\r\n \"\ + 20.39.11.8/29\",\r\n \"20.41.4.88/29\",\r\n \"20.41.64.120/29\"\ + ,\r\n \"20.41.192.104/29\",\r\n \"20.42.4.120/29\",\r\n\ + \ \"20.42.129.152/29\",\r\n \"20.42.224.104/29\",\r\n \ + \ \"20.43.41.136/29\",\r\n \"20.43.65.128/29\",\r\n \ + \ \"20.43.130.80/29\",\r\n \"20.45.112.104/29\",\r\n \ + \ \"20.45.192.104/29\",\r\n \"20.150.160.96/29\",\r\n \"\ + 20.189.106.112/29\",\r\n \"20.192.161.104/29\",\r\n \"20.192.225.48/29\"\ + ,\r\n \"40.67.48.104/29\",\r\n \"40.74.30.72/29\",\r\n \ + \ \"40.80.56.104/29\",\r\n \"40.80.168.104/29\",\r\n \ + \ \"40.80.184.120/29\",\r\n \"40.82.248.248/29\",\r\n \ + \ \"40.89.16.104/29\",\r\n \"51.12.41.8/29\",\r\n \"\ + 51.12.193.8/29\",\r\n \"51.104.25.128/29\",\r\n \"51.105.80.104/29\"\ + ,\r\n \"51.105.88.104/29\",\r\n \"51.107.48.104/29\",\r\n\ + \ \"51.107.144.104/29\",\r\n \"51.120.40.104/29\",\r\n \ + \ \"51.120.224.104/29\",\r\n \"51.137.160.112/29\",\r\n \ + \ \"51.143.192.104/29\",\r\n \"52.136.48.104/29\",\r\n \ + \ \"52.140.104.104/29\",\r\n \"52.150.136.120/29\",\r\n \ + \ \"52.228.80.120/29\",\r\n \"102.133.56.88/29\",\r\n \ + \ \"102.133.216.88/29\",\r\n \"147.243.0.0/16\",\r\n \ + \ \"191.233.9.120/29\",\r\n \"191.235.225.128/29\",\r\n \ + \ \"2603:1000:104::e0/123\",\r\n \"2603:1000:104::300/123\",\r\n\ + \ \"2603:1000:104:1::5c0/123\",\r\n \"2603:1000:104:1::7e0/123\"\ + ,\r\n \"2603:1010:6:1::5c0/123\",\r\n \"2603:1010:6:1::7e0/123\"\ + ,\r\n \"2603:1020:5:1::5c0/123\",\r\n \"2603:1020:5:1::7e0/123\"\ + ,\r\n \"2603:1020:206:1::5c0/123\",\r\n \"2603:1020:206:1::7e0/123\"\ + ,\r\n \"2603:1020:705:1::5c0/123\",\r\n \"2603:1020:705:1::7e0/123\"\ + ,\r\n \"2603:1020:805:1::5c0/123\",\r\n \"2603:1020:805:1::7e0/123\"\ + ,\r\n \"2603:1020:a04:1::5c0/123\",\r\n \"2603:1020:a04:1::7e0/123\"\ + ,\r\n \"2603:1020:c04:1::5c0/123\",\r\n \"2603:1020:c04:1::7e0/123\"\ + ,\r\n \"2603:1020:e04:1::5c0/123\",\r\n \"2603:1020:e04:1::7e0/123\"\ + ,\r\n \"2603:1020:1004::5c0/123\",\r\n \"2603:1020:1004::7e0/123\"\ + ,\r\n \"2603:1030:10:1::5c0/123\",\r\n \"2603:1030:10:1::7e0/123\"\ + ,\r\n \"2603:1030:104:1::5c0/123\",\r\n \"2603:1030:104:1::7e0/123\"\ + ,\r\n \"2603:1030:210:1::5c0/123\",\r\n \"2603:1030:210:1::7e0/123\"\ + ,\r\n \"2603:1030:40b:1::5c0/123\",\r\n \"2603:1030:40c:1::5c0/123\"\ + ,\r\n \"2603:1030:40c:1::7e0/123\",\r\n \"2603:1030:504:1::5c0/123\"\ + ,\r\n \"2603:1030:504:1::7e0/123\",\r\n \"2603:1030:807:1::5c0/123\"\ + ,\r\n \"2603:1030:807:1::7e0/123\",\r\n \"2603:1030:c06:1::5c0/123\"\ + ,\r\n \"2603:1030:f05:1::5c0/123\",\r\n \"2603:1030:f05:1::7e0/123\"\ + ,\r\n \"2603:1040:5::e0/123\",\r\n \"2603:1040:5:1::5c0/123\"\ + ,\r\n \"2603:1040:5:1::7e0/123\",\r\n \"2603:1040:407:1::5c0/123\"\ + ,\r\n \"2603:1040:407:1::7e0/123\",\r\n \"2603:1040:904:1::5c0/123\"\ + ,\r\n \"2603:1040:904:1::7e0/123\",\r\n \"2603:1040:a06::e0/123\"\ + ,\r\n \"2603:1040:a06:1::5c0/123\",\r\n \"2603:1040:a06:1::7e0/123\"\ + ,\r\n \"2603:1040:d04::5c0/123\",\r\n \"2603:1040:d04::7e0/123\"\ + ,\r\n \"2603:1040:f05:1::5c0/123\",\r\n \"2603:1040:f05:1::7e0/123\"\ + ,\r\n \"2603:1050:6:1::5c0/123\",\r\n \"2603:1050:6:1::7e0/123\"\ + ,\r\n \"2603:1050:403::5c0/123\",\r\n \"2a01:111:2050::/44\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureFrontDoor.FirstParty\"\ + ,\r\n \"id\": \"AzureFrontDoor.FirstParty\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureFrontDoor\",\r\n \"addressPrefixes\": [\r\n \"13.107.3.0/24\"\ + ,\r\n \"13.107.4.0/22\",\r\n \"13.107.9.0/24\",\r\n \ + \ \"13.107.12.0/23\",\r\n \"13.107.15.0/24\",\r\n \"\ + 13.107.16.0/24\",\r\n \"13.107.18.0/23\",\r\n \"13.107.21.0/24\"\ + ,\r\n \"13.107.22.0/24\",\r\n \"13.107.37.0/24\",\r\n \ + \ \"13.107.38.0/23\",\r\n \"13.107.40.0/24\",\r\n \ + \ \"13.107.42.0/23\",\r\n \"13.107.48.0/24\",\r\n \"13.107.50.0/24\"\ + ,\r\n \"13.107.52.0/24\",\r\n \"13.107.54.0/24\",\r\n \ + \ \"13.107.56.0/24\",\r\n \"13.107.64.0/18\",\r\n \ + \ \"13.107.128.0/19\",\r\n \"13.107.245.0/24\",\r\n \"\ + 13.107.254.0/23\",\r\n \"131.253.3.0/24\",\r\n \"131.253.21.0/24\"\ + ,\r\n \"131.253.33.0/24\",\r\n \"150.171.32.0/19\",\r\n\ + \ \"202.89.233.96/28\",\r\n \"204.79.197.0/24\",\r\n \ + \ \"2620:1ec:4::/46\",\r\n \"2620:1ec:a::/47\",\r\n \ + \ \"2620:1ec:c::/47\",\r\n \"2620:1ec:12::/47\",\r\n \"\ + 2620:1ec:21::/48\",\r\n \"2620:1ec:22::/48\",\r\n \"2620:1ec:26::/63\"\ + ,\r\n \"2620:1ec:26:2::/64\",\r\n \"2620:1ec:28::/48\",\r\ + \n \"2620:1ec:34::/48\",\r\n \"2620:1ec:39::/48\",\r\n \ + \ \"2620:1ec:3e::/47\",\r\n \"2620:1ec:42::/47\",\r\n \ + \ \"2620:1ec:44::/47\",\r\n \"2620:1ec:8f0::/44\",\r\n \ + \ \"2620:1ec:900::/44\",\r\n \"2620:1ec:a92::/48\",\r\n \ + \ \"2620:1ec:c11::/48\",\r\n \"2a01:111:2003::/48\",\r\n \ + \ \"2a01:111:202c::/46\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureFrontDoor.Frontend\",\r\n \"id\": \"AzureFrontDoor.Frontend\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"\",\r\n \"addressPrefixes\": [\r\n \"13.73.248.8/29\"\ + ,\r\n \"13.107.208.0/24\",\r\n \"13.107.219.0/24\",\r\n\ + \ \"13.107.246.0/24\",\r\n \"13.107.253.0/24\",\r\n \ + \ \"20.36.120.96/29\",\r\n \"20.37.64.96/29\",\r\n \ + \ \"20.37.156.112/29\",\r\n \"20.37.192.88/29\",\r\n \"\ + 20.37.224.96/29\",\r\n \"20.38.84.64/29\",\r\n \"20.38.136.96/29\"\ + ,\r\n \"20.39.11.0/29\",\r\n \"20.41.4.80/29\",\r\n \ + \ \"20.41.64.112/29\",\r\n \"20.41.192.96/29\",\r\n \ + \ \"20.42.4.112/29\",\r\n \"20.42.129.144/29\",\r\n \"\ + 20.42.224.96/29\",\r\n \"20.43.41.128/29\",\r\n \"20.43.64.88/29\"\ + ,\r\n \"20.43.128.104/29\",\r\n \"20.45.112.96/29\",\r\n\ + \ \"20.45.192.96/29\",\r\n \"20.150.160.72/29\",\r\n \ + \ \"20.189.106.72/29\",\r\n \"20.192.161.96/29\",\r\n \ + \ \"20.192.225.40/29\",\r\n \"40.67.48.96/29\",\r\n \ + \ \"40.74.30.64/29\",\r\n \"40.80.56.96/29\",\r\n \"40.80.168.96/29\"\ + ,\r\n \"40.80.184.112/29\",\r\n \"40.82.248.72/29\",\r\n\ + \ \"40.89.16.96/29\",\r\n \"51.12.41.0/29\",\r\n \ + \ \"51.12.193.0/29\",\r\n \"51.104.24.88/29\",\r\n \"\ + 51.105.80.96/29\",\r\n \"51.105.88.96/29\",\r\n \"51.107.48.96/29\"\ + ,\r\n \"51.107.144.96/29\",\r\n \"51.120.40.96/29\",\r\n\ + \ \"51.120.224.96/29\",\r\n \"51.137.160.88/29\",\r\n \ + \ \"51.143.192.96/29\",\r\n \"52.136.48.96/29\",\r\n \ + \ \"52.140.104.96/29\",\r\n \"52.150.136.112/29\",\r\n \ + \ \"52.228.80.112/29\",\r\n \"102.133.56.80/29\",\r\n \ + \ \"102.133.216.80/29\",\r\n \"191.233.9.112/29\",\r\n \ + \ \"191.235.224.88/29\",\r\n \"2603:1000:104::c0/123\",\r\n \ + \ \"2603:1000:104::160/123\",\r\n \"2603:1000:104:1::5a0/123\"\ + ,\r\n \"2603:1000:104:1::7c0/123\",\r\n \"2603:1010:6:1::5a0/123\"\ + ,\r\n \"2603:1010:6:1::7c0/123\",\r\n \"2603:1020:5:1::5a0/123\"\ + ,\r\n \"2603:1020:5:1::7c0/123\",\r\n \"2603:1020:206:1::5a0/123\"\ + ,\r\n \"2603:1020:206:1::7c0/123\",\r\n \"2603:1020:705:1::5a0/123\"\ + ,\r\n \"2603:1020:705:1::7c0/123\",\r\n \"2603:1020:805:1::5a0/123\"\ + ,\r\n \"2603:1020:805:1::7c0/123\",\r\n \"2603:1020:a04:1::5a0/123\"\ + ,\r\n \"2603:1020:a04:1::7c0/123\",\r\n \"2603:1020:c04:1::5a0/123\"\ + ,\r\n \"2603:1020:c04:1::7c0/123\",\r\n \"2603:1020:e04:1::5a0/123\"\ + ,\r\n \"2603:1020:e04:1::7c0/123\",\r\n \"2603:1020:1004::5a0/123\"\ + ,\r\n \"2603:1020:1004::7c0/123\",\r\n \"2603:1030:10:1::5a0/123\"\ + ,\r\n \"2603:1030:10:1::7c0/123\",\r\n \"2603:1030:104:1::5a0/123\"\ + ,\r\n \"2603:1030:104:1::7c0/123\",\r\n \"2603:1030:210:1::5a0/123\"\ + ,\r\n \"2603:1030:210:1::7c0/123\",\r\n \"2603:1030:40b:1::5a0/123\"\ + ,\r\n \"2603:1030:40c:1::5a0/123\",\r\n \"2603:1030:40c:1::7c0/123\"\ + ,\r\n \"2603:1030:504:1::5a0/123\",\r\n \"2603:1030:504:1::7c0/123\"\ + ,\r\n \"2603:1030:807:1::5a0/123\",\r\n \"2603:1030:807:1::7c0/123\"\ + ,\r\n \"2603:1030:c06:1::5a0/123\",\r\n \"2603:1030:f05:1::5a0/123\"\ + ,\r\n \"2603:1030:f05:1::7c0/123\",\r\n \"2603:1040:5::c0/123\"\ + ,\r\n \"2603:1040:5:1::5a0/123\",\r\n \"2603:1040:5:1::7c0/123\"\ + ,\r\n \"2603:1040:407:1::5a0/123\",\r\n \"2603:1040:407:1::7c0/123\"\ + ,\r\n \"2603:1040:904:1::5a0/123\",\r\n \"2603:1040:904:1::7c0/123\"\ + ,\r\n \"2603:1040:a06::c0/123\",\r\n \"2603:1040:a06:1::5a0/123\"\ + ,\r\n \"2603:1040:a06:1::7c0/123\",\r\n \"2603:1040:d04::5a0/123\"\ + ,\r\n \"2603:1040:d04::7c0/123\",\r\n \"2603:1040:f05:1::5a0/123\"\ + ,\r\n \"2603:1040:f05:1::7c0/123\",\r\n \"2603:1050:6:1::5a0/123\"\ + ,\r\n \"2603:1050:6:1::7c0/123\",\r\n \"2603:1050:403::5a0/123\"\ + ,\r\n \"2620:1ec:29::/48\",\r\n \"2620:1ec:40::/47\",\r\n\ + \ \"2620:1ec:bdf::/48\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureInformationProtection\",\r\n \"id\": \"\ + AzureInformationProtection\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"FW\"\r\n ],\r\n \"systemService\": \"AzureInformationProtection\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.153.57/32\",\r\n\ + \ \"13.66.245.220/32\",\r\n \"13.66.251.171/32\",\r\n \ + \ \"13.67.114.221/32\",\r\n \"13.68.179.152/32\",\r\n \ + \ \"13.76.139.8/32\",\r\n \"13.76.244.119/32\",\r\n \ + \ \"13.77.166.40/32\",\r\n \"13.77.203.47/32\",\r\n \"\ + 13.78.130.67/32\",\r\n \"13.78.130.185/32\",\r\n \"13.78.178.191/32\"\ + ,\r\n \"13.79.189.239/32\",\r\n \"13.79.189.241/32\",\r\n\ + \ \"13.82.198.231/32\",\r\n \"13.83.91.144/32\",\r\n \ + \ \"13.92.58.123/32\",\r\n \"13.92.61.93/32\",\r\n \ + \ \"13.93.72.133/32\",\r\n \"13.93.75.214/32\",\r\n \"\ + 13.94.98.184/32\",\r\n \"13.94.116.226/32\",\r\n \"23.97.70.206/32\"\ + ,\r\n \"23.99.106.184/32\",\r\n \"23.99.114.156/32\",\r\n\ + \ \"23.99.251.107/32\",\r\n \"23.101.112.34/32\",\r\n \ + \ \"23.101.147.227/32\",\r\n \"23.101.163.169/32\",\r\n \ + \ \"40.69.191.65/32\",\r\n \"40.70.16.196/32\",\r\n \ + \ \"40.76.94.49/32\",\r\n \"40.83.177.47/32\",\r\n \"\ + 40.83.223.214/32\",\r\n \"40.87.2.166/32\",\r\n \"40.87.67.213/32\"\ + ,\r\n \"40.87.94.91/32\",\r\n \"40.114.2.72/32\",\r\n \ + \ \"40.117.180.9/32\",\r\n \"40.121.48.207/32\",\r\n \ + \ \"40.121.49.153/32\",\r\n \"40.121.90.82/32\",\r\n \ + \ \"40.127.160.102/32\",\r\n \"40.127.175.173/32\",\r\n \ + \ \"51.136.18.12/32\",\r\n \"51.141.184.35/32\",\r\n \"\ + 51.143.32.47/32\",\r\n \"51.143.88.135/32\",\r\n \"51.144.167.90/32\"\ + ,\r\n \"51.145.146.97/32\",\r\n \"52.162.33.18/32\",\r\n\ + \ \"52.162.37.146/32\",\r\n \"52.162.88.200/32\",\r\n \ + \ \"52.162.95.132/32\",\r\n \"52.162.208.48/32\",\r\n \ + \ \"52.163.61.51/32\",\r\n \"52.163.85.21/32\",\r\n \ + \ \"52.163.85.129/32\",\r\n \"52.163.87.92/32\",\r\n \"\ + 52.163.89.155/32\",\r\n \"52.163.89.160/32\",\r\n \"52.165.189.139/32\"\ + ,\r\n \"52.167.1.118/32\",\r\n \"52.167.225.247/32\",\r\n\ + \ \"52.167.226.2/32\",\r\n \"52.167.227.104/32\",\r\n \ + \ \"52.167.227.154/32\",\r\n \"52.173.21.111/32\",\r\n \ + \ \"52.173.89.54/32\",\r\n \"52.173.89.66/32\",\r\n \ + \ \"52.173.93.137/32\",\r\n \"52.176.44.178/32\",\r\n \ + \ \"52.178.145.186/32\",\r\n \"52.178.147.96/32\",\r\n \"\ + 52.179.136.129/32\",\r\n \"52.184.34.233/32\",\r\n \"52.184.35.49/32\"\ + ,\r\n \"52.232.110.114/32\",\r\n \"52.232.113.160/32\",\r\ + \n \"52.232.118.97/32\",\r\n \"52.232.119.81/32\",\r\n \ + \ \"52.237.141.83/32\",\r\n \"52.237.141.229/32\",\r\n \ + \ \"52.250.56.125/32\",\r\n \"65.52.36.85/32\",\r\n \ + \ \"65.52.55.108/32\",\r\n \"65.52.176.250/32\",\r\n \ + \ \"65.52.177.192/32\",\r\n \"65.52.184.44/32\",\r\n \"\ + 65.52.184.218/32\",\r\n \"65.52.236.123/32\",\r\n \"70.37.163.131/32\"\ + ,\r\n \"94.245.88.160/32\",\r\n \"104.40.16.135/32\",\r\n\ + \ \"104.40.30.29/32\",\r\n \"104.41.143.145/32\",\r\n \ + \ \"137.116.91.123/32\",\r\n \"137.117.47.75/32\",\r\n \ + \ \"138.91.121.248/32\",\r\n \"138.91.122.178/32\",\r\n \ + \ \"157.55.177.248/32\",\r\n \"157.55.185.205/32\",\r\n \ + \ \"157.56.8.93/32\",\r\n \"157.56.8.135/32\",\r\n \ + \ \"157.56.9.127/32\",\r\n \"168.61.46.212/32\",\r\n \"\ + 168.62.5.167/32\",\r\n \"168.62.8.139/32\",\r\n \"168.62.25.173/32\"\ + ,\r\n \"168.62.25.179/32\",\r\n \"168.62.48.148/32\",\r\n\ + \ \"168.62.49.18/32\",\r\n \"168.62.52.244/32\",\r\n \ + \ \"168.62.53.73/32\",\r\n \"168.62.53.132/32\",\r\n \ + \ \"168.62.54.75/32\",\r\n \"168.62.54.211/32\",\r\n \ + \ \"168.62.54.212/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureInformationProtection.NorthCentralUS\",\r\n \"id\"\ + : \"AzureInformationProtection.NorthCentralUS\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureInformationProtection\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.101.163.169/32\",\r\n \"52.162.33.18/32\",\r\n \ + \ \"52.162.37.146/32\",\r\n \"52.162.88.200/32\",\r\n \ + \ \"52.162.95.132/32\",\r\n \"52.162.208.48/32\",\r\n \ + \ \"52.237.141.83/32\",\r\n \"52.237.141.229/32\",\r\n \ + \ \"65.52.55.108/32\",\r\n \"65.52.236.123/32\",\r\n \"\ + 157.56.8.93/32\",\r\n \"157.56.8.135/32\",\r\n \"157.56.9.127/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureInformationProtection.WestEurope\"\ + ,\r\n \"id\": \"AzureInformationProtection.WestEurope\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureInformationProtection\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.93.72.133/32\",\r\n \"13.93.75.214/32\",\r\n\ + \ \"51.136.18.12/32\",\r\n \"51.144.167.90/32\",\r\n \ + \ \"51.145.146.97/32\",\r\n \"52.232.110.114/32\",\r\n \ + \ \"52.232.113.160/32\",\r\n \"52.232.118.97/32\",\r\n \ + \ \"52.232.119.81/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureInformationProtection.WestUS2\",\r\n \"id\":\ + \ \"AzureInformationProtection.WestUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureInformationProtection\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.153.57/32\",\r\n \"13.66.245.220/32\",\r\n \ + \ \"13.66.251.171/32\",\r\n \"13.77.166.40/32\",\r\n \ + \ \"51.141.184.35/32\",\r\n \"51.143.32.47/32\",\r\n \"\ + 51.143.88.135/32\",\r\n \"52.250.56.125/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub\",\r\n \"id\"\ + : \"AzureIoTHub\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"FW\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.142.96/27\",\r\n\ + \ \"13.67.10.224/27\",\r\n \"13.67.234.22/32\",\r\n \ + \ \"13.69.71.0/25\",\r\n \"13.69.109.0/25\",\r\n \"\ + 13.69.192.43/32\",\r\n \"13.69.230.64/27\",\r\n \"13.70.74.192/27\"\ + ,\r\n \"13.70.182.204/32\",\r\n \"13.70.182.210/32\",\r\n\ + \ \"13.71.84.34/32\",\r\n \"13.71.113.127/32\",\r\n \ + \ \"13.71.150.19/32\",\r\n \"13.71.175.32/27\",\r\n \ + \ \"13.71.196.224/27\",\r\n \"13.73.115.51/32\",\r\n \"\ + 13.73.244.0/27\",\r\n \"13.73.252.128/25\",\r\n \"13.74.108.192/27\"\ + ,\r\n \"13.75.39.160/27\",\r\n \"13.76.83.155/32\",\r\n\ + \ \"13.76.217.46/32\",\r\n \"13.77.53.128/27\",\r\n \ + \ \"13.78.109.160/27\",\r\n \"13.78.129.154/32\",\r\n \ + \ \"13.78.130.69/32\",\r\n \"13.79.172.43/32\",\r\n \"\ + 13.82.93.138/32\",\r\n \"13.84.189.6/32\",\r\n \"13.85.68.113/32\"\ + ,\r\n \"13.86.221.0/25\",\r\n \"13.87.58.96/27\",\r\n \ + \ \"13.87.124.96/27\",\r\n \"13.89.174.160/27\",\r\n \ + \ \"13.89.231.149/32\",\r\n \"13.94.40.72/32\",\r\n \ + \ \"13.95.15.251/32\",\r\n \"20.36.108.160/27\",\r\n \"\ + 20.36.117.64/27\",\r\n \"20.36.123.32/27\",\r\n \"20.36.123.128/25\"\ + ,\r\n \"20.37.67.128/25\",\r\n \"20.37.68.0/27\",\r\n \ + \ \"20.37.76.160/27\",\r\n \"20.37.198.160/27\",\r\n \ + \ \"20.37.199.0/25\",\r\n \"20.37.227.64/27\",\r\n \"\ + 20.37.227.128/25\",\r\n \"20.38.128.128/27\",\r\n \"20.38.139.128/25\"\ + ,\r\n \"20.38.140.0/27\",\r\n \"20.38.147.192/27\",\r\n\ + \ \"20.39.14.32/27\",\r\n \"20.39.14.128/25\",\r\n \ + \ \"20.40.206.192/27\",\r\n \"20.40.207.0/25\",\r\n \ + \ \"20.41.68.96/27\",\r\n \"20.41.68.128/25\",\r\n \"20.41.197.64/27\"\ + ,\r\n \"20.41.197.128/25\",\r\n \"20.42.230.160/27\",\r\n\ + \ \"20.42.231.0/25\",\r\n \"20.43.44.160/27\",\r\n \ + \ \"20.43.45.0/25\",\r\n \"20.43.70.160/27\",\r\n \"\ + 20.43.71.0/25\",\r\n \"20.43.121.64/27\",\r\n \"20.44.4.128/27\"\ + ,\r\n \"20.44.8.224/27\",\r\n \"20.44.17.96/27\",\r\n \ + \ \"20.44.29.0/27\",\r\n \"20.45.114.224/27\",\r\n \ + \ \"20.45.115.0/25\",\r\n \"20.45.123.128/27\",\r\n \"\ + 20.45.198.32/27\",\r\n \"20.45.198.128/25\",\r\n \"20.49.83.128/27\"\ + ,\r\n \"20.49.91.128/27\",\r\n \"20.49.99.96/27\",\r\n \ + \ \"20.49.99.128/25\",\r\n \"20.49.109.128/25\",\r\n \ + \ \"20.49.110.0/26\",\r\n \"20.49.110.128/25\",\r\n \ + \ \"20.49.113.32/27\",\r\n \"20.49.113.128/25\",\r\n \"\ + 20.49.120.96/27\",\r\n \"20.49.120.128/25\",\r\n \"20.49.121.0/25\"\ + ,\r\n \"20.50.65.128/25\",\r\n \"20.50.68.0/27\",\r\n \ + \ \"20.150.165.192/27\",\r\n \"20.150.166.0/25\",\r\n \ + \ \"20.150.172.192/27\",\r\n \"20.150.179.224/27\",\r\n \ + \ \"20.150.187.224/27\",\r\n \"20.187.195.0/25\",\r\n \ + \ \"20.188.0.51/32\",\r\n \"20.188.3.145/32\",\r\n \"\ + 20.188.39.126/32\",\r\n \"20.189.109.192/27\",\r\n \"20.192.99.224/27\"\ + ,\r\n \"20.192.165.224/27\",\r\n \"20.192.166.0/25\",\r\n\ + \ \"20.192.230.32/27\",\r\n \"20.192.230.128/25\",\r\n \ + \ \"20.192.238.0/27\",\r\n \"20.193.206.0/27\",\r\n \ + \ \"20.194.67.96/27\",\r\n \"23.96.222.45/32\",\r\n \ + \ \"23.96.223.89/32\",\r\n \"23.98.86.0/27\",\r\n \"23.98.104.192/27\"\ + ,\r\n \"23.98.106.0/25\",\r\n \"23.99.109.81/32\",\r\n \ + \ \"23.100.4.253/32\",\r\n \"23.100.8.130/32\",\r\n \ + \ \"23.100.105.192/32\",\r\n \"23.101.29.228/32\",\r\n \ + \ \"23.102.235.31/32\",\r\n \"40.64.132.160/27\",\r\n \ + \ \"40.64.134.0/25\",\r\n \"40.67.51.0/25\",\r\n \"40.67.51.128/27\"\ + ,\r\n \"40.67.60.128/27\",\r\n \"40.69.108.128/27\",\r\n\ + \ \"40.70.148.128/27\",\r\n \"40.71.14.128/25\",\r\n \ + \ \"40.74.66.139/32\",\r\n \"40.74.125.44/32\",\r\n \ + \ \"40.74.149.0/27\",\r\n \"40.75.35.96/27\",\r\n \"40.76.71.185/32\"\ + ,\r\n \"40.77.23.107/32\",\r\n \"40.78.22.17/32\",\r\n \ + \ \"40.78.196.96/27\",\r\n \"40.78.204.64/27\",\r\n \ + \ \"40.78.229.128/25\",\r\n \"40.78.238.0/27\",\r\n \ + \ \"40.78.245.32/27\",\r\n \"40.78.251.160/27\",\r\n \"\ + 40.79.114.144/32\",\r\n \"40.79.132.128/27\",\r\n \"40.79.139.32/27\"\ + ,\r\n \"40.79.148.0/27\",\r\n \"40.79.156.128/25\",\r\n\ + \ \"40.79.163.32/27\",\r\n \"40.79.171.128/27\",\r\n \ + \ \"40.79.180.96/27\",\r\n \"40.79.187.224/27\",\r\n \ + \ \"40.79.195.192/27\",\r\n \"40.80.51.128/27\",\r\n \ + \ \"40.80.62.64/27\",\r\n \"40.80.62.128/25\",\r\n \"40.80.172.64/27\"\ + ,\r\n \"40.80.172.128/25\",\r\n \"40.80.176.64/27\",\r\n\ + \ \"40.83.177.42/32\",\r\n \"40.84.53.157/32\",\r\n \ + \ \"40.87.138.172/32\",\r\n \"40.87.143.97/32\",\r\n \ + \ \"40.89.20.192/27\",\r\n \"40.89.21.0/25\",\r\n \"40.112.221.188/32\"\ + ,\r\n \"40.112.223.235/32\",\r\n \"40.113.153.50/32\",\r\ + \n \"40.113.176.160/27\",\r\n \"40.113.176.192/27\",\r\n\ + \ \"40.113.177.0/24\",\r\n \"40.114.53.146/32\",\r\n \ + \ \"40.118.27.192/32\",\r\n \"40.119.11.224/27\",\r\n \ + \ \"40.120.75.160/27\",\r\n \"40.127.132.17/32\",\r\n \ + \ \"51.12.42.32/27\",\r\n \"51.12.42.128/25\",\r\n \"\ + 51.12.100.64/27\",\r\n \"51.12.194.32/27\",\r\n \"51.12.194.128/25\"\ + ,\r\n \"51.12.204.64/27\",\r\n \"51.12.227.224/27\",\r\n\ + \ \"51.12.235.224/27\",\r\n \"51.104.30.0/25\",\r\n \ + \ \"51.104.30.128/27\",\r\n \"51.105.69.0/27\",\r\n \ + \ \"51.105.75.192/27\",\r\n \"51.105.91.128/25\",\r\n \"\ + 51.105.92.0/27\",\r\n \"51.107.51.64/27\",\r\n \"51.107.51.128/25\"\ + ,\r\n \"51.107.60.96/27\",\r\n \"51.107.147.64/27\",\r\n\ + \ \"51.107.147.128/25\",\r\n \"51.107.156.96/27\",\r\n \ + \ \"51.116.49.224/27\",\r\n \"51.116.50.0/25\",\r\n \ + \ \"51.116.60.96/27\",\r\n \"51.116.145.192/27\",\r\n \ + \ \"51.116.146.0/25\",\r\n \"51.116.158.0/27\",\r\n \"\ + 51.116.243.160/27\",\r\n \"51.116.251.128/27\",\r\n \"51.120.43.128/25\"\ + ,\r\n \"51.120.44.0/27\",\r\n \"51.120.100.96/27\",\r\n\ + \ \"51.120.107.224/27\",\r\n \"51.120.211.224/27\",\r\n\ + \ \"51.120.227.128/25\",\r\n \"51.120.228.0/27\",\r\n \ + \ \"51.137.164.160/27\",\r\n \"51.137.165.0/25\",\r\n \ + \ \"51.140.84.251/32\",\r\n \"51.140.126.10/32\",\r\n \ + \ \"51.140.149.32/27\",\r\n \"51.140.212.160/27\",\r\n \ + \ \"51.140.226.207/32\",\r\n \"51.140.240.234/32\",\r\n \ + \ \"51.141.49.253/32\",\r\n \"51.144.118.31/32\",\r\n \ + \ \"52.136.51.128/25\",\r\n \"52.136.52.0/27\",\r\n \"52.136.132.236/32\"\ + ,\r\n \"52.138.92.96/27\",\r\n \"52.138.229.0/27\",\r\n\ + \ \"52.140.108.160/27\",\r\n \"52.140.109.0/25\",\r\n \ + \ \"52.147.10.141/32\",\r\n \"52.147.10.149/32\",\r\n \ + \ \"52.150.152.96/27\",\r\n \"52.150.153.128/25\",\r\n \ + \ \"52.151.6.77/32\",\r\n \"52.151.78.51/32\",\r\n \"\ + 52.158.236.252/32\",\r\n \"52.161.15.247/32\",\r\n \"52.162.111.64/27\"\ + ,\r\n \"52.163.212.39/32\",\r\n \"52.163.215.122/32\",\r\ + \n \"52.167.107.192/27\",\r\n \"52.167.155.89/32\",\r\n\ + \ \"52.168.180.95/32\",\r\n \"52.169.138.222/32\",\r\n \ + \ \"52.172.203.144/32\",\r\n \"52.175.221.106/32\",\r\n \ + \ \"52.176.4.4/32\",\r\n \"52.176.92.27/32\",\r\n \ + \ \"52.177.196.50/32\",\r\n \"52.178.147.144/32\",\r\n \ + \ \"52.179.159.231/32\",\r\n \"52.180.165.88/32\",\r\n \ + \ \"52.180.165.248/32\",\r\n \"52.180.177.125/32\",\r\n \ + \ \"52.182.139.224/27\",\r\n \"52.225.176.167/32\",\r\n \ + \ \"52.225.177.25/32\",\r\n \"52.225.179.220/32\",\r\n \"\ + 52.225.180.26/32\",\r\n \"52.225.180.217/32\",\r\n \"52.225.187.149/32\"\ + ,\r\n \"52.228.85.224/27\",\r\n \"52.228.86.0/25\",\r\n\ + \ \"52.231.20.32/27\",\r\n \"52.231.32.236/32\",\r\n \ + \ \"52.231.148.128/27\",\r\n \"52.231.205.15/32\",\r\n \ + \ \"52.236.189.128/25\",\r\n \"52.237.27.123/32\",\r\n \ + \ \"52.242.31.77/32\",\r\n \"52.246.155.192/27\",\r\n \ + \ \"52.250.225.32/27\",\r\n \"65.52.252.160/27\",\r\n \ + \ \"102.133.28.160/27\",\r\n \"102.133.59.0/25\",\r\n \"\ + 102.133.59.128/27\",\r\n \"102.133.124.32/27\",\r\n \"102.133.156.64/27\"\ + ,\r\n \"102.133.218.192/27\",\r\n \"102.133.219.0/25\",\r\ + \n \"102.133.251.128/27\",\r\n \"104.40.49.44/32\",\r\n\ + \ \"104.41.34.180/32\",\r\n \"104.43.252.98/32\",\r\n \ + \ \"104.46.115.237/32\",\r\n \"104.210.105.7/32\",\r\n \ + \ \"104.211.210.195/32\",\r\n \"104.214.34.123/32\",\r\n \ + \ \"137.117.83.38/32\",\r\n \"168.61.54.255/32\",\r\n \ + \ \"168.61.208.218/32\",\r\n \"191.233.11.160/27\",\r\n \ + \ \"191.233.14.0/25\",\r\n \"191.233.54.0/27\",\r\n \ + \ \"191.233.205.128/27\",\r\n \"191.234.136.128/25\",\r\n \ + \ \"191.234.137.0/27\",\r\n \"191.234.147.224/27\",\r\n \ + \ \"191.234.155.224/27\",\r\n \"207.46.138.102/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureIoTHub.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.108.160/27\",\r\n\ + \ \"20.37.227.64/27\",\r\n \"20.37.227.128/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.AustraliaCentral2\"\ + ,\r\n \"id\": \"AzureIoTHub.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.117.64/27\",\r\n\ + \ \"20.36.123.32/27\",\r\n \"20.36.123.128/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.AustraliaEast\"\ + ,\r\n \"id\": \"AzureIoTHub.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.74.192/27\",\r\n\ + \ \"20.37.198.160/27\",\r\n \"20.37.199.0/25\",\r\n \ + \ \"40.79.163.32/27\",\r\n \"40.79.171.128/27\",\r\n \ + \ \"52.147.10.141/32\",\r\n \"52.147.10.149/32\",\r\n \ + \ \"104.210.105.7/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureIoTHub.AustraliaSoutheast\",\r\n \"id\": \"AzureIoTHub.AustraliaSoutheast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n\ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \ + \ \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\":\ + \ [\r\n \"13.70.182.204/32\",\r\n \"13.70.182.210/32\",\r\ + \n \"13.73.115.51/32\",\r\n \"13.77.53.128/27\",\r\n \ + \ \"20.42.230.160/27\",\r\n \"20.42.231.0/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.BrazilSouth\"\ + ,\r\n \"id\": \"AzureIoTHub.BrazilSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"104.41.34.180/32\",\r\n\ + \ \"191.233.205.128/27\",\r\n \"191.234.136.128/25\",\r\n\ + \ \"191.234.137.0/27\",\r\n \"191.234.147.224/27\",\r\n\ + \ \"191.234.155.224/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureIoTHub.CanadaCentral\",\r\n \"id\": \"\ + AzureIoTHub.CanadaCentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"canadacentral\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\ + \n \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.175.32/27\",\r\n \"20.38.147.192/27\",\r\ + \n \"52.228.85.224/27\",\r\n \"52.228.86.0/25\",\r\n \ + \ \"52.237.27.123/32\",\r\n \"52.246.155.192/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.CanadaEast\"\ + ,\r\n \"id\": \"AzureIoTHub.CanadaEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"40.69.108.128/27\",\r\n \ + \ \"40.89.20.192/27\",\r\n \"40.89.21.0/25\",\r\n \ + \ \"52.242.31.77/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureIoTHub.CentralIndia\",\r\n \"id\": \"AzureIoTHub.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.43.121.64/27\",\r\n \"20.192.99.224/27\",\r\n \ + \ \"40.80.51.128/27\",\r\n \"52.140.108.160/27\",\r\n \ + \ \"52.140.109.0/25\",\r\n \"52.172.203.144/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.CentralUS\"\ + ,\r\n \"id\": \"AzureIoTHub.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"13.67.234.22/32\",\r\n \ + \ \"13.89.174.160/27\",\r\n \"13.89.231.149/32\",\r\n \ + \ \"20.40.206.192/27\",\r\n \"20.40.207.0/25\",\r\n \ + \ \"20.44.8.224/27\",\r\n \"40.77.23.107/32\",\r\n \"52.176.4.4/32\"\ + ,\r\n \"52.176.92.27/32\",\r\n \"52.182.139.224/27\",\r\n\ + \ \"104.43.252.98/32\",\r\n \"168.61.208.218/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureIoTHub.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.45.198.32/27\",\r\n\ + \ \"20.45.198.128/25\",\r\n \"40.78.204.64/27\",\r\n \ + \ \"52.180.165.88/32\",\r\n \"52.180.165.248/32\",\r\n \ + \ \"52.180.177.125/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureIoTHub.EastAsia\",\r\n \"id\": \"AzureIoTHub.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.75.39.160/27\"\ + ,\r\n \"13.94.40.72/32\",\r\n \"20.187.195.0/25\",\r\n \ + \ \"20.189.109.192/27\",\r\n \"23.99.109.81/32\",\r\n \ + \ \"23.102.235.31/32\",\r\n \"207.46.138.102/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS\"\ + ,\r\n \"id\": \"AzureIoTHub.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.82.93.138/32\",\r\n \ + \ \"20.49.109.128/25\",\r\n \"20.49.110.0/26\",\r\n \ + \ \"20.49.110.128/25\",\r\n \"40.71.14.128/25\",\r\n \"\ + 40.76.71.185/32\",\r\n \"40.78.229.128/25\",\r\n \"40.79.156.128/25\"\ + ,\r\n \"40.114.53.146/32\",\r\n \"52.168.180.95/32\",\r\n\ + \ \"137.117.83.38/32\",\r\n \"168.61.54.255/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS2\"\ + ,\r\n \"id\": \"AzureIoTHub.EastUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.44.17.96/27\",\r\n \ + \ \"20.49.99.96/27\",\r\n \"20.49.99.128/25\",\r\n \"\ + 40.70.148.128/27\",\r\n \"40.84.53.157/32\",\r\n \"52.167.107.192/27\"\ + ,\r\n \"52.167.155.89/32\",\r\n \"52.177.196.50/32\",\r\n\ + \ \"52.179.159.231/32\",\r\n \"104.46.115.237/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureIoTHub.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.39.14.32/27\",\r\n \ + \ \"20.39.14.128/25\",\r\n \"40.74.149.0/27\",\r\n \ + \ \"40.75.35.96/27\",\r\n \"40.79.114.144/32\",\r\n \"\ + 52.138.92.96/27\",\r\n \"52.225.176.167/32\",\r\n \"52.225.177.25/32\"\ + ,\r\n \"52.225.179.220/32\",\r\n \"52.225.180.26/32\",\r\ + \n \"52.225.180.217/32\",\r\n \"52.225.187.149/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.FranceCentral\"\ + ,\r\n \"id\": \"AzureIoTHub.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.44.160/27\",\r\n\ + \ \"20.43.45.0/25\",\r\n \"20.188.39.126/32\",\r\n \ + \ \"40.79.132.128/27\",\r\n \"40.79.139.32/27\",\r\n \ + \ \"40.79.148.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureIoTHub.FranceSouth\",\r\n \"id\": \"AzureIoTHub.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.79.180.96/27\",\r\n \"51.105.91.128/25\",\r\n \ + \ \"51.105.92.0/27\",\r\n \"52.136.132.236/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.GermanyNorth\"\ + ,\r\n \"id\": \"AzureIoTHub.GermanyNorth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.49.224/27\",\r\n\ + \ \"51.116.50.0/25\",\r\n \"51.116.60.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureIoTHub.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.145.192/27\",\r\n\ + \ \"51.116.146.0/25\",\r\n \"51.116.158.0/27\",\r\n \ + \ \"51.116.243.160/27\",\r\n \"51.116.251.128/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.JapanEast\"\ + ,\r\n \"id\": \"AzureIoTHub.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"13.71.150.19/32\",\r\n \ + \ \"13.78.109.160/27\",\r\n \"20.43.70.160/27\",\r\n \ + \ \"20.43.71.0/25\",\r\n \"20.188.0.51/32\",\r\n \"20.188.3.145/32\"\ + ,\r\n \"40.79.187.224/27\",\r\n \"40.79.195.192/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.JapanWest\"\ + ,\r\n \"id\": \"AzureIoTHub.JapanWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"23.100.105.192/32\",\r\n \ + \ \"40.74.66.139/32\",\r\n \"40.74.125.44/32\",\r\n \ + \ \"40.80.62.64/27\",\r\n \"40.80.62.128/25\",\r\n \"\ + 40.80.176.64/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureIoTHub.KoreaCentral\",\r\n \"id\": \"AzureIoTHub.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.41.68.96/27\",\r\n \"20.41.68.128/25\",\r\n \ + \ \"20.44.29.0/27\",\r\n \"20.194.67.96/27\",\r\n \"52.231.20.32/27\"\ + ,\r\n \"52.231.32.236/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureIoTHub.KoreaSouth\",\r\n \"id\": \"\ + AzureIoTHub.KoreaSouth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"koreasouth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n\ + \ \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.80.172.64/27\",\r\n \"40.80.172.128/25\",\r\ + \n \"52.231.148.128/27\",\r\n \"52.231.205.15/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorthCentralUS\"\ + ,\r\n \"id\": \"AzureIoTHub.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.49.113.32/27\",\r\n\ + \ \"20.49.113.128/25\",\r\n \"23.96.222.45/32\",\r\n \ + \ \"23.96.223.89/32\",\r\n \"52.162.111.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorthEurope\"\ + ,\r\n \"id\": \"AzureIoTHub.NorthEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.192.43/32\",\r\n\ + \ \"13.69.230.64/27\",\r\n \"13.74.108.192/27\",\r\n \ + \ \"13.79.172.43/32\",\r\n \"20.50.65.128/25\",\r\n \ + \ \"20.50.68.0/27\",\r\n \"40.87.138.172/32\",\r\n \"\ + 40.87.143.97/32\",\r\n \"40.127.132.17/32\",\r\n \"52.138.229.0/27\"\ + ,\r\n \"52.169.138.222/32\",\r\n \"52.178.147.144/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorwayEast\"\ + ,\r\n \"id\": \"AzureIoTHub.NorwayEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.120.43.128/25\",\r\n \ + \ \"51.120.44.0/27\",\r\n \"51.120.100.96/27\",\r\n \ + \ \"51.120.107.224/27\",\r\n \"51.120.211.224/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.NorwayWest\"\ + ,\r\n \"id\": \"AzureIoTHub.NorwayWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.120.227.128/25\",\r\n \ + \ \"51.120.228.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureIoTHub.SouthAfricaNorth\",\r\n \"id\": \"AzureIoTHub.SouthAfricaNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \ + \ \"systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\ + \n \"102.133.124.32/27\",\r\n \"102.133.156.64/27\",\r\n\ + \ \"102.133.218.192/27\",\r\n \"102.133.219.0/25\",\r\n\ + \ \"102.133.251.128/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureIoTHub.SouthAfricaWest\",\r\n \"id\":\ + \ \"AzureIoTHub.SouthAfricaWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.133.28.160/27\",\r\n \ + \ \"102.133.59.0/25\",\r\n \"102.133.59.128/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureIoTHub.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.244.0/27\",\r\n \ + \ \"13.73.252.128/25\",\r\n \"13.84.189.6/32\",\r\n \ + \ \"13.85.68.113/32\",\r\n \"20.45.123.128/27\",\r\n \ + \ \"20.49.91.128/27\",\r\n \"40.119.11.224/27\",\r\n \"\ + 104.214.34.123/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureIoTHub.SoutheastAsia\",\r\n \"id\": \"AzureIoTHub.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.10.224/27\",\r\n \"13.76.83.155/32\",\r\n \ + \ \"13.76.217.46/32\",\r\n \"23.98.86.0/27\",\r\n \"\ + 23.98.104.192/27\",\r\n \"23.98.106.0/25\",\r\n \"23.101.29.228/32\"\ + ,\r\n \"40.78.238.0/27\",\r\n \"52.163.212.39/32\",\r\n\ + \ \"52.163.215.122/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureIoTHub.SouthIndia\",\r\n \"id\": \"AzureIoTHub.SouthIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.84.34/32\"\ + ,\r\n \"13.71.113.127/32\",\r\n \"20.41.197.64/27\",\r\n\ + \ \"20.41.197.128/25\",\r\n \"40.78.196.96/27\",\r\n \ + \ \"104.211.210.195/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureIoTHub.SwitzerlandNorth\",\r\n \"id\": \"AzureIoTHub.SwitzerlandNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.51.64/27\",\r\n \"51.107.51.128/25\",\r\n \ + \ \"51.107.60.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureIoTHub.SwitzerlandWest\",\r\n \"id\": \"AzureIoTHub.SwitzerlandWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.147.64/27\",\r\n \"51.107.147.128/25\",\r\n \ + \ \"51.107.156.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureIoTHub.UAECentral\",\r\n \"id\": \"AzureIoTHub.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \"20.37.67.128/25\"\ + ,\r\n \"20.37.68.0/27\",\r\n \"20.37.76.160/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UAENorth\"\ + ,\r\n \"id\": \"AzureIoTHub.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.38.139.128/25\",\r\n \ + \ \"20.38.140.0/27\",\r\n \"40.120.75.160/27\",\r\n \ + \ \"65.52.252.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureIoTHub.UKNorth\",\r\n \"id\": \"AzureIoTHub.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.124.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKSouth\"\ + ,\r\n \"id\": \"AzureIoTHub.UKSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.104.30.0/25\",\r\n \ + \ \"51.104.30.128/27\",\r\n \"51.105.69.0/27\",\r\n \ + \ \"51.105.75.192/27\",\r\n \"51.140.84.251/32\",\r\n \"\ + 51.140.126.10/32\",\r\n \"51.140.149.32/27\",\r\n \"52.151.78.51/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKSouth2\"\ + ,\r\n \"id\": \"AzureIoTHub.UKSouth2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.58.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.UKWest\"\ + ,\r\n \"id\": \"AzureIoTHub.UKWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.137.164.160/27\",\r\n \ + \ \"51.137.165.0/25\",\r\n \"51.140.212.160/27\",\r\n \ + \ \"51.140.226.207/32\",\r\n \"51.140.240.234/32\",\r\n \ + \ \"51.141.49.253/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureIoTHub.WestCentralUS\",\r\n \"id\": \"AzureIoTHub.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureIoTHub\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.196.224/27\",\r\n \"13.78.129.154/32\",\r\n \ + \ \"13.78.130.69/32\",\r\n \"52.150.152.96/27\",\r\n \ + \ \"52.150.153.128/25\",\r\n \"52.161.15.247/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestEurope\"\ + ,\r\n \"id\": \"AzureIoTHub.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"13.69.71.0/25\",\r\n \ + \ \"13.69.109.0/25\",\r\n \"13.95.15.251/32\",\r\n \"\ + 23.100.4.253/32\",\r\n \"23.100.8.130/32\",\r\n \"40.113.153.50/32\"\ + ,\r\n \"40.113.176.160/27\",\r\n \"40.113.176.192/27\",\r\ + \n \"40.113.177.0/24\",\r\n \"40.118.27.192/32\",\r\n \ + \ \"51.144.118.31/32\",\r\n \"52.236.189.128/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestIndia\"\ + ,\r\n \"id\": \"AzureIoTHub.WestIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\ + \n \"addressPrefixes\": [\r\n \"20.38.128.128/27\",\r\n \ + \ \"52.136.51.128/25\",\r\n \"52.136.52.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestUS\"\ + ,\r\n \"id\": \"AzureIoTHub.WestUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.86.221.0/25\",\r\n \ + \ \"20.49.120.96/27\",\r\n \"20.49.120.128/25\",\r\n \ + \ \"20.49.121.0/25\",\r\n \"40.78.22.17/32\",\r\n \"40.83.177.42/32\"\ + ,\r\n \"40.112.221.188/32\",\r\n \"40.112.223.235/32\",\r\ + \n \"52.250.225.32/27\",\r\n \"104.40.49.44/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureIoTHub.WestUS2\"\ + ,\r\n \"id\": \"AzureIoTHub.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureIoTHub\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.66.142.96/27\",\r\n \ + \ \"40.64.132.160/27\",\r\n \"40.64.134.0/25\",\r\n \ + \ \"40.78.245.32/27\",\r\n \"40.78.251.160/27\",\r\n \"\ + 52.151.6.77/32\",\r\n \"52.158.236.252/32\",\r\n \"52.175.221.106/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault\"\ + ,\r\n \"id\": \"AzureKeyVault\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"VSE\",\r\n \"FW\"\r\n ],\r\n\ + \ \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.138.88/30\",\r\n \"13.66.226.249/32\",\r\ + \n \"13.66.230.241/32\",\r\n \"13.67.8.104/30\",\r\n \ + \ \"13.68.24.216/32\",\r\n \"13.68.29.203/32\",\r\n \ + \ \"13.68.104.240/32\",\r\n \"13.69.64.72/30\",\r\n \"\ + 13.69.227.72/30\",\r\n \"13.70.72.24/30\",\r\n \"13.70.138.129/32\"\ + ,\r\n \"13.71.170.40/30\",\r\n \"13.71.194.112/30\",\r\n\ + \ \"13.72.250.239/32\",\r\n \"13.74.10.39/32\",\r\n \ + \ \"13.74.10.113/32\",\r\n \"13.75.34.144/30\",\r\n \ + \ \"13.77.50.64/30\",\r\n \"13.78.106.88/30\",\r\n \"13.80.247.19/32\"\ + ,\r\n \"13.80.247.42/32\",\r\n \"13.84.174.143/32\",\r\n\ + \ \"13.87.34.51/32\",\r\n \"13.87.39.0/32\",\r\n \ + \ \"13.87.56.80/30\",\r\n \"13.87.101.60/32\",\r\n \"\ + 13.87.101.111/32\",\r\n \"13.87.122.80/30\",\r\n \"13.89.61.248/32\"\ + ,\r\n \"13.89.170.200/30\",\r\n \"20.36.40.39/32\",\r\n\ + \ \"20.36.40.42/32\",\r\n \"20.36.72.34/32\",\r\n \ + \ \"20.36.72.38/32\",\r\n \"20.36.106.64/30\",\r\n \"\ + 20.36.114.16/30\",\r\n \"20.37.74.228/30\",\r\n \"20.43.56.38/32\"\ + ,\r\n \"20.43.56.66/32\",\r\n \"20.44.2.0/30\",\r\n \ + \ \"20.45.123.240/30\",\r\n \"20.49.82.0/30\",\r\n \ + \ \"20.49.90.0/30\",\r\n \"20.150.170.0/30\",\r\n \"20.150.181.28/30\"\ + ,\r\n \"20.185.217.251/32\",\r\n \"20.185.218.1/32\",\r\n\ + \ \"20.186.41.83/32\",\r\n \"20.186.47.182/32\",\r\n \ + \ \"20.188.2.148/32\",\r\n \"20.188.2.156/32\",\r\n \ + \ \"20.188.40.44/32\",\r\n \"20.188.40.46/32\",\r\n \"\ + 20.192.234.0/30\",\r\n \"20.193.202.0/30\",\r\n \"20.194.66.0/30\"\ + ,\r\n \"23.96.210.207/32\",\r\n \"23.96.250.48/32\",\r\n\ + \ \"23.97.50.43/32\",\r\n \"23.97.178.0/32\",\r\n \ + \ \"23.99.132.207/32\",\r\n \"23.100.57.24/32\",\r\n \ + \ \"23.100.58.149/32\",\r\n \"23.101.21.103/32\",\r\n \"\ + 23.101.21.193/32\",\r\n \"23.101.23.190/32\",\r\n \"23.101.23.192/32\"\ + ,\r\n \"23.102.72.114/32\",\r\n \"23.102.75.18/32\",\r\n\ + \ \"40.65.188.244/32\",\r\n \"40.65.189.219/32\",\r\n \ + \ \"40.67.58.0/30\",\r\n \"40.69.106.64/30\",\r\n \ + \ \"40.70.146.72/30\",\r\n \"40.70.204.6/32\",\r\n \"40.70.204.32/32\"\ + ,\r\n \"40.71.10.200/30\",\r\n \"40.74.100.48/30\",\r\n\ + \ \"40.76.196.75/32\",\r\n \"40.76.212.37/32\",\r\n \ + \ \"40.78.194.64/30\",\r\n \"40.79.118.1/32\",\r\n \ + \ \"40.79.118.5/32\",\r\n \"40.79.130.40/30\",\r\n \"40.79.163.156/30\"\ + ,\r\n \"40.79.178.64/30\",\r\n \"40.85.185.208/32\",\r\n\ + \ \"40.85.229.9/32\",\r\n \"40.85.231.231/32\",\r\n \ + \ \"40.86.224.94/32\",\r\n \"40.86.231.180/32\",\r\n \ + \ \"40.87.69.184/32\",\r\n \"40.89.145.89/32\",\r\n \"\ + 40.89.145.93/32\",\r\n \"40.89.180.10/32\",\r\n \"40.89.180.25/32\"\ + ,\r\n \"40.91.193.78/32\",\r\n \"40.91.199.213/32\",\r\n\ + \ \"40.112.242.144/30\",\r\n \"40.117.157.122/32\",\r\n\ + \ \"40.120.74.0/30\",\r\n \"51.12.98.0/30\",\r\n \ + \ \"51.12.202.0/30\",\r\n \"51.104.192.129/32\",\r\n \"\ + 51.104.192.138/32\",\r\n \"51.105.4.67/32\",\r\n \"51.105.4.75/32\"\ + ,\r\n \"51.107.58.0/30\",\r\n \"51.107.154.0/30\",\r\n \ + \ \"51.116.58.0/30\",\r\n \"51.116.154.64/30\",\r\n \ + \ \"51.116.243.220/30\",\r\n \"51.116.251.188/30\",\r\n \ + \ \"51.120.98.8/30\",\r\n \"51.120.218.0/30\",\r\n \"\ + 51.140.146.56/30\",\r\n \"51.140.157.60/32\",\r\n \"51.140.184.38/31\"\ + ,\r\n \"51.140.210.80/30\",\r\n \"51.141.8.42/31\",\r\n\ + \ \"51.143.6.21/32\",\r\n \"52.136.136.15/32\",\r\n \ + \ \"52.136.136.16/32\",\r\n \"52.138.73.5/32\",\r\n \ + \ \"52.138.73.51/32\",\r\n \"52.138.160.103/32\",\r\n \"\ + 52.138.160.105/32\",\r\n \"52.148.84.142/32\",\r\n \"52.148.84.145/32\"\ + ,\r\n \"52.151.41.92/32\",\r\n \"52.151.47.4/32\",\r\n \ + \ \"52.151.75.86/32\",\r\n \"52.154.176.47/32\",\r\n \ + \ \"52.154.177.179/32\",\r\n \"52.157.162.137/32\",\r\n \ + \ \"52.157.162.147/32\",\r\n \"52.158.236.253/32\",\r\n \ + \ \"52.158.239.35/32\",\r\n \"52.161.25.42/32\",\r\n \ + \ \"52.161.31.136/32\",\r\n \"52.161.31.139/32\",\r\n \ + \ \"52.162.106.144/30\",\r\n \"52.162.255.194/32\",\r\n \ + \ \"52.165.21.159/32\",\r\n \"52.165.208.47/32\",\r\n \"\ + 52.167.143.179/32\",\r\n \"52.167.228.54/32\",\r\n \"52.168.109.101/32\"\ + ,\r\n \"52.169.232.147/32\",\r\n \"52.173.90.250/32\",\r\ + \n \"52.173.199.154/32\",\r\n \"52.173.216.55/32\",\r\n\ + \ \"52.175.236.86/32\",\r\n \"52.176.48.58/32\",\r\n \ + \ \"52.176.254.165/32\",\r\n \"52.180.176.121/32\",\r\n \ + \ \"52.180.176.122/32\",\r\n \"52.183.24.22/32\",\r\n \ + \ \"52.183.80.133/32\",\r\n \"52.183.93.92/32\",\r\n \ + \ \"52.183.94.166/32\",\r\n \"52.184.155.181/32\",\r\n \ + \ \"52.187.161.13/32\",\r\n \"52.187.163.139/32\",\r\n \"\ + 52.225.179.130/32\",\r\n \"52.225.182.225/32\",\r\n \"52.225.188.225/32\"\ + ,\r\n \"52.225.191.36/32\",\r\n \"52.225.218.218/32\",\r\ + \n \"52.231.18.40/30\",\r\n \"52.231.32.65/32\",\r\n \ + \ \"52.231.32.66/32\",\r\n \"52.231.146.80/30\",\r\n \ + \ \"52.231.200.107/32\",\r\n \"52.231.200.108/32\",\r\n \ + \ \"52.237.253.194/32\",\r\n \"52.246.157.4/30\",\r\n \ + \ \"52.247.193.69/32\",\r\n \"52.255.63.107/32\",\r\n \"\ + 52.255.152.252/32\",\r\n \"52.255.152.255/32\",\r\n \"65.52.250.0/30\"\ + ,\r\n \"102.133.26.0/30\",\r\n \"102.133.154.0/30\",\r\n\ + \ \"104.41.0.141/32\",\r\n \"104.41.1.239/32\",\r\n \ + \ \"104.41.162.219/32\",\r\n \"104.41.162.228/32\",\r\n \ + \ \"104.42.6.91/32\",\r\n \"104.42.136.180/32\",\r\n \ + \ \"104.43.161.34/32\",\r\n \"104.43.192.26/32\",\r\n \ + \ \"104.44.136.42/32\",\r\n \"104.46.40.31/32\",\r\n \"\ + 104.46.219.151/32\",\r\n \"104.46.219.184/32\",\r\n \"104.208.26.47/32\"\ + ,\r\n \"104.210.195.61/32\",\r\n \"104.211.81.24/30\",\r\ + \n \"104.211.98.11/32\",\r\n \"104.211.99.174/32\",\r\n\ + \ \"104.211.146.64/30\",\r\n \"104.211.166.82/32\",\r\n\ + \ \"104.211.167.57/32\",\r\n \"104.211.224.186/32\",\r\n\ + \ \"104.211.225.134/32\",\r\n \"104.214.18.168/30\",\r\n\ + \ \"104.215.18.67/32\",\r\n \"104.215.31.67/32\",\r\n \ + \ \"104.215.94.76/32\",\r\n \"104.215.99.117/32\",\r\n \ + \ \"104.215.139.166/32\",\r\n \"104.215.140.132/32\",\r\n \ + \ \"137.116.44.148/32\",\r\n \"137.116.120.244/32\",\r\n\ + \ \"137.116.233.191/32\",\r\n \"168.62.108.27/32\",\r\n\ + \ \"168.62.237.29/32\",\r\n \"168.63.167.27/32\",\r\n \ + \ \"168.63.219.200/32\",\r\n \"168.63.219.205/32\",\r\n \ + \ \"191.233.50.0/30\",\r\n \"191.233.203.24/30\",\r\n \ + \ \"191.234.149.140/30\",\r\n \"191.234.157.44/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureKeyVault.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.36.40.39/32\"\ + ,\r\n \"20.36.40.42/32\",\r\n \"20.36.106.64/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.AustraliaCentral2\"\ + ,\r\n \"id\": \"AzureKeyVault.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.36.72.34/32\"\ + ,\r\n \"20.36.72.38/32\",\r\n \"20.36.114.16/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.AustraliaEast\"\ + ,\r\n \"id\": \"AzureKeyVault.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.24/30\"\ + ,\r\n \"13.72.250.239/32\",\r\n \"40.79.163.156/30\",\r\n\ + \ \"52.237.253.194/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureKeyVault.AustraliaSoutheast\",\r\n \"id\"\ + : \"AzureKeyVault.AustraliaSoutheast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.70.138.129/32\"\ + ,\r\n \"13.77.50.64/30\",\r\n \"52.255.63.107/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.BrazilSouth\"\ + ,\r\n \"id\": \"AzureKeyVault.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \ + \ \"addressPrefixes\": [\r\n \"104.41.0.141/32\",\r\n \ + \ \"104.41.1.239/32\",\r\n \"191.233.203.24/30\",\r\n \ + \ \"191.234.149.140/30\",\r\n \"191.234.157.44/30\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.CanadaCentral\"\ + ,\r\n \"id\": \"AzureKeyVault.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.71.170.40/30\",\r\n \ + \ \"40.85.229.9/32\",\r\n \"40.85.231.231/32\",\r\n \"\ + 52.246.157.4/30\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureKeyVault.CanadaEast\",\r\n \"id\": \"AzureKeyVault.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n \ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.64/30\"\ + ,\r\n \"40.86.224.94/32\",\r\n \"40.86.231.180/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.CentralIndia\"\ + ,\r\n \"id\": \"AzureKeyVault.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n \"\ + FW\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \ + \ \"addressPrefixes\": [\r\n \"104.211.81.24/30\",\r\n \ + \ \"104.211.98.11/32\",\r\n \"104.211.99.174/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.CentralUS\"\ + ,\r\n \"id\": \"AzureKeyVault.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.89.61.248/32\"\ + ,\r\n \"13.89.170.200/30\",\r\n \"23.99.132.207/32\",\r\n\ + \ \"52.154.176.47/32\",\r\n \"52.154.177.179/32\",\r\n \ + \ \"52.165.21.159/32\",\r\n \"52.165.208.47/32\",\r\n \ + \ \"52.173.90.250/32\",\r\n \"52.173.199.154/32\",\r\n \ + \ \"52.173.216.55/32\",\r\n \"52.176.48.58/32\",\r\n \ + \ \"104.43.161.34/32\",\r\n \"104.43.192.26/32\",\r\n \ + \ \"104.208.26.47/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureKeyVault.CentralUSEUAP\",\r\n \"id\": \"AzureKeyVault.CentralUSEUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"\ + addressPrefixes\": [\r\n \"52.176.254.165/32\",\r\n \"52.180.176.121/32\"\ + ,\r\n \"52.180.176.122/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureKeyVault.EastAsia\",\r\n \"id\": \"\ + AzureKeyVault.EastAsia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastasia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.75.34.144/30\",\r\n \ + \ \"168.63.219.200/32\",\r\n \"168.63.219.205/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.EastUS\"\ + ,\r\n \"id\": \"AzureKeyVault.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.185.217.251/32\"\ + ,\r\n \"20.185.218.1/32\",\r\n \"40.71.10.200/30\",\r\n\ + \ \"40.76.196.75/32\",\r\n \"40.76.212.37/32\",\r\n \ + \ \"40.85.185.208/32\",\r\n \"40.87.69.184/32\",\r\n \ + \ \"40.117.157.122/32\",\r\n \"52.168.109.101/32\",\r\n \ + \ \"52.255.152.252/32\",\r\n \"52.255.152.255/32\",\r\n \ + \ \"137.116.120.244/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureKeyVault.EastUS2\",\r\n \"id\": \"AzureKeyVault.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.68.24.216/32\",\r\n \"13.68.29.203/32\",\r\n \ + \ \"13.68.104.240/32\",\r\n \"20.186.41.83/32\",\r\n \ + \ \"20.186.47.182/32\",\r\n \"40.70.146.72/30\",\r\n \"\ + 40.70.204.6/32\",\r\n \"40.70.204.32/32\",\r\n \"52.167.143.179/32\"\ + ,\r\n \"52.167.228.54/32\",\r\n \"52.184.155.181/32\",\r\ + \n \"52.225.218.218/32\",\r\n \"137.116.44.148/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureKeyVault.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"40.79.118.1/32\"\ + ,\r\n \"40.79.118.5/32\",\r\n \"52.138.73.5/32\",\r\n \ + \ \"52.138.73.51/32\",\r\n \"52.225.179.130/32\",\r\n \ + \ \"52.225.182.225/32\",\r\n \"52.225.188.225/32\",\r\n \ + \ \"52.225.191.36/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureKeyVault.FranceCentral\",\r\n \"id\": \"AzureKeyVault.FranceCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"\ + addressPrefixes\": [\r\n \"20.43.56.38/32\",\r\n \"20.43.56.66/32\"\ + ,\r\n \"20.188.40.44/32\",\r\n \"20.188.40.46/32\",\r\n\ + \ \"40.79.130.40/30\",\r\n \"40.89.145.89/32\",\r\n \ + \ \"40.89.145.93/32\",\r\n \"40.89.180.10/32\",\r\n \ + \ \"40.89.180.25/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureKeyVault.FranceSouth\",\r\n \"id\": \"AzureKeyVault.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.79.178.64/30\",\r\n \"52.136.136.15/32\",\r\ + \n \"52.136.136.16/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureKeyVault.GermanyNorth\",\r\n \"id\": \"\ + AzureKeyVault.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.116.58.0/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.GermanyWestCentral\"\ + ,\r\n \"id\": \"AzureKeyVault.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.116.154.64/30\"\ + ,\r\n \"51.116.243.220/30\",\r\n \"51.116.251.188/30\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.JapanEast\"\ + ,\r\n \"id\": \"AzureKeyVault.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.78.106.88/30\"\ + ,\r\n \"20.188.2.148/32\",\r\n \"20.188.2.156/32\",\r\n\ + \ \"23.102.72.114/32\",\r\n \"23.102.75.18/32\",\r\n \ + \ \"104.41.162.219/32\",\r\n \"104.41.162.228/32\",\r\n \ + \ \"104.46.219.151/32\",\r\n \"104.46.219.184/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.JapanWest\"\ + ,\r\n \"id\": \"AzureKeyVault.JapanWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"40.74.100.48/30\"\ + ,\r\n \"104.215.18.67/32\",\r\n \"104.215.31.67/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.KoreaCentral\"\ + ,\r\n \"id\": \"AzureKeyVault.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.194.66.0/30\"\ + ,\r\n \"52.231.18.40/30\",\r\n \"52.231.32.65/32\",\r\n\ + \ \"52.231.32.66/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.KoreaSouth\",\r\n \"id\": \"AzureKeyVault.KoreaSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.231.146.80/30\",\r\n \"52.231.200.107/32\"\ + ,\r\n \"52.231.200.108/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureKeyVault.NorthCentralUS\",\r\n \"id\"\ + : \"AzureKeyVault.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"23.96.210.207/32\"\ + ,\r\n \"23.96.250.48/32\",\r\n \"52.162.106.144/30\",\r\n\ + \ \"52.162.255.194/32\",\r\n \"168.62.108.27/32\",\r\n \ + \ \"168.62.237.29/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.NorthEurope\",\r\n \"id\": \"AzureKeyVault.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.227.72/30\",\r\n \"13.74.10.39/32\",\r\n\ + \ \"13.74.10.113/32\",\r\n \"23.100.57.24/32\",\r\n \ + \ \"23.100.58.149/32\",\r\n \"52.138.160.103/32\",\r\n \ + \ \"52.138.160.105/32\",\r\n \"52.169.232.147/32\",\r\n \ + \ \"137.116.233.191/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureKeyVault.NorwayEast\",\r\n \"id\": \"AzureKeyVault.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.98.8/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.NorwayWest\",\r\n \"id\": \"AzureKeyVault.NorwayWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.218.0/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.SouthAfricaNorth\",\r\n \"id\": \"\ + AzureKeyVault.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"102.133.154.0/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SouthAfricaWest\"\ + ,\r\n \"id\": \"AzureKeyVault.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.0/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureKeyVault.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.84.174.143/32\"\ + ,\r\n \"20.45.123.240/30\",\r\n \"20.49.90.0/30\",\r\n \ + \ \"104.44.136.42/32\",\r\n \"104.210.195.61/32\",\r\n \ + \ \"104.214.18.168/30\",\r\n \"104.215.94.76/32\",\r\n \ + \ \"104.215.99.117/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.SoutheastAsia\",\r\n \"id\": \"AzureKeyVault.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"\ + addressPrefixes\": [\r\n \"13.67.8.104/30\",\r\n \"23.97.50.43/32\"\ + ,\r\n \"23.101.21.103/32\",\r\n \"23.101.21.193/32\",\r\n\ + \ \"23.101.23.190/32\",\r\n \"23.101.23.192/32\",\r\n \ + \ \"40.65.188.244/32\",\r\n \"40.65.189.219/32\",\r\n \ + \ \"52.148.84.142/32\",\r\n \"52.148.84.145/32\",\r\n \ + \ \"52.187.161.13/32\",\r\n \"52.187.163.139/32\",\r\n \ + \ \"104.215.139.166/32\",\r\n \"104.215.140.132/32\",\r\n \ + \ \"168.63.167.27/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureKeyVault.SouthIndia\",\r\n \"id\": \"AzureKeyVault.SouthIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.78.194.64/30\",\r\n \"104.211.224.186/32\"\ + ,\r\n \"104.211.225.134/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureKeyVault.SwitzerlandNorth\",\r\n \"\ + id\": \"AzureKeyVault.SwitzerlandNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.107.58.0/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureKeyVault.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.107.154.0/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UAECentral\"\ + ,\r\n \"id\": \"AzureKeyVault.UAECentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.228/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UAENorth\"\ + ,\r\n \"id\": \"AzureKeyVault.UAENorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.0/30\"\ + ,\r\n \"65.52.250.0/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureKeyVault.UKNorth\",\r\n \"id\": \"AzureKeyVault.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.101.60/32\",\r\n\ + \ \"13.87.101.111/32\",\r\n \"13.87.122.80/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKSouth\"\ + ,\r\n \"id\": \"AzureKeyVault.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.104.192.129/32\"\ + ,\r\n \"51.104.192.138/32\",\r\n \"51.105.4.67/32\",\r\n\ + \ \"51.105.4.75/32\",\r\n \"51.140.146.56/30\",\r\n \ + \ \"51.140.157.60/32\",\r\n \"51.140.184.38/31\",\r\n \ + \ \"52.151.75.86/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureKeyVault.UKSouth2\",\r\n \"id\": \"AzureKeyVault.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"13.87.34.51/32\"\ + ,\r\n \"13.87.39.0/32\",\r\n \"13.87.56.80/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureKeyVault.UKWest\"\ + ,\r\n \"id\": \"AzureKeyVault.UKWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n \"51.140.210.80/30\"\ + ,\r\n \"51.141.8.42/31\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureKeyVault.WestCentralUS\",\r\n \"id\":\ + \ \"AzureKeyVault.WestCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureKeyVault\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.194.112/30\",\r\n\ + \ \"52.161.25.42/32\",\r\n \"52.161.31.136/32\",\r\n \ + \ \"52.161.31.139/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureKeyVault.WestEurope\",\r\n \"id\": \"AzureKeyVault.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.64.72/30\",\r\n \"13.80.247.19/32\",\r\n\ + \ \"13.80.247.42/32\",\r\n \"23.97.178.0/32\",\r\n \ + \ \"40.91.193.78/32\",\r\n \"40.91.199.213/32\",\r\n \ + \ \"52.157.162.137/32\",\r\n \"52.157.162.147/32\",\r\n \ + \ \"104.46.40.31/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureKeyVault.WestIndia\",\r\n \"id\": \"AzureKeyVault.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\"\ + : [\r\n \"104.211.146.64/30\",\r\n \"104.211.166.82/32\"\ + ,\r\n \"104.211.167.57/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureKeyVault.WestUS\",\r\n \"id\": \"AzureKeyVault.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.112.242.144/30\",\r\n \"104.42.6.91/32\",\r\n \ + \ \"104.42.136.180/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureKeyVault.WestUS2\",\r\n \"id\": \"AzureKeyVault.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureKeyVault\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.66.138.88/30\",\r\n \"13.66.226.249/32\",\r\n \ + \ \"13.66.230.241/32\",\r\n \"51.143.6.21/32\",\r\n \ + \ \"52.151.41.92/32\",\r\n \"52.151.47.4/32\",\r\n \"\ + 52.158.236.253/32\",\r\n \"52.158.239.35/32\",\r\n \"52.175.236.86/32\"\ + ,\r\n \"52.183.24.22/32\",\r\n \"52.183.80.133/32\",\r\n\ + \ \"52.183.93.92/32\",\r\n \"52.183.94.166/32\",\r\n \ + \ \"52.247.193.69/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureMachineLearning\",\r\n \"id\": \"AzureMachineLearning\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.66.87.135/32\",\r\n \ + \ \"13.66.140.80/28\",\r\n \"13.67.8.224/28\",\r\n \"13.69.64.192/28\"\ + ,\r\n \"13.69.106.192/28\",\r\n \"13.69.227.192/28\",\r\n\ + \ \"13.70.72.144/28\",\r\n \"13.71.170.192/28\",\r\n \ + \ \"13.71.173.80/28\",\r\n \"13.71.194.240/28\",\r\n \ + \ \"13.73.240.16/28\",\r\n \"13.73.240.112/28\",\r\n \ + \ \"13.73.240.240/28\",\r\n \"13.73.248.96/28\",\r\n \"\ + 13.74.107.160/28\",\r\n \"13.75.36.16/28\",\r\n \"13.77.50.224/28\"\ + ,\r\n \"13.78.106.208/28\",\r\n \"13.86.195.35/32\",\r\n\ + \ \"13.87.56.112/28\",\r\n \"13.87.122.112/28\",\r\n \ + \ \"13.87.160.129/32\",\r\n \"13.89.171.64/28\",\r\n \ + \ \"20.36.106.80/28\",\r\n \"20.36.114.160/28\",\r\n \ + \ \"20.37.67.80/28\",\r\n \"20.37.74.208/28\",\r\n \"20.37.152.240/28\"\ + ,\r\n \"20.37.192.96/28\",\r\n \"20.38.80.96/28\",\r\n \ + \ \"20.38.128.48/28\",\r\n \"20.38.147.128/28\",\r\n \ + \ \"20.39.1.205/32\",\r\n \"20.39.11.80/28\",\r\n \"\ + 20.40.141.171/32\",\r\n \"20.41.0.240/28\",\r\n \"20.41.64.80/28\"\ + ,\r\n \"20.41.197.0/28\",\r\n \"20.42.0.240/28\",\r\n \ + \ \"20.42.129.16/28\",\r\n \"20.42.227.48/28\",\r\n \ + \ \"20.43.40.96/28\",\r\n \"20.43.64.96/28\",\r\n \"\ + 20.43.120.112/28\",\r\n \"20.43.128.112/28\",\r\n \"20.44.3.32/28\"\ + ,\r\n \"20.44.26.224/28\",\r\n \"20.44.132.166/32\",\r\n\ + \ \"20.150.161.128/28\",\r\n \"20.150.171.80/28\",\r\n \ + \ \"20.150.179.64/28\",\r\n \"20.150.187.64/28\",\r\n \ + \ \"20.188.219.157/32\",\r\n \"20.188.221.15/32\",\r\n \ + \ \"20.189.106.80/28\",\r\n \"20.192.99.64/28\",\r\n \ + \ \"20.192.160.48/28\",\r\n \"20.192.225.144/28\",\r\n \ + \ \"20.192.235.16/28\",\r\n \"23.98.82.192/28\",\r\n \"\ + 23.100.232.216/32\",\r\n \"40.66.61.146/32\",\r\n \"40.67.59.80/28\"\ + ,\r\n \"40.69.106.224/28\",\r\n \"40.70.146.192/28\",\r\n\ + \ \"40.70.154.161/32\",\r\n \"40.71.11.64/28\",\r\n \ + \ \"40.74.24.96/28\",\r\n \"40.74.100.176/28\",\r\n \ + \ \"40.74.147.48/28\",\r\n \"40.75.35.48/28\",\r\n \"40.78.194.224/28\"\ + ,\r\n \"40.78.202.80/28\",\r\n \"40.78.227.32/28\",\r\n\ + \ \"40.78.234.128/28\",\r\n \"40.78.242.176/28\",\r\n \ + \ \"40.78.250.112/28\",\r\n \"40.79.130.192/28\",\r\n \ + \ \"40.79.138.128/28\",\r\n \"40.79.146.128/28\",\r\n \ + \ \"40.79.154.64/28\",\r\n \"40.79.162.48/28\",\r\n \"\ + 40.79.170.224/28\",\r\n \"40.79.178.224/28\",\r\n \"40.79.186.160/28\"\ + ,\r\n \"40.79.194.64/28\",\r\n \"40.80.51.64/28\",\r\n \ + \ \"40.80.57.176/28\",\r\n \"40.80.169.160/28\",\r\n \ + \ \"40.80.184.80/28\",\r\n \"40.80.188.96/28\",\r\n \ + \ \"40.81.27.228/32\",\r\n \"40.82.187.230/32\",\r\n \"\ + 40.82.248.80/28\",\r\n \"40.89.17.208/28\",\r\n \"40.90.184.249/32\"\ + ,\r\n \"40.91.77.76/32\",\r\n \"40.112.242.176/28\",\r\n\ + \ \"40.119.8.80/28\",\r\n \"51.11.24.49/32\",\r\n \ + \ \"51.12.99.80/28\",\r\n \"51.12.203.80/28\",\r\n \"\ + 51.12.227.64/28\",\r\n \"51.12.235.64/28\",\r\n \"51.104.8.64/27\"\ + ,\r\n \"51.104.24.96/28\",\r\n \"51.105.67.16/28\",\r\n\ + \ \"51.105.75.128/28\",\r\n \"51.105.88.224/28\",\r\n \ + \ \"51.105.129.135/32\",\r\n \"51.107.59.48/28\",\r\n \ + \ \"51.107.147.32/28\",\r\n \"51.107.155.48/28\",\r\n \ + \ \"51.116.49.176/28\",\r\n \"51.116.59.48/28\",\r\n \ + \ \"51.116.155.112/28\",\r\n \"51.116.156.128/28\",\r\n \ + \ \"51.116.250.224/28\",\r\n \"51.120.99.64/28\",\r\n \"\ + 51.120.107.64/28\",\r\n \"51.120.211.64/28\",\r\n \"51.120.219.80/28\"\ + ,\r\n \"51.120.227.80/28\",\r\n \"51.137.161.224/28\",\r\ + \n \"51.140.146.208/28\",\r\n \"51.140.210.208/28\",\r\n\ + \ \"51.144.184.47/32\",\r\n \"52.138.90.144/28\",\r\n \ + \ \"52.138.226.160/28\",\r\n \"52.139.3.33/32\",\r\n \ + \ \"52.140.107.96/28\",\r\n \"52.141.25.58/32\",\r\n \ + \ \"52.141.26.97/32\",\r\n \"52.148.163.43/32\",\r\n \"\ + 52.150.136.80/28\",\r\n \"52.151.111.249/32\",\r\n \"52.155.90.254/32\"\ + ,\r\n \"52.155.115.7/32\",\r\n \"52.156.193.50/32\",\r\n\ + \ \"52.162.106.176/28\",\r\n \"52.167.106.160/28\",\r\n\ + \ \"52.177.164.219/32\",\r\n \"52.182.139.32/28\",\r\n \ + \ \"52.184.87.76/32\",\r\n \"52.185.70.56/32\",\r\n \ + \ \"52.228.80.80/28\",\r\n \"52.230.56.136/32\",\r\n \ + \ \"52.231.18.192/28\",\r\n \"52.231.146.208/28\",\r\n \ + \ \"52.236.186.192/28\",\r\n \"52.242.224.215/32\",\r\n \ + \ \"52.246.155.128/28\",\r\n \"52.249.59.91/32\",\r\n \"\ + 52.252.160.26/32\",\r\n \"52.253.131.79/32\",\r\n \"52.253.131.198/32\"\ + ,\r\n \"52.253.227.208/32\",\r\n \"52.255.214.109/32\",\r\ + \n \"52.255.217.127/32\",\r\n \"65.52.250.192/28\",\r\n\ + \ \"102.133.27.32/28\",\r\n \"102.133.58.224/28\",\r\n \ + \ \"102.133.122.224/27\",\r\n \"102.133.155.32/28\",\r\n\ + \ \"102.133.251.64/28\",\r\n \"104.208.16.160/28\",\r\n\ + \ \"104.208.144.160/28\",\r\n \"104.211.81.144/28\",\r\n\ + \ \"104.214.19.32/28\",\r\n \"191.233.8.48/28\",\r\n \ + \ \"191.233.203.144/28\",\r\n \"191.233.240.165/32\",\r\n \ + \ \"191.233.242.167/32\",\r\n \"191.234.147.64/28\",\r\n\ + \ \"191.234.155.64/28\",\r\n \"191.235.224.96/28\",\r\n\ + \ \"2603:1000:104:1::2c0/122\",\r\n \"2603:1010:6:1::2c0/122\"\ + ,\r\n \"2603:1020:5:1::2c0/122\",\r\n \"2603:1020:206:1::2c0/122\"\ + ,\r\n \"2603:1020:705:1::2c0/122\",\r\n \"2603:1020:805:1::2c0/122\"\ + ,\r\n \"2603:1020:a04:1::2c0/122\",\r\n \"2603:1020:c04:1::2c0/122\"\ + ,\r\n \"2603:1020:e04:1::2c0/122\",\r\n \"2603:1020:1004::2c0/122\"\ + ,\r\n \"2603:1030:10:1::2c0/122\",\r\n \"2603:1030:104:1::2c0/122\"\ + ,\r\n \"2603:1030:210:1::2c0/122\",\r\n \"2603:1030:40b:1::2c0/122\"\ + ,\r\n \"2603:1030:40c:1::2c0/122\",\r\n \"2603:1030:504:1::2c0/122\"\ + ,\r\n \"2603:1030:807:1::2c0/122\",\r\n \"2603:1030:c06:1::2c0/122\"\ + ,\r\n \"2603:1030:f05:1::2c0/122\",\r\n \"2603:1040:5:1::2c0/122\"\ + ,\r\n \"2603:1040:407:1::2c0/122\",\r\n \"2603:1040:904:1::2c0/122\"\ + ,\r\n \"2603:1040:a06:1::2c0/122\",\r\n \"2603:1040:d04::2c0/122\"\ + ,\r\n \"2603:1040:f05:1::2c0/122\",\r\n \"2603:1050:6:1::2c0/122\"\ + ,\r\n \"2603:1050:403::2c0/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureMachineLearning.AustraliaCentral\",\r\n\ + \ \"id\": \"AzureMachineLearning.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.106.80/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.AustraliaCentral2\"\ + ,\r\n \"id\": \"AzureMachineLearning.AustraliaCentral2\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.114.160/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.AustraliaEast\"\ + ,\r\n \"id\": \"AzureMachineLearning.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.72.144/28\",\r\n\ + \ \"20.37.192.96/28\",\r\n \"20.188.219.157/32\",\r\n \ + \ \"20.188.221.15/32\",\r\n \"40.79.162.48/28\",\r\n \ + \ \"40.79.170.224/28\",\r\n \"2603:1010:6:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureMachineLearning.AustraliaSoutheast\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.50.224/28\",\r\n\ + \ \"20.42.227.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.BrazilSouth\",\r\n \"id\": \"\ + AzureMachineLearning.BrazilSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"191.233.203.144/28\",\r\ + \n \"191.233.240.165/32\",\r\n \"191.233.242.167/32\",\r\ + \n \"191.234.147.64/28\",\r\n \"191.234.155.64/28\",\r\n\ + \ \"191.235.224.96/28\",\r\n \"2603:1050:6:1::2c0/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CanadaCentral\"\ + ,\r\n \"id\": \"AzureMachineLearning.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.170.192/28\",\r\n\ + \ \"13.71.173.80/28\",\r\n \"20.38.147.128/28\",\r\n \ + \ \"40.82.187.230/32\",\r\n \"52.139.3.33/32\",\r\n \ + \ \"52.228.80.80/28\",\r\n \"52.246.155.128/28\",\r\n \ + \ \"2603:1030:f05:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.CanadaEast\",\r\n \"id\": \"\ + AzureMachineLearning.CanadaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.69.106.224/28\",\r\n \ + \ \"40.89.17.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureMachineLearning.CentralIndia\",\r\n \"id\": \"\ + AzureMachineLearning.CentralIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.120.112/28\",\r\n\ + \ \"20.192.99.64/28\",\r\n \"40.80.51.64/28\",\r\n \ + \ \"52.140.107.96/28\",\r\n \"104.211.81.144/28\",\r\n \ + \ \"2603:1040:a06:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMachineLearning.CentralUS\",\r\n \"id\"\ + : \"AzureMachineLearning.CentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.89.171.64/28\",\r\n\ + \ \"20.37.152.240/28\",\r\n \"52.182.139.32/28\",\r\n \ + \ \"52.185.70.56/32\",\r\n \"52.242.224.215/32\",\r\n \ + \ \"104.208.16.160/28\",\r\n \"2603:1030:10:1::2c0/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureMachineLearning.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.202.80/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.EastAsia\"\ + ,\r\n \"id\": \"AzureMachineLearning.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.75.36.16/28\",\r\n \ + \ \"20.189.106.80/28\",\r\n \"40.81.27.228/32\",\r\n \ + \ \"52.184.87.76/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureMachineLearning.EastUS\",\r\n \"id\": \"AzureMachineLearning.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.0.240/28\",\r\n \ + \ \"40.71.11.64/28\",\r\n \"40.78.227.32/28\",\r\n \ + \ \"40.79.154.64/28\",\r\n \"52.255.214.109/32\",\r\n \ + \ \"52.255.217.127/32\",\r\n \"2603:1030:210:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.EastUS2\"\ + ,\r\n \"id\": \"AzureMachineLearning.EastUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.0.240/28\",\r\n \ + \ \"40.70.146.192/28\",\r\n \"40.70.154.161/32\",\r\n \ + \ \"52.167.106.160/28\",\r\n \"52.177.164.219/32\",\r\n \ + \ \"104.208.144.160/28\",\r\n \"2603:1030:40c:1::2c0/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.EastUS2EUAP\"\ + ,\r\n \"id\": \"AzureMachineLearning.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.39.1.205/32\",\r\n \ + \ \"20.39.11.80/28\",\r\n \"40.74.147.48/28\",\r\n \ + \ \"40.75.35.48/28\",\r\n \"52.138.90.144/28\",\r\n \"\ + 52.253.227.208/32\",\r\n \"2603:1030:40b:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.FranceCentral\"\ + ,\r\n \"id\": \"AzureMachineLearning.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.40.141.171/32\",\r\n\ + \ \"20.43.40.96/28\",\r\n \"40.66.61.146/32\",\r\n \ + \ \"40.79.130.192/28\",\r\n \"40.79.138.128/28\",\r\n \ + \ \"40.79.146.128/28\",\r\n \"2603:1020:805:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.FranceSouth\"\ + ,\r\n \"id\": \"AzureMachineLearning.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.178.224/28\",\r\n\ + \ \"51.105.88.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.GermanyNorth\",\r\n \"id\":\ + \ \"AzureMachineLearning.GermanyNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.49.176/28\",\r\n\ + \ \"51.116.59.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.GermanyWestCentral\",\r\n \"\ + id\": \"AzureMachineLearning.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.155.112/28\",\r\n\ + \ \"51.116.156.128/28\",\r\n \"51.116.250.224/28\",\r\n\ + \ \"2603:1020:c04:1::2c0/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureMachineLearning.JapanEast\",\r\n \"\ + id\": \"AzureMachineLearning.JapanEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.78.106.208/28\",\r\n\ + \ \"20.43.64.96/28\",\r\n \"20.44.132.166/32\",\r\n \ + \ \"40.79.186.160/28\",\r\n \"40.79.194.64/28\",\r\n \ + \ \"52.155.115.7/32\",\r\n \"2603:1040:407:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.JapanWest\"\ + ,\r\n \"id\": \"AzureMachineLearning.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.74.100.176/28\",\r\n\ + \ \"40.80.57.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.KoreaCentral\",\r\n \"id\":\ + \ \"AzureMachineLearning.KoreaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.64.80/28\",\r\n \ + \ \"20.44.26.224/28\",\r\n \"52.141.25.58/32\",\r\n \ + \ \"52.141.26.97/32\",\r\n \"52.231.18.192/28\",\r\n \ + \ \"2603:1040:f05:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.KoreaSouth\",\r\n \"id\": \"\ + AzureMachineLearning.KoreaSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.80.169.160/28\",\r\n \ + \ \"52.231.146.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureMachineLearning.NorthCentralUS\",\r\n \"id\"\ + : \"AzureMachineLearning.NorthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"23.100.232.216/32\",\r\n\ + \ \"40.80.184.80/28\",\r\n \"40.80.188.96/28\",\r\n \ + \ \"52.162.106.176/28\",\r\n \"52.252.160.26/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorthEurope\"\ + ,\r\n \"id\": \"AzureMachineLearning.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.227.192/28\",\r\n\ + \ \"13.74.107.160/28\",\r\n \"20.38.80.96/28\",\r\n \ + \ \"52.138.226.160/28\",\r\n \"52.155.90.254/32\",\r\n \ + \ \"52.156.193.50/32\",\r\n \"2603:1020:5:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.NorwayEast\"\ + ,\r\n \"id\": \"AzureMachineLearning.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.99.64/28\",\r\n\ + \ \"51.120.107.64/28\",\r\n \"51.120.211.64/28\",\r\n \ + \ \"2603:1020:e04:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMachineLearning.NorwayWest\",\r\n \"\ + id\": \"AzureMachineLearning.NorwayWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.219.80/28\",\r\n\ + \ \"51.120.227.80/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.SouthAfricaNorth\",\r\n \"id\"\ + : \"AzureMachineLearning.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.122.224/27\",\r\ + \n \"102.133.155.32/28\",\r\n \"102.133.251.64/28\",\r\n\ + \ \"2603:1000:104:1::2c0/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureMachineLearning.SouthAfricaWest\",\r\n \ + \ \"id\": \"AzureMachineLearning.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.27.32/28\",\r\n\ + \ \"102.133.58.224/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMachineLearning.SouthCentralUS\",\r\n \"\ + id\": \"AzureMachineLearning.SouthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.87.135/32\",\r\n\ + \ \"13.73.240.16/28\",\r\n \"13.73.240.112/28\",\r\n \ + \ \"13.73.240.240/28\",\r\n \"13.73.248.96/28\",\r\n \ + \ \"40.119.8.80/28\",\r\n \"52.249.59.91/32\",\r\n \"\ + 104.214.19.32/28\",\r\n \"2603:1030:807:1::2c0/122\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureMachineLearning.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.8.224/28\",\r\n \ + \ \"20.43.128.112/28\",\r\n \"23.98.82.192/28\",\r\n \ + \ \"40.78.234.128/28\",\r\n \"40.90.184.249/32\",\r\n \ + \ \"52.230.56.136/32\",\r\n \"2603:1040:5:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.SouthIndia\"\ + ,\r\n \"id\": \"AzureMachineLearning.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.197.0/28\",\r\n \ + \ \"40.78.194.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.SwitzerlandNorth\",\r\n \"id\"\ + : \"AzureMachineLearning.SwitzerlandNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.59.48/28\",\r\n\ + \ \"2603:1020:a04:1::2c0/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureMachineLearning.SwitzerlandWest\",\r\n \ + \ \"id\": \"AzureMachineLearning.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.147.32/28\",\r\n\ + \ \"51.107.155.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.UAECentral\",\r\n \"id\": \"\ + AzureMachineLearning.UAECentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.37.67.80/28\",\r\n \ + \ \"20.37.74.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureMachineLearning.UAENorth\",\r\n \"id\": \"AzureMachineLearning.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \ + \ \"65.52.250.192/28\",\r\n \"2603:1040:904:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UKNorth\"\ + ,\r\n \"id\": \"AzureMachineLearning.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.112/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.UKSouth\"\ + ,\r\n \"id\": \"AzureMachineLearning.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.11.24.49/32\",\r\n \ + \ \"51.104.8.64/27\",\r\n \"51.104.24.96/28\",\r\n \ + \ \"51.105.67.16/28\",\r\n \"51.105.75.128/28\",\r\n \ + \ \"51.140.146.208/28\",\r\n \"52.151.111.249/32\",\r\n \ + \ \"2603:1020:705:1::2c0/122\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.UKSouth2\",\r\n \"id\": \"AzureMachineLearning.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureMachineLearning\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.87.56.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureMachineLearning.UKWest\",\r\n \"id\": \"AzureMachineLearning.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.137.161.224/28\",\r\n\ + \ \"51.140.210.208/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMachineLearning.WestCentralUS\",\r\n \"\ + id\": \"AzureMachineLearning.WestCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.194.240/28\",\r\n\ + \ \"52.150.136.80/28\",\r\n \"52.253.131.79/32\",\r\n \ + \ \"52.253.131.198/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.WestEurope\",\r\n \"id\": \"\ + AzureMachineLearning.WestEurope\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureMachineLearning\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.69.64.192/28\",\r\n \ + \ \"13.69.106.192/28\",\r\n \"40.74.24.96/28\",\r\n \"\ + 51.105.129.135/32\",\r\n \"51.144.184.47/32\",\r\n \"52.236.186.192/28\"\ + ,\r\n \"2603:1020:206:1::2c0/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureMachineLearning.WestIndia\",\r\n\ + \ \"id\": \"AzureMachineLearning.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.38.128.48/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMachineLearning.WestUS\"\ + ,\r\n \"id\": \"AzureMachineLearning.WestUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.86.195.35/32\",\r\n\ + \ \"13.87.160.129/32\",\r\n \"40.82.248.80/28\",\r\n \ + \ \"40.112.242.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMachineLearning.WestUS2\",\r\n \"id\": \"AzureMachineLearning.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureMachineLearning\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.140.80/28\",\r\n\ + \ \"20.42.129.16/28\",\r\n \"40.78.242.176/28\",\r\n \ + \ \"40.78.250.112/28\",\r\n \"40.91.77.76/32\",\r\n \ + \ \"52.148.163.43/32\",\r\n \"2603:1030:c06:1::2c0/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor\"\ + ,\r\n \"id\": \"AzureMonitor\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.65.96.175/32\"\ + ,\r\n \"13.65.206.67/32\",\r\n \"13.65.211.125/32\",\r\n\ + \ \"13.66.36.144/32\",\r\n \"13.66.37.172/32\",\r\n \ + \ \"13.66.59.226/32\",\r\n \"13.66.60.151/32\",\r\n \ + \ \"13.66.140.168/29\",\r\n \"13.66.141.152/29\",\r\n \"\ + 13.66.143.218/32\",\r\n \"13.66.160.124/32\",\r\n \"13.66.220.187/32\"\ + ,\r\n \"13.66.231.27/32\",\r\n \"13.67.9.192/28\",\r\n \ + \ \"13.67.10.64/29\",\r\n \"13.67.10.92/30\",\r\n \ + \ \"13.67.15.0/32\",\r\n \"13.67.77.233/32\",\r\n \"13.67.89.191/32\"\ + ,\r\n \"13.68.31.237/32\",\r\n \"13.68.101.211/32\",\r\n\ + \ \"13.68.106.77/32\",\r\n \"13.68.109.212/32\",\r\n \ + \ \"13.68.111.247/32\",\r\n \"13.69.51.175/32\",\r\n \ + \ \"13.69.51.218/32\",\r\n \"13.69.65.16/28\",\r\n \"\ + 13.69.66.136/29\",\r\n \"13.69.67.60/30\",\r\n \"13.69.67.126/32\"\ + ,\r\n \"13.69.106.88/29\",\r\n \"13.69.106.208/28\",\r\n\ + \ \"13.69.229.64/29\",\r\n \"13.69.229.240/29\",\r\n \ + \ \"13.69.233.0/30\",\r\n \"13.70.72.232/29\",\r\n \ + \ \"13.70.73.104/29\",\r\n \"13.70.124.27/32\",\r\n \"\ + 13.70.127.61/32\",\r\n \"13.71.172.128/28\",\r\n \"13.71.172.248/29\"\ + ,\r\n \"13.71.175.128/32\",\r\n \"13.71.187.91/32\",\r\n\ + \ \"13.71.191.47/32\",\r\n \"13.71.195.192/27\",\r\n \ + \ \"13.71.196.56/29\",\r\n \"13.71.199.116/32\",\r\n \ + \ \"13.73.26.213/32\",\r\n \"13.73.240.0/29\",\r\n \"\ + 13.73.242.32/29\",\r\n \"13.73.244.192/31\",\r\n \"13.74.107.88/30\"\ + ,\r\n \"13.74.108.128/29\",\r\n \"13.75.38.0/28\",\r\n \ + \ \"13.75.38.120/29\",\r\n \"13.75.39.76/30\",\r\n \ + \ \"13.75.117.221/32\",\r\n \"13.75.119.169/32\",\r\n \ + \ \"13.75.195.15/32\",\r\n \"13.76.85.243/32\",\r\n \"\ + 13.76.87.86/32\",\r\n \"13.77.52.16/28\",\r\n \"13.77.53.48/29\"\ + ,\r\n \"13.77.53.220/32\",\r\n \"13.77.150.166/32\",\r\n\ + \ \"13.77.155.39/32\",\r\n \"13.77.174.177/32\",\r\n \ + \ \"13.78.10.58/32\",\r\n \"13.78.13.189/32\",\r\n \ + \ \"13.78.108.160/29\",\r\n \"13.78.108.168/30\",\r\n \"\ + 13.78.109.112/29\",\r\n \"13.78.111.192/32\",\r\n \"13.78.135.15/32\"\ + ,\r\n \"13.78.145.11/32\",\r\n \"13.78.151.158/32\",\r\n\ + \ \"13.78.172.58/32\",\r\n \"13.78.189.112/32\",\r\n \ + \ \"13.78.236.149/32\",\r\n \"13.78.237.51/32\",\r\n \ + \ \"13.80.134.255/32\",\r\n \"13.82.100.176/32\",\r\n \ + \ \"13.82.184.151/32\",\r\n \"13.84.134.59/32\",\r\n \"\ + 13.84.148.7/32\",\r\n \"13.84.149.186/32\",\r\n \"13.84.173.179/32\"\ + ,\r\n \"13.84.189.95/32\",\r\n \"13.84.225.10/32\",\r\n\ + \ \"13.85.70.142/32\",\r\n \"13.86.218.224/28\",\r\n \ + \ \"13.86.218.248/29\",\r\n \"13.87.56.248/29\",\r\n \ + \ \"13.87.57.128/28\",\r\n \"13.87.122.248/29\",\r\n \ + \ \"13.87.123.128/28\",\r\n \"13.88.177.28/32\",\r\n \"\ + 13.88.230.43/32\",\r\n \"13.88.247.208/32\",\r\n \"13.88.255.115/32\"\ + ,\r\n \"13.89.42.127/32\",\r\n \"13.89.171.112/30\",\r\n\ + \ \"13.89.174.128/29\",\r\n \"13.90.93.206/32\",\r\n \ + \ \"13.90.248.141/32\",\r\n \"13.90.249.229/32\",\r\n \ + \ \"13.90.251.123/32\",\r\n \"13.91.42.27/32\",\r\n \ + \ \"13.91.102.27/32\",\r\n \"13.92.40.198/32\",\r\n \"13.92.40.223/32\"\ + ,\r\n \"13.92.138.16/32\",\r\n \"13.92.179.52/32\",\r\n\ + \ \"13.92.211.249/32\",\r\n \"13.92.232.146/32\",\r\n \ + \ \"13.92.254.218/32\",\r\n \"13.92.255.146/32\",\r\n \ + \ \"13.93.215.80/32\",\r\n \"13.93.233.49/32\",\r\n \ + \ \"13.93.236.73/32\",\r\n \"13.94.39.13/32\",\r\n \"20.36.107.24/29\"\ + ,\r\n \"20.36.107.160/28\",\r\n \"20.36.114.200/29\",\r\n\ + \ \"20.36.114.208/28\",\r\n \"20.37.74.232/29\",\r\n \ + \ \"20.37.74.240/28\",\r\n \"20.37.152.68/31\",\r\n \ + \ \"20.37.192.68/31\",\r\n \"20.37.198.112/28\",\r\n \"\ + 20.37.227.16/28\",\r\n \"20.38.80.68/31\",\r\n \"20.38.128.64/29\"\ + ,\r\n \"20.38.146.152/29\",\r\n \"20.38.147.144/29\",\r\n\ + \ \"20.39.14.0/28\",\r\n \"20.40.124.0/32\",\r\n \ + \ \"20.40.137.91/32\",\r\n \"20.40.140.212/32\",\r\n \"\ + 20.40.160.120/32\",\r\n \"20.40.206.128/28\",\r\n \"20.41.49.208/32\"\ + ,\r\n \"20.41.64.68/31\",\r\n \"20.41.67.112/28\",\r\n \ + \ \"20.42.0.68/31\",\r\n \"20.42.128.68/31\",\r\n \ + \ \"20.42.230.112/28\",\r\n \"20.43.40.68/31\",\r\n \"\ + 20.43.44.128/28\",\r\n \"20.43.64.68/31\",\r\n \"20.43.70.96/28\"\ + ,\r\n \"20.43.98.234/32\",\r\n \"20.43.99.158/32\",\r\n\ + \ \"20.43.120.0/29\",\r\n \"20.43.120.240/29\",\r\n \ + \ \"20.43.128.68/31\",\r\n \"20.43.152.45/32\",\r\n \ + \ \"20.44.3.48/28\",\r\n \"20.44.8.0/28\",\r\n \"20.44.16.0/29\"\ + ,\r\n \"20.44.17.0/29\",\r\n \"20.44.26.152/29\",\r\n \ + \ \"20.44.26.248/29\",\r\n \"20.44.73.196/32\",\r\n \ + \ \"20.44.192.217/32\",\r\n \"20.45.122.152/29\",\r\n \ + \ \"20.45.123.80/29\",\r\n \"20.45.123.116/30\",\r\n \"\ + 20.45.125.224/28\",\r\n \"20.49.83.32/28\",\r\n \"20.49.91.32/28\"\ + ,\r\n \"20.49.99.64/28\",\r\n \"20.49.109.80/28\",\r\n \ + \ \"20.49.120.64/28\",\r\n \"20.50.65.80/28\",\r\n \ + \ \"20.150.171.208/29\",\r\n \"20.150.173.0/28\",\r\n \ + \ \"20.150.178.152/29\",\r\n \"20.150.181.96/28\",\r\n \ + \ \"20.150.186.152/29\",\r\n \"20.188.36.28/32\",\r\n \"\ + 20.189.109.144/28\",\r\n \"20.190.60.32/32\",\r\n \"20.190.60.38/32\"\ + ,\r\n \"20.192.98.152/29\",\r\n \"20.192.235.144/28\",\r\ + \n \"20.193.203.112/28\",\r\n \"20.194.67.32/28\",\r\n \ + \ \"23.96.28.38/32\",\r\n \"23.96.245.125/32\",\r\n \ + \ \"23.96.252.161/32\",\r\n \"23.96.252.216/32\",\r\n \ + \ \"23.97.65.103/32\",\r\n \"23.98.82.120/29\",\r\n \"\ + 23.98.82.208/28\",\r\n \"23.98.104.160/28\",\r\n \"23.99.130.172/32\"\ + ,\r\n \"23.100.90.7/32\",\r\n \"23.100.94.221/32\",\r\n\ + \ \"23.100.122.113/32\",\r\n \"23.100.228.32/32\",\r\n \ + \ \"23.101.0.142/32\",\r\n \"23.101.9.4/32\",\r\n \ + \ \"23.101.13.65/32\",\r\n \"23.101.69.223/32\",\r\n \"\ + 23.101.225.155/32\",\r\n \"23.101.232.120/32\",\r\n \"23.101.239.238/32\"\ + ,\r\n \"23.102.44.211/32\",\r\n \"23.102.45.216/32\",\r\n\ + \ \"23.102.66.132/32\",\r\n \"23.102.77.48/32\",\r\n \ + \ \"23.102.181.197/32\",\r\n \"40.64.132.128/28\",\r\n \ + \ \"40.67.59.192/28\",\r\n \"40.68.61.229/32\",\r\n \ + \ \"40.68.154.39/32\",\r\n \"40.69.81.159/32\",\r\n \"\ + 40.69.107.16/28\",\r\n \"40.69.108.48/29\",\r\n \"40.69.194.158/32\"\ + ,\r\n \"40.70.23.205/32\",\r\n \"40.70.148.0/30\",\r\n \ + \ \"40.70.148.8/29\",\r\n \"40.71.12.224/28\",\r\n \ + \ \"40.71.12.240/30\",\r\n \"40.71.12.248/29\",\r\n \"\ + 40.71.13.168/29\",\r\n \"40.71.14.112/30\",\r\n \"40.71.183.225/32\"\ + ,\r\n \"40.74.24.68/31\",\r\n \"40.74.36.208/32\",\r\n \ + \ \"40.74.59.40/32\",\r\n \"40.74.101.32/28\",\r\n \ + \ \"40.74.101.200/29\",\r\n \"40.74.146.84/30\",\r\n \ + \ \"40.74.147.160/29\",\r\n \"40.74.249.98/32\",\r\n \"\ + 40.75.34.40/29\",\r\n \"40.75.35.64/29\",\r\n \"40.76.29.55/32\"\ + ,\r\n \"40.76.53.225/32\",\r\n \"40.77.17.183/32\",\r\n\ + \ \"40.77.22.234/32\",\r\n \"40.77.24.27/32\",\r\n \ + \ \"40.77.101.95/32\",\r\n \"40.77.109.134/32\",\r\n \ + \ \"40.78.23.86/32\",\r\n \"40.78.57.61/32\",\r\n \"40.78.107.177/32\"\ + ,\r\n \"40.78.195.16/28\",\r\n \"40.78.196.48/29\",\r\n\ + \ \"40.78.202.144/28\",\r\n \"40.78.203.240/29\",\r\n \ + \ \"40.78.226.216/29\",\r\n \"40.78.229.32/29\",\r\n \ + \ \"40.78.234.56/29\",\r\n \"40.78.234.144/28\",\r\n \ + \ \"40.78.242.168/30\",\r\n \"40.78.243.16/29\",\r\n \"\ + 40.78.250.104/30\",\r\n \"40.78.250.208/29\",\r\n \"40.79.130.240/29\"\ + ,\r\n \"40.79.132.32/29\",\r\n \"40.79.138.40/30\",\r\n\ + \ \"40.79.138.144/29\",\r\n \"40.79.146.40/30\",\r\n \ + \ \"40.79.146.144/29\",\r\n \"40.79.154.80/29\",\r\n \ + \ \"40.79.156.32/29\",\r\n \"40.79.162.40/29\",\r\n \"\ + 40.79.163.0/29\",\r\n \"40.79.165.64/28\",\r\n \"40.79.170.24/29\"\ + ,\r\n \"40.79.170.240/29\",\r\n \"40.79.179.8/29\",\r\n\ + \ \"40.79.179.16/28\",\r\n \"40.79.187.8/29\",\r\n \ + \ \"40.79.194.104/29\",\r\n \"40.79.194.112/29\",\r\n \ + \ \"40.80.50.152/29\",\r\n \"40.80.51.80/29\",\r\n \"\ + 40.80.191.224/28\",\r\n \"40.81.58.225/32\",\r\n \"40.84.133.5/32\"\ + ,\r\n \"40.84.150.47/32\",\r\n \"40.84.189.107/32\",\r\n\ + \ \"40.84.192.116/32\",\r\n \"40.85.180.90/32\",\r\n \ + \ \"40.85.201.168/32\",\r\n \"40.85.218.175/32\",\r\n \ + \ \"40.85.248.43/32\",\r\n \"40.86.89.165/32\",\r\n \ + \ \"40.86.201.128/32\",\r\n \"40.87.67.118/32\",\r\n \"\ + 40.87.138.220/32\",\r\n \"40.87.140.215/32\",\r\n \"40.89.153.171/32\"\ + ,\r\n \"40.89.189.61/32\",\r\n \"40.112.49.101/32\",\r\n\ + \ \"40.112.74.241/32\",\r\n \"40.113.176.128/28\",\r\n \ + \ \"40.114.241.141/32\",\r\n \"40.115.54.120/32\",\r\n \ + \ \"40.115.103.168/32\",\r\n \"40.115.104.31/32\",\r\n \ + \ \"40.117.80.207/32\",\r\n \"40.117.95.162/32\",\r\n \ + \ \"40.117.147.74/32\",\r\n \"40.117.190.239/32\",\r\n \ + \ \"40.117.197.224/32\",\r\n \"40.118.129.58/32\",\r\n \ + \ \"40.119.4.128/32\",\r\n \"40.119.8.72/31\",\r\n \"\ + 40.119.11.160/28\",\r\n \"40.120.75.32/28\",\r\n \"40.121.57.2/32\"\ + ,\r\n \"40.121.61.208/32\",\r\n \"40.121.135.131/32\",\r\ + \n \"40.121.163.228/32\",\r\n \"40.121.165.150/32\",\r\n\ + \ \"40.121.210.163/32\",\r\n \"40.126.246.183/32\",\r\n\ + \ \"40.127.75.125/32\",\r\n \"40.127.84.197/32\",\r\n \ + \ \"40.127.144.141/32\",\r\n \"51.12.99.72/29\",\r\n \ + \ \"51.12.203.208/28\",\r\n \"51.12.226.152/29\",\r\n \ + \ \"51.12.234.152/29\",\r\n \"51.104.8.104/29\",\r\n \"\ + 51.104.15.255/32\",\r\n \"51.104.24.68/31\",\r\n \"51.104.29.192/28\"\ + ,\r\n \"51.104.252.13/32\",\r\n \"51.104.255.249/32\",\r\ + \n \"51.105.66.152/29\",\r\n \"51.105.67.160/29\",\r\n \ + \ \"51.105.74.152/29\",\r\n \"51.105.75.144/29\",\r\n \ + \ \"51.105.248.23/32\",\r\n \"51.107.48.68/31\",\r\n \ + \ \"51.107.51.16/28\",\r\n \"51.107.59.176/28\",\r\n \ + \ \"51.107.75.144/32\",\r\n \"51.107.75.207/32\",\r\n \"\ + 51.107.147.16/28\",\r\n \"51.107.155.176/28\",\r\n \"51.107.156.48/29\"\ + ,\r\n \"51.116.59.176/28\",\r\n \"51.116.155.240/28\",\r\ + \n \"51.116.242.152/29\",\r\n \"51.116.245.96/28\",\r\n\ + \ \"51.116.250.152/29\",\r\n \"51.116.253.32/28\",\r\n \ + \ \"51.120.40.68/31\",\r\n \"51.120.98.0/29\",\r\n \ + \ \"51.120.98.248/29\",\r\n \"51.120.106.152/29\",\r\n \ + \ \"51.120.210.152/29\",\r\n \"51.120.219.208/28\",\r\n \ + \ \"51.137.164.112/28\",\r\n \"51.140.6.23/32\",\r\n \"\ + 51.140.54.208/32\",\r\n \"51.140.60.235/32\",\r\n \"51.140.69.144/32\"\ + ,\r\n \"51.140.148.48/28\",\r\n \"51.140.152.61/32\",\r\n\ + \ \"51.140.152.186/32\",\r\n \"51.140.163.207/32\",\r\n\ + \ \"51.140.180.52/32\",\r\n \"51.140.181.40/32\",\r\n \ + \ \"51.140.211.160/28\",\r\n \"51.140.212.64/29\",\r\n \ + \ \"51.141.113.128/32\",\r\n \"51.143.88.183/32\",\r\n \ + \ \"51.143.165.22/32\",\r\n \"51.144.41.38/32\",\r\n \ + \ \"51.144.81.252/32\",\r\n \"51.145.44.242/32\",\r\n \ + \ \"52.138.31.112/32\",\r\n \"52.138.31.127/32\",\r\n \"\ + 52.138.90.48/30\",\r\n \"52.138.90.56/29\",\r\n \"52.138.222.110/32\"\ + ,\r\n \"52.138.226.88/29\",\r\n \"52.138.227.128/29\",\r\ + \n \"52.139.8.32/32\",\r\n \"52.140.104.68/31\",\r\n \ + \ \"52.140.108.96/28\",\r\n \"52.141.22.149/32\",\r\n \ + \ \"52.141.22.239/32\",\r\n \"52.150.36.187/32\",\r\n \ + \ \"52.150.152.48/28\",\r\n \"52.151.11.176/32\",\r\n \ + \ \"52.155.118.97/32\",\r\n \"52.155.162.238/32\",\r\n \"\ + 52.156.40.142/32\",\r\n \"52.156.168.82/32\",\r\n \"52.161.8.76/32\"\ + ,\r\n \"52.161.11.71/32\",\r\n \"52.161.12.245/32\",\r\n\ + \ \"52.162.87.50/32\",\r\n \"52.162.110.64/28\",\r\n \ + \ \"52.162.110.168/29\",\r\n \"52.162.214.75/32\",\r\n \ + \ \"52.163.94.131/32\",\r\n \"52.163.122.20/32\",\r\n \ + \ \"52.164.120.183/32\",\r\n \"52.164.125.22/32\",\r\n \ + \ \"52.164.225.5/32\",\r\n \"52.165.27.187/32\",\r\n \"\ + 52.165.34.117/32\",\r\n \"52.165.38.20/32\",\r\n \"52.165.150.242/32\"\ + ,\r\n \"52.167.106.88/29\",\r\n \"52.167.107.64/29\",\r\n\ + \ \"52.167.221.184/32\",\r\n \"52.168.112.64/32\",\r\n \ + \ \"52.168.136.177/32\",\r\n \"52.169.4.236/32\",\r\n \ + \ \"52.169.15.254/32\",\r\n \"52.169.30.110/32\",\r\n \ + \ \"52.169.64.244/32\",\r\n \"52.171.56.178/32\",\r\n \ + \ \"52.171.138.167/32\",\r\n \"52.172.209.125/32\",\r\n \ + \ \"52.173.25.25/32\",\r\n \"52.173.33.254/32\",\r\n \"\ + 52.173.90.199/32\",\r\n \"52.173.185.24/32\",\r\n \"52.173.196.209/32\"\ + ,\r\n \"52.173.196.230/32\",\r\n \"52.173.249.138/32\",\r\ + \n \"52.175.198.74/32\",\r\n \"52.175.231.105/32\",\r\n\ + \ \"52.175.235.148/32\",\r\n \"52.176.42.206/32\",\r\n \ + \ \"52.176.46.30/32\",\r\n \"52.176.49.206/32\",\r\n \ + \ \"52.176.55.135/32\",\r\n \"52.176.92.196/32\",\r\n \ + \ \"52.177.223.60/32\",\r\n \"52.178.26.73/32\",\r\n \ + \ \"52.178.37.209/32\",\r\n \"52.179.192.178/32\",\r\n \"\ + 52.180.160.132/32\",\r\n \"52.180.164.91/32\",\r\n \"52.180.178.187/32\"\ + ,\r\n \"52.180.182.209/32\",\r\n \"52.182.138.216/29\",\r\ + \n \"52.182.139.48/29\",\r\n \"52.183.41.109/32\",\r\n \ + \ \"52.183.66.112/32\",\r\n \"52.183.73.112/32\",\r\n \ + \ \"52.183.95.86/32\",\r\n \"52.183.127.155/32\",\r\n \ + \ \"52.184.158.205/32\",\r\n \"52.185.132.101/32\",\r\n \ + \ \"52.185.132.170/32\",\r\n \"52.185.215.171/32\",\r\n \ + \ \"52.186.121.41/32\",\r\n \"52.186.126.31/32\",\r\n \ + \ \"52.188.179.229/32\",\r\n \"52.191.170.253/32\",\r\n \ + \ \"52.191.197.52/32\",\r\n \"52.224.125.230/32\",\r\n \ + \ \"52.224.162.220/32\",\r\n \"52.224.235.3/32\",\r\n \"\ + 52.226.151.250/32\",\r\n \"52.228.80.68/31\",\r\n \"52.228.85.192/28\"\ + ,\r\n \"52.229.25.130/32\",\r\n \"52.229.37.75/32\",\r\n\ + \ \"52.229.218.221/32\",\r\n \"52.229.225.6/32\",\r\n \ + \ \"52.230.224.237/32\",\r\n \"52.231.18.240/28\",\r\n \ + \ \"52.231.28.204/32\",\r\n \"52.231.33.16/32\",\r\n \ + \ \"52.231.64.72/32\",\r\n \"52.231.67.208/32\",\r\n \ + \ \"52.231.70.0/32\",\r\n \"52.231.108.46/32\",\r\n \"52.231.111.52/32\"\ + ,\r\n \"52.231.147.160/28\",\r\n \"52.231.148.80/29\",\r\ + \n \"52.232.35.33/32\",\r\n \"52.232.65.133/32\",\r\n \ + \ \"52.232.106.242/32\",\r\n \"52.236.186.88/29\",\r\n \ + \ \"52.236.186.208/28\",\r\n \"52.237.34.41/32\",\r\n \ + \ \"52.237.157.70/32\",\r\n \"52.242.230.209/32\",\r\n \ + \ \"52.246.154.152/29\",\r\n \"52.246.155.144/29\",\r\n \ + \ \"52.246.157.16/28\",\r\n \"52.247.202.90/32\",\r\n \ + \ \"65.52.2.145/32\",\r\n \"65.52.5.76/32\",\r\n \"65.52.122.208/32\"\ + ,\r\n \"65.52.250.232/29\",\r\n \"65.52.250.240/28\",\r\n\ + \ \"102.133.27.48/28\",\r\n \"102.133.28.64/29\",\r\n \ + \ \"102.133.122.152/29\",\r\n \"102.133.123.240/29\",\r\n\ + \ \"102.133.155.48/28\",\r\n \"102.133.161.73/32\",\r\n\ + \ \"102.133.162.233/32\",\r\n \"102.133.216.68/31\",\r\n\ + \ \"102.133.218.144/28\",\r\n \"102.133.250.152/29\",\r\n\ + \ \"102.133.251.80/29\",\r\n \"104.40.222.36/32\",\r\n \ + \ \"104.41.61.169/32\",\r\n \"104.41.152.101/32\",\r\n \ + \ \"104.41.157.59/32\",\r\n \"104.41.224.134/32\",\r\n \ + \ \"104.42.40.28/32\",\r\n \"104.44.140.84/32\",\r\n \ + \ \"104.45.136.42/32\",\r\n \"104.45.230.69/32\",\r\n \ + \ \"104.45.232.72/32\",\r\n \"104.46.123.164/32\",\r\n \ + \ \"104.208.33.155/32\",\r\n \"104.208.34.98/32\",\r\n \"\ + 104.208.35.169/32\",\r\n \"104.209.156.106/32\",\r\n \"\ + 104.209.161.217/32\",\r\n \"104.210.9.42/32\",\r\n \"104.211.79.84/32\"\ + ,\r\n \"104.211.90.234/32\",\r\n \"104.211.91.254/32\",\r\ + \n \"104.211.92.54/32\",\r\n \"104.211.92.218/32\",\r\n\ + \ \"104.211.95.59/32\",\r\n \"104.211.96.228/32\",\r\n \ + \ \"104.211.103.96/32\",\r\n \"104.211.147.128/28\",\r\n\ + \ \"104.211.216.161/32\",\r\n \"104.214.70.219/32\",\r\n\ + \ \"104.214.104.109/32\",\r\n \"104.215.81.124/32\",\r\n\ + \ \"104.215.96.105/32\",\r\n \"104.215.100.22/32\",\r\n\ + \ \"104.215.103.78/32\",\r\n \"104.215.115.118/32\",\r\n\ + \ \"111.221.88.173/32\",\r\n \"137.116.82.175/32\",\r\n\ + \ \"137.116.146.215/32\",\r\n \"137.116.151.139/32\",\r\n\ + \ \"137.116.226.81/32\",\r\n \"137.117.144.33/32\",\r\n\ + \ \"138.91.9.98/32\",\r\n \"138.91.32.98/32\",\r\n \ + \ \"138.91.37.93/32\",\r\n \"157.55.177.6/32\",\r\n \ + \ \"168.61.179.178/32\",\r\n \"168.62.169.17/32\",\r\n \"\ + 168.63.174.169/32\",\r\n \"168.63.242.221/32\",\r\n \"191.232.33.83/32\"\ + ,\r\n \"191.232.161.75/32\",\r\n \"191.232.213.23/32\",\r\ + \n \"191.232.213.239/32\",\r\n \"191.232.214.6/32\",\r\n\ + \ \"191.232.239.181/32\",\r\n \"191.233.51.128/28\",\r\n\ + \ \"191.233.203.232/29\",\r\n \"191.233.204.248/29\",\r\n\ + \ \"191.234.136.80/28\",\r\n \"191.234.146.152/29\",\r\n\ + \ \"191.234.149.144/28\",\r\n \"191.234.154.152/29\",\r\n\ + \ \"191.234.157.48/28\",\r\n \"191.235.224.68/31\",\r\n\ + \ \"191.239.251.90/32\",\r\n \"207.46.224.101/32\",\r\n\ + \ \"207.46.236.191/32\",\r\n \"2603:1000:104:1::280/122\"\ + ,\r\n \"2603:1010:6:1::280/122\",\r\n \"2603:1020:5:1::280/122\"\ + ,\r\n \"2603:1020:206:1::280/122\",\r\n \"2603:1020:705:1::280/122\"\ + ,\r\n \"2603:1020:805:1::280/122\",\r\n \"2603:1020:a04:1::280/122\"\ + ,\r\n \"2603:1020:c01:2::b/128\",\r\n \"2603:1020:c01:2::e/128\"\ + ,\r\n \"2603:1020:c04:1::280/122\",\r\n \"2603:1020:d01:2::a/128\"\ + ,\r\n \"2603:1020:e04:1::280/122\",\r\n \"2603:1020:1004::280/122\"\ + ,\r\n \"2603:1030:10:1::280/122\",\r\n \"2603:1030:104:1::280/122\"\ + ,\r\n \"2603:1030:210:1::280/122\",\r\n \"2603:1030:40b:1::280/122\"\ + ,\r\n \"2603:1030:40c:1::280/122\",\r\n \"2603:1030:504:1::280/122\"\ + ,\r\n \"2603:1030:800:5::bfee:a418/128\",\r\n \"2603:1030:800:5::bfee:a42a/128\"\ + ,\r\n \"2603:1030:800:5::bfee:a435/128\",\r\n \"2603:1030:807:1::280/122\"\ + ,\r\n \"2603:1030:b00::e8/128\",\r\n \"2603:1030:b00::164/128\"\ + ,\r\n \"2603:1030:b00::2a1/128\",\r\n \"2603:1030:b00::4db/128\"\ + ,\r\n \"2603:1030:c02:2::4e1/128\",\r\n \"2603:1030:c06:1::280/122\"\ + ,\r\n \"2603:1030:d00::1d/128\",\r\n \"2603:1030:d00::48/128\"\ + ,\r\n \"2603:1030:d00::5a/128\",\r\n \"2603:1030:f05:1::280/122\"\ + ,\r\n \"2603:1040:5:1::280/122\",\r\n \"2603:1040:407:1::280/122\"\ + ,\r\n \"2603:1040:904:1::280/122\",\r\n \"2603:1040:a06:1::280/122\"\ + ,\r\n \"2603:1040:d04::280/122\",\r\n \"2603:1040:f05:1::280/122\"\ + ,\r\n \"2603:1050:6:1::280/122\",\r\n \"2603:1050:403::280/122\"\ + ,\r\n \"2a01:111:f100:1003::4134:36c2/128\",\r\n \"2a01:111:f100:1003::4134:36d9/128\"\ + ,\r\n \"2a01:111:f100:1003::4134:370d/128\",\r\n \"2a01:111:f100:2000::a83e:3015/128\"\ + ,\r\n \"2a01:111:f100:2000::a83e:301c/128\",\r\n \"2a01:111:f100:2000::a83e:3083/128\"\ + ,\r\n \"2a01:111:f100:2000::a83e:335c/128\",\r\n \"2a01:111:f100:2000::a83e:3370/128\"\ + ,\r\n \"2a01:111:f100:2002::8975:2c8c/128\",\r\n \"2a01:111:f100:2002::8975:2d44/128\"\ + ,\r\n \"2a01:111:f100:2002::8975:2e91/128\",\r\n \"2a01:111:f100:3000::a83e:187a/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:187c/128\",\r\n \"2a01:111:f100:3000::a83e:1913/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:19c0/128\",\r\n \"2a01:111:f100:3000::a83e:1a55/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:1a8e/128\",\r\n \"2a01:111:f100:3000::a83e:1adf/128\"\ + ,\r\n \"2a01:111:f100:4002::9d37:c0bd/128\",\r\n \"2a01:111:f100:6000::4134:a6cf/128\"\ + ,\r\n \"2a01:111:f100:7000::6fdd:5343/128\",\r\n \"2a01:111:f100:9001::1761:91e4/128\"\ + ,\r\n \"2a01:111:f100:a001::4134:e463/128\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureMonitor.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.36.107.24/29\"\ + ,\r\n \"20.36.107.160/28\",\r\n \"20.37.227.16/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.AustraliaCentral2\"\ + ,\r\n \"id\": \"AzureMonitor.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.200/29\"\ + ,\r\n \"20.36.114.208/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.AustraliaEast\",\r\n \"id\"\ + : \"AzureMonitor.AustraliaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.72.232/29\",\r\n\ + \ \"13.70.73.104/29\",\r\n \"13.70.124.27/32\",\r\n \ + \ \"13.70.127.61/32\",\r\n \"13.75.195.15/32\",\r\n \ + \ \"20.37.192.68/31\",\r\n \"20.37.198.112/28\",\r\n \"\ + 20.40.124.0/32\",\r\n \"20.43.98.234/32\",\r\n \"20.43.99.158/32\"\ + ,\r\n \"40.79.162.40/29\",\r\n \"40.79.163.0/29\",\r\n \ + \ \"40.79.165.64/28\",\r\n \"40.79.170.24/29\",\r\n \ + \ \"40.79.170.240/29\",\r\n \"40.126.246.183/32\",\r\n \ + \ \"52.156.168.82/32\",\r\n \"2603:1010:6:1::280/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzureMonitor.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.77.52.16/28\"\ + ,\r\n \"13.77.53.48/29\",\r\n \"13.77.53.220/32\",\r\n \ + \ \"20.40.160.120/32\",\r\n \"20.42.230.112/28\",\r\n \ + \ \"23.101.225.155/32\",\r\n \"23.101.232.120/32\",\r\n \ + \ \"23.101.239.238/32\",\r\n \"40.81.58.225/32\",\r\n \ + \ \"40.127.75.125/32\",\r\n \"40.127.84.197/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.BrazilSouth\"\ + ,\r\n \"id\": \"AzureMonitor.BrazilSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"104.41.61.169/32\"\ + ,\r\n \"191.232.33.83/32\",\r\n \"191.232.161.75/32\",\r\ + \n \"191.232.213.23/32\",\r\n \"191.232.213.239/32\",\r\n\ + \ \"191.232.214.6/32\",\r\n \"191.232.239.181/32\",\r\n\ + \ \"191.233.203.232/29\",\r\n \"191.233.204.248/29\",\r\n\ + \ \"191.234.136.80/28\",\r\n \"191.234.146.152/29\",\r\n\ + \ \"191.234.149.144/28\",\r\n \"191.234.154.152/29\",\r\n\ + \ \"191.234.157.48/28\",\r\n \"191.235.224.68/31\",\r\n\ + \ \"191.239.251.90/32\",\r\n \"2603:1050:6:1::280/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.CanadaCentral\"\ + ,\r\n \"id\": \"AzureMonitor.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.71.172.128/28\"\ + ,\r\n \"13.71.172.248/29\",\r\n \"13.71.175.128/32\",\r\n\ + \ \"13.71.187.91/32\",\r\n \"13.71.191.47/32\",\r\n \ + \ \"13.88.230.43/32\",\r\n \"13.88.247.208/32\",\r\n \ + \ \"13.88.255.115/32\",\r\n \"20.38.146.152/29\",\r\n \ + \ \"20.38.147.144/29\",\r\n \"40.85.201.168/32\",\r\n \"\ + 40.85.218.175/32\",\r\n \"40.85.248.43/32\",\r\n \"52.138.31.112/32\"\ + ,\r\n \"52.138.31.127/32\",\r\n \"52.139.8.32/32\",\r\n\ + \ \"52.228.80.68/31\",\r\n \"52.228.85.192/28\",\r\n \ + \ \"52.237.34.41/32\",\r\n \"52.246.154.152/29\",\r\n \ + \ \"52.246.155.144/29\",\r\n \"52.246.157.16/28\",\r\n \ + \ \"2603:1030:f05:1::280/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.CanadaEast\",\r\n \"id\": \"AzureMonitor.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.69.107.16/28\",\r\n \"40.69.108.48/29\",\r\n\ + \ \"40.86.201.128/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMonitor.CentralIndia\",\r\n \"id\": \"AzureMonitor.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.43.120.0/29\",\r\n \"20.43.120.240/29\",\r\n\ + \ \"20.192.98.152/29\",\r\n \"40.80.50.152/29\",\r\n \ + \ \"40.80.51.80/29\",\r\n \"52.140.104.68/31\",\r\n \ + \ \"52.140.108.96/28\",\r\n \"52.172.209.125/32\",\r\n \ + \ \"104.211.79.84/32\",\r\n \"104.211.90.234/32\",\r\n \ + \ \"104.211.91.254/32\",\r\n \"104.211.92.54/32\",\r\n \"\ + 104.211.92.218/32\",\r\n \"104.211.95.59/32\",\r\n \"104.211.96.228/32\"\ + ,\r\n \"104.211.103.96/32\",\r\n \"2603:1040:a06:1::280/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.CentralUS\"\ + ,\r\n \"id\": \"AzureMonitor.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.89.42.127/32\"\ + ,\r\n \"13.89.171.112/30\",\r\n \"13.89.174.128/29\",\r\n\ + \ \"20.37.152.68/31\",\r\n \"20.40.206.128/28\",\r\n \ + \ \"20.44.8.0/28\",\r\n \"23.99.130.172/32\",\r\n \ + \ \"40.77.17.183/32\",\r\n \"40.77.22.234/32\",\r\n \"40.77.24.27/32\"\ + ,\r\n \"40.77.101.95/32\",\r\n \"40.77.109.134/32\",\r\n\ + \ \"40.86.89.165/32\",\r\n \"52.165.27.187/32\",\r\n \ + \ \"52.165.34.117/32\",\r\n \"52.165.38.20/32\",\r\n \ + \ \"52.165.150.242/32\",\r\n \"52.173.25.25/32\",\r\n \ + \ \"52.173.33.254/32\",\r\n \"52.173.90.199/32\",\r\n \"\ + 52.173.185.24/32\",\r\n \"52.173.196.209/32\",\r\n \"52.173.196.230/32\"\ + ,\r\n \"52.173.249.138/32\",\r\n \"52.176.42.206/32\",\r\ + \n \"52.176.46.30/32\",\r\n \"52.176.49.206/32\",\r\n \ + \ \"52.176.55.135/32\",\r\n \"52.176.92.196/32\",\r\n \ + \ \"52.182.138.216/29\",\r\n \"52.182.139.48/29\",\r\n \ + \ \"52.230.224.237/32\",\r\n \"52.242.230.209/32\",\r\n \ + \ \"104.208.33.155/32\",\r\n \"104.208.34.98/32\",\r\n \ + \ \"104.208.35.169/32\",\r\n \"168.61.179.178/32\",\r\n \ + \ \"2603:1030:10:1::280/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.CentralUSEUAP\",\r\n \"id\": \"\ + AzureMonitor.CentralUSEUAP\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centraluseuap\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\ + \n \"addressPrefixes\": [\r\n \"40.78.202.144/28\",\r\n \ + \ \"40.78.203.240/29\",\r\n \"52.180.160.132/32\",\r\n \ + \ \"52.180.164.91/32\",\r\n \"52.180.178.187/32\",\r\n \ + \ \"52.180.182.209/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureMonitor.EastAsia\",\r\n \"id\": \"AzureMonitor.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.75.38.0/28\",\r\n \"13.75.38.120/29\",\r\n\ + \ \"13.75.39.76/30\",\r\n \"13.75.117.221/32\",\r\n \ + \ \"13.75.119.169/32\",\r\n \"13.94.39.13/32\",\r\n \ + \ \"20.189.109.144/28\",\r\n \"23.97.65.103/32\",\r\n \"\ + 23.100.90.7/32\",\r\n \"23.100.94.221/32\",\r\n \"23.101.0.142/32\"\ + ,\r\n \"23.101.9.4/32\",\r\n \"23.101.13.65/32\",\r\n \ + \ \"52.229.218.221/32\",\r\n \"52.229.225.6/32\",\r\n \ + \ \"2a01:111:f100:6000::4134:a6cf/128\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureMonitor.EastUS\",\r\n \"id\"\ + : \"AzureMonitor.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.82.100.176/32\",\r\n \"\ + 13.82.184.151/32\",\r\n \"13.90.93.206/32\",\r\n \"13.90.248.141/32\"\ + ,\r\n \"13.90.249.229/32\",\r\n \"13.90.251.123/32\",\r\n\ + \ \"13.92.40.198/32\",\r\n \"13.92.40.223/32\",\r\n \ + \ \"13.92.138.16/32\",\r\n \"13.92.179.52/32\",\r\n \ + \ \"13.92.211.249/32\",\r\n \"13.92.232.146/32\",\r\n \"\ + 13.92.254.218/32\",\r\n \"13.92.255.146/32\",\r\n \"20.42.0.68/31\"\ + ,\r\n \"20.49.109.80/28\",\r\n \"23.96.28.38/32\",\r\n \ + \ \"40.71.12.224/28\",\r\n \"40.71.12.240/30\",\r\n \ + \ \"40.71.12.248/29\",\r\n \"40.71.13.168/29\",\r\n \ + \ \"40.71.14.112/30\",\r\n \"40.71.183.225/32\",\r\n \"\ + 40.76.29.55/32\",\r\n \"40.76.53.225/32\",\r\n \"40.78.226.216/29\"\ + ,\r\n \"40.78.229.32/29\",\r\n \"40.79.154.80/29\",\r\n\ + \ \"40.79.156.32/29\",\r\n \"40.85.180.90/32\",\r\n \ + \ \"40.87.67.118/32\",\r\n \"40.112.49.101/32\",\r\n \ + \ \"40.117.80.207/32\",\r\n \"40.117.95.162/32\",\r\n \ + \ \"40.117.147.74/32\",\r\n \"40.117.190.239/32\",\r\n \"\ + 40.117.197.224/32\",\r\n \"40.121.57.2/32\",\r\n \"40.121.61.208/32\"\ + ,\r\n \"40.121.135.131/32\",\r\n \"40.121.163.228/32\",\r\ + \n \"40.121.165.150/32\",\r\n \"40.121.210.163/32\",\r\n\ + \ \"52.150.36.187/32\",\r\n \"52.168.112.64/32\",\r\n \ + \ \"52.168.136.177/32\",\r\n \"52.186.121.41/32\",\r\n \ + \ \"52.186.126.31/32\",\r\n \"52.188.179.229/32\",\r\n \ + \ \"52.191.197.52/32\",\r\n \"52.224.125.230/32\",\r\n \ + \ \"52.224.162.220/32\",\r\n \"52.224.235.3/32\",\r\n \ + \ \"52.226.151.250/32\",\r\n \"104.41.152.101/32\",\r\n \ + \ \"104.41.157.59/32\",\r\n \"104.45.136.42/32\",\r\n \ + \ \"168.62.169.17/32\",\r\n \"2603:1030:210:1::280/122\",\r\n \ + \ \"2a01:111:f100:2000::a83e:3015/128\",\r\n \"2a01:111:f100:2000::a83e:301c/128\"\ + ,\r\n \"2a01:111:f100:2000::a83e:3083/128\",\r\n \"2a01:111:f100:2000::a83e:335c/128\"\ + ,\r\n \"2a01:111:f100:2000::a83e:3370/128\",\r\n \"2a01:111:f100:2002::8975:2c8c/128\"\ + ,\r\n \"2a01:111:f100:2002::8975:2d44/128\",\r\n \"2a01:111:f100:2002::8975:2e91/128\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.EastUS2\"\ + ,\r\n \"id\": \"AzureMonitor.EastUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.68.31.237/32\"\ + ,\r\n \"13.68.101.211/32\",\r\n \"13.68.106.77/32\",\r\n\ + \ \"13.68.109.212/32\",\r\n \"13.68.111.247/32\",\r\n \ + \ \"20.41.49.208/32\",\r\n \"20.44.16.0/29\",\r\n \ + \ \"20.44.17.0/29\",\r\n \"20.44.73.196/32\",\r\n \"20.49.99.64/28\"\ + ,\r\n \"40.70.23.205/32\",\r\n \"40.70.148.0/30\",\r\n \ + \ \"40.70.148.8/29\",\r\n \"52.167.106.88/29\",\r\n \ + \ \"52.167.107.64/29\",\r\n \"52.167.221.184/32\",\r\n \ + \ \"52.177.223.60/32\",\r\n \"52.179.192.178/32\",\r\n \ + \ \"52.184.158.205/32\",\r\n \"104.46.123.164/32\",\r\n \ + \ \"104.209.156.106/32\",\r\n \"104.209.161.217/32\",\r\n \ + \ \"104.210.9.42/32\",\r\n \"137.116.82.175/32\",\r\n \ + \ \"2603:1030:40c:1::280/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.EastUS2EUAP\",\r\n \"id\": \"AzureMonitor.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.39.14.0/28\",\r\n \"40.74.146.84/30\",\r\n\ + \ \"40.74.147.160/29\",\r\n \"40.75.34.40/29\",\r\n \ + \ \"40.75.35.64/29\",\r\n \"52.138.90.48/30\",\r\n \ + \ \"52.138.90.56/29\",\r\n \"2603:1030:40b:1::280/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.FranceCentral\"\ + ,\r\n \"id\": \"AzureMonitor.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.40.137.91/32\"\ + ,\r\n \"20.40.140.212/32\",\r\n \"20.43.40.68/31\",\r\n\ + \ \"20.43.44.128/28\",\r\n \"20.188.36.28/32\",\r\n \ + \ \"40.79.130.240/29\",\r\n \"40.79.132.32/29\",\r\n \ + \ \"40.79.138.40/30\",\r\n \"40.79.138.144/29\",\r\n \"\ + 40.79.146.40/30\",\r\n \"40.79.146.144/29\",\r\n \"40.89.153.171/32\"\ + ,\r\n \"40.89.189.61/32\",\r\n \"2603:1020:805:1::280/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.FranceSouth\"\ + ,\r\n \"id\": \"AzureMonitor.FranceSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"40.79.179.8/29\"\ + ,\r\n \"40.79.179.16/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.GermanyNorth\",\r\n \"id\": \"\ + AzureMonitor.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.116.59.176/28\",\r\n \ + \ \"2603:1020:d01:2::a/128\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.GermanyWestCentral\",\r\n \"id\"\ + : \"AzureMonitor.GermanyWestCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.116.155.240/28\"\ + ,\r\n \"51.116.242.152/29\",\r\n \"51.116.245.96/28\",\r\ + \n \"51.116.250.152/29\",\r\n \"51.116.253.32/28\",\r\n\ + \ \"2603:1020:c01:2::b/128\",\r\n \"2603:1020:c01:2::e/128\"\ + ,\r\n \"2603:1020:c04:1::280/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureMonitor.JapanEast\",\r\n \"\ + id\": \"AzureMonitor.JapanEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.26.213/32\",\r\n\ + \ \"13.78.10.58/32\",\r\n \"13.78.13.189/32\",\r\n \ + \ \"13.78.108.160/29\",\r\n \"13.78.108.168/30\",\r\n \ + \ \"13.78.109.112/29\",\r\n \"13.78.111.192/32\",\r\n \ + \ \"20.43.64.68/31\",\r\n \"20.43.70.96/28\",\r\n \"23.102.66.132/32\"\ + ,\r\n \"23.102.77.48/32\",\r\n \"40.79.187.8/29\",\r\n \ + \ \"40.79.194.104/29\",\r\n \"40.79.194.112/29\",\r\n \ + \ \"52.155.118.97/32\",\r\n \"52.156.40.142/32\",\r\n \ + \ \"52.185.132.101/32\",\r\n \"52.185.132.170/32\",\r\n \ + \ \"138.91.9.98/32\",\r\n \"2603:1040:407:1::280/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.JapanWest\"\ + ,\r\n \"id\": \"AzureMonitor.JapanWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"40.74.101.32/28\"\ + ,\r\n \"40.74.101.200/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.KoreaCentral\",\r\n \"id\":\ + \ \"AzureMonitor.KoreaCentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.64.68/31\",\r\n \ + \ \"20.41.67.112/28\",\r\n \"20.44.26.152/29\",\r\n \ + \ \"20.44.26.248/29\",\r\n \"20.194.67.32/28\",\r\n \ + \ \"52.141.22.149/32\",\r\n \"52.141.22.239/32\",\r\n \"\ + 52.231.18.240/28\",\r\n \"52.231.28.204/32\",\r\n \"52.231.33.16/32\"\ + ,\r\n \"52.231.64.72/32\",\r\n \"52.231.67.208/32\",\r\n\ + \ \"52.231.70.0/32\",\r\n \"52.231.108.46/32\",\r\n \ + \ \"52.231.111.52/32\",\r\n \"2603:1040:f05:1::280/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.KoreaSouth\"\ + ,\r\n \"id\": \"AzureMonitor.KoreaSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"52.231.147.160/28\"\ + ,\r\n \"52.231.148.80/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.NorthCentralUS\",\r\n \"id\"\ + : \"AzureMonitor.NorthCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"23.96.245.125/32\"\ + ,\r\n \"23.96.252.161/32\",\r\n \"23.96.252.216/32\",\r\n\ + \ \"23.100.228.32/32\",\r\n \"40.80.191.224/28\",\r\n \ + \ \"52.162.87.50/32\",\r\n \"52.162.110.64/28\",\r\n \ + \ \"52.162.110.168/29\",\r\n \"52.162.214.75/32\",\r\n \ + \ \"52.237.157.70/32\",\r\n \"65.52.2.145/32\",\r\n \"\ + 65.52.5.76/32\",\r\n \"2a01:111:f100:1003::4134:36c2/128\",\r\n \ + \ \"2a01:111:f100:1003::4134:36d9/128\",\r\n \"2a01:111:f100:1003::4134:370d/128\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.NorthEurope\"\ + ,\r\n \"id\": \"AzureMonitor.NorthEurope\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.69.229.64/29\"\ + ,\r\n \"13.69.229.240/29\",\r\n \"13.69.233.0/30\",\r\n\ + \ \"13.74.107.88/30\",\r\n \"13.74.108.128/29\",\r\n \ + \ \"20.38.80.68/31\",\r\n \"20.50.65.80/28\",\r\n \ + \ \"23.102.44.211/32\",\r\n \"23.102.45.216/32\",\r\n \"\ + 40.69.81.159/32\",\r\n \"40.69.194.158/32\",\r\n \"40.87.138.220/32\"\ + ,\r\n \"40.87.140.215/32\",\r\n \"40.112.74.241/32\",\r\n\ + \ \"40.115.103.168/32\",\r\n \"40.115.104.31/32\",\r\n \ + \ \"40.127.144.141/32\",\r\n \"52.138.222.110/32\",\r\n \ + \ \"52.138.226.88/29\",\r\n \"52.138.227.128/29\",\r\n \ + \ \"52.155.162.238/32\",\r\n \"52.164.120.183/32\",\r\n \ + \ \"52.164.125.22/32\",\r\n \"52.164.225.5/32\",\r\n \ + \ \"52.169.4.236/32\",\r\n \"52.169.15.254/32\",\r\n \ + \ \"52.169.30.110/32\",\r\n \"52.169.64.244/32\",\r\n \"\ + 104.41.224.134/32\",\r\n \"137.116.226.81/32\",\r\n \"2603:1020:5:1::280/122\"\ + ,\r\n \"2a01:111:f100:a001::4134:e463/128\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.NorwayEast\",\r\n\ + \ \"id\": \"AzureMonitor.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.120.40.68/31\"\ + ,\r\n \"51.120.98.0/29\",\r\n \"51.120.98.248/29\",\r\n\ + \ \"51.120.106.152/29\",\r\n \"51.120.210.152/29\",\r\n\ + \ \"2603:1020:e04:1::280/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureMonitor.NorwayWest\",\r\n \"id\": \"\ + AzureMonitor.NorwayWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.120.219.208/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SouthAfricaNorth\"\ + ,\r\n \"id\": \"AzureMonitor.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"102.133.122.152/29\"\ + ,\r\n \"102.133.123.240/29\",\r\n \"102.133.155.48/28\"\ + ,\r\n \"102.133.161.73/32\",\r\n \"102.133.162.233/32\"\ + ,\r\n \"102.133.216.68/31\",\r\n \"102.133.218.144/28\"\ + ,\r\n \"102.133.250.152/29\",\r\n \"102.133.251.80/29\"\ + ,\r\n \"2603:1000:104:1::280/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzureMonitor.SouthAfricaWest\",\r\n \ + \ \"id\": \"AzureMonitor.SouthAfricaWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"102.133.27.48/28\"\ + ,\r\n \"102.133.28.64/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.SouthCentralUS\",\r\n \"id\"\ + : \"AzureMonitor.SouthCentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.65.96.175/32\"\ + ,\r\n \"13.65.206.67/32\",\r\n \"13.65.211.125/32\",\r\n\ + \ \"13.66.36.144/32\",\r\n \"13.66.37.172/32\",\r\n \ + \ \"13.66.59.226/32\",\r\n \"13.66.60.151/32\",\r\n \ + \ \"13.73.240.0/29\",\r\n \"13.73.242.32/29\",\r\n \"13.73.244.192/31\"\ + ,\r\n \"13.84.134.59/32\",\r\n \"13.84.148.7/32\",\r\n \ + \ \"13.84.149.186/32\",\r\n \"13.84.173.179/32\",\r\n \ + \ \"13.84.189.95/32\",\r\n \"13.84.225.10/32\",\r\n \ + \ \"13.85.70.142/32\",\r\n \"20.45.122.152/29\",\r\n \"\ + 20.45.123.80/29\",\r\n \"20.45.123.116/30\",\r\n \"20.45.125.224/28\"\ + ,\r\n \"20.49.91.32/28\",\r\n \"23.100.122.113/32\",\r\n\ + \ \"23.102.181.197/32\",\r\n \"40.74.249.98/32\",\r\n \ + \ \"40.84.133.5/32\",\r\n \"40.84.150.47/32\",\r\n \ + \ \"40.84.189.107/32\",\r\n \"40.84.192.116/32\",\r\n \ + \ \"40.119.4.128/32\",\r\n \"40.119.8.72/31\",\r\n \"40.119.11.160/28\"\ + ,\r\n \"52.171.56.178/32\",\r\n \"52.171.138.167/32\",\r\ + \n \"52.185.215.171/32\",\r\n \"104.44.140.84/32\",\r\n\ + \ \"104.214.70.219/32\",\r\n \"104.214.104.109/32\",\r\n\ + \ \"104.215.81.124/32\",\r\n \"104.215.96.105/32\",\r\n\ + \ \"104.215.100.22/32\",\r\n \"104.215.103.78/32\",\r\n\ + \ \"104.215.115.118/32\",\r\n \"157.55.177.6/32\",\r\n \ + \ \"2603:1030:800:5::bfee:a418/128\",\r\n \"2603:1030:800:5::bfee:a42a/128\"\ + ,\r\n \"2603:1030:800:5::bfee:a435/128\",\r\n \"2603:1030:807:1::280/122\"\ + ,\r\n \"2a01:111:f100:4002::9d37:c0bd/128\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureMonitor.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.67.9.192/28\"\ + ,\r\n \"13.67.10.64/29\",\r\n \"13.67.10.92/30\",\r\n \ + \ \"13.67.15.0/32\",\r\n \"13.67.77.233/32\",\r\n \ + \ \"13.67.89.191/32\",\r\n \"13.76.85.243/32\",\r\n \"\ + 13.76.87.86/32\",\r\n \"20.43.128.68/31\",\r\n \"20.43.152.45/32\"\ + ,\r\n \"20.44.192.217/32\",\r\n \"23.98.82.120/29\",\r\n\ + \ \"23.98.82.208/28\",\r\n \"23.98.104.160/28\",\r\n \ + \ \"40.78.234.56/29\",\r\n \"40.78.234.144/28\",\r\n \ + \ \"52.163.94.131/32\",\r\n \"52.163.122.20/32\",\r\n \ + \ \"111.221.88.173/32\",\r\n \"137.116.146.215/32\",\r\n \ + \ \"137.116.151.139/32\",\r\n \"138.91.32.98/32\",\r\n \ + \ \"138.91.37.93/32\",\r\n \"168.63.174.169/32\",\r\n \"\ + 168.63.242.221/32\",\r\n \"207.46.224.101/32\",\r\n \"207.46.236.191/32\"\ + ,\r\n \"2603:1040:5:1::280/122\",\r\n \"2a01:111:f100:7000::6fdd:5343/128\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SouthIndia\"\ + ,\r\n \"id\": \"AzureMonitor.SouthIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"40.78.195.16/28\"\ + ,\r\n \"40.78.196.48/29\",\r\n \"104.211.216.161/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.SwitzerlandNorth\"\ + ,\r\n \"id\": \"AzureMonitor.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.107.48.68/31\"\ + ,\r\n \"51.107.51.16/28\",\r\n \"51.107.59.176/28\",\r\n\ + \ \"51.107.75.144/32\",\r\n \"51.107.75.207/32\",\r\n \ + \ \"2603:1020:a04:1::280/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.SwitzerlandWest\",\r\n \"id\"\ + : \"AzureMonitor.SwitzerlandWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"51.107.147.16/28\"\ + ,\r\n \"51.107.155.176/28\",\r\n \"51.107.156.48/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.UAECentral\"\ + ,\r\n \"id\": \"AzureMonitor.UAECentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.232/29\"\ + ,\r\n \"20.37.74.240/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureMonitor.UAENorth\",\r\n \"id\": \"AzureMonitor.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.120.75.32/28\",\r\n \"65.52.250.232/29\",\r\ + \n \"65.52.250.240/28\",\r\n \"2603:1040:904:1::280/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.UKNorth\"\ + ,\r\n \"id\": \"AzureMonitor.UKNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\ + \n \"addressPrefixes\": [\r\n \"13.87.122.248/29\",\r\n \ + \ \"13.87.123.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureMonitor.UKSouth\",\r\n \"id\": \"AzureMonitor.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.104.8.104/29\",\r\n \"51.104.15.255/32\",\r\n \ + \ \"51.104.24.68/31\",\r\n \"51.104.29.192/28\",\r\n \ + \ \"51.104.252.13/32\",\r\n \"51.104.255.249/32\",\r\n \ + \ \"51.105.66.152/29\",\r\n \"51.105.67.160/29\",\r\n \"\ + 51.105.74.152/29\",\r\n \"51.105.75.144/29\",\r\n \"51.140.6.23/32\"\ + ,\r\n \"51.140.54.208/32\",\r\n \"51.140.60.235/32\",\r\n\ + \ \"51.140.69.144/32\",\r\n \"51.140.148.48/28\",\r\n \ + \ \"51.140.152.61/32\",\r\n \"51.140.152.186/32\",\r\n \ + \ \"51.140.163.207/32\",\r\n \"51.140.180.52/32\",\r\n \ + \ \"51.140.181.40/32\",\r\n \"51.143.165.22/32\",\r\n \ + \ \"51.145.44.242/32\",\r\n \"2603:1020:705:1::280/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.UKSouth2\"\ + ,\r\n \"id\": \"AzureMonitor.UKSouth2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureMonitor\",\r\ + \n \"addressPrefixes\": [\r\n \"13.87.56.248/29\",\r\n \ + \ \"13.87.57.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureMonitor.UKWest\",\r\n \"id\": \"AzureMonitor.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.137.164.112/28\",\r\n \"51.140.211.160/28\",\r\n \ + \ \"51.140.212.64/29\",\r\n \"51.141.113.128/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestCentralUS\"\ + ,\r\n \"id\": \"AzureMonitor.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.71.195.192/27\"\ + ,\r\n \"13.71.196.56/29\",\r\n \"13.71.199.116/32\",\r\n\ + \ \"13.78.135.15/32\",\r\n \"13.78.145.11/32\",\r\n \ + \ \"13.78.151.158/32\",\r\n \"13.78.172.58/32\",\r\n \ + \ \"13.78.189.112/32\",\r\n \"13.78.236.149/32\",\r\n \ + \ \"13.78.237.51/32\",\r\n \"52.150.152.48/28\",\r\n \"\ + 52.161.8.76/32\",\r\n \"52.161.11.71/32\",\r\n \"52.161.12.245/32\"\ + ,\r\n \"2603:1030:b00::e8/128\",\r\n \"2603:1030:b00::164/128\"\ + ,\r\n \"2603:1030:b00::2a1/128\",\r\n \"2603:1030:b00::4db/128\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestEurope\"\ + ,\r\n \"id\": \"AzureMonitor.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.69.51.175/32\"\ + ,\r\n \"13.69.51.218/32\",\r\n \"13.69.65.16/28\",\r\n \ + \ \"13.69.66.136/29\",\r\n \"13.69.67.60/30\",\r\n \ + \ \"13.69.67.126/32\",\r\n \"13.69.106.88/29\",\r\n \"\ + 13.69.106.208/28\",\r\n \"13.80.134.255/32\",\r\n \"23.101.69.223/32\"\ + ,\r\n \"40.68.61.229/32\",\r\n \"40.68.154.39/32\",\r\n\ + \ \"40.74.24.68/31\",\r\n \"40.74.36.208/32\",\r\n \ + \ \"40.74.59.40/32\",\r\n \"40.113.176.128/28\",\r\n \ + \ \"40.114.241.141/32\",\r\n \"40.115.54.120/32\",\r\n \ + \ \"51.105.248.23/32\",\r\n \"51.144.41.38/32\",\r\n \"\ + 51.144.81.252/32\",\r\n \"52.178.26.73/32\",\r\n \"52.178.37.209/32\"\ + ,\r\n \"52.232.35.33/32\",\r\n \"52.232.65.133/32\",\r\n\ + \ \"52.232.106.242/32\",\r\n \"52.236.186.88/29\",\r\n \ + \ \"52.236.186.208/28\",\r\n \"104.40.222.36/32\",\r\n \ + \ \"137.117.144.33/32\",\r\n \"2603:1020:206:1::280/122\"\ + ,\r\n \"2a01:111:f100:9001::1761:91e4/128\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestIndia\",\r\n\ + \ \"id\": \"AzureMonitor.WestIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"20.38.128.64/29\"\ + ,\r\n \"104.211.147.128/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureMonitor.WestUS\",\r\n \"id\": \"AzureMonitor.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.86.218.224/28\",\r\n \"13.86.218.248/29\",\r\n \ + \ \"13.88.177.28/32\",\r\n \"13.91.42.27/32\",\r\n \ + \ \"13.91.102.27/32\",\r\n \"13.93.215.80/32\",\r\n \"\ + 13.93.233.49/32\",\r\n \"13.93.236.73/32\",\r\n \"20.49.120.64/28\"\ + ,\r\n \"40.78.23.86/32\",\r\n \"40.78.57.61/32\",\r\n \ + \ \"40.78.107.177/32\",\r\n \"40.118.129.58/32\",\r\n \ + \ \"65.52.122.208/32\",\r\n \"104.42.40.28/32\",\r\n \ + \ \"104.45.230.69/32\",\r\n \"104.45.232.72/32\",\r\n \ + \ \"2a01:111:f100:3000::a83e:187a/128\",\r\n \"2a01:111:f100:3000::a83e:187c/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:1913/128\",\r\n \"2a01:111:f100:3000::a83e:19c0/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:1a55/128\",\r\n \"2a01:111:f100:3000::a83e:1a8e/128\"\ + ,\r\n \"2a01:111:f100:3000::a83e:1adf/128\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureMonitor.WestUS2\",\r\n \ + \ \"id\": \"AzureMonitor.WestUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureMonitor\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.168/29\"\ + ,\r\n \"13.66.141.152/29\",\r\n \"13.66.143.218/32\",\r\n\ + \ \"13.66.160.124/32\",\r\n \"13.66.220.187/32\",\r\n \ + \ \"13.66.231.27/32\",\r\n \"13.77.150.166/32\",\r\n \ + \ \"13.77.155.39/32\",\r\n \"13.77.174.177/32\",\r\n \ + \ \"20.42.128.68/31\",\r\n \"20.190.60.32/32\",\r\n \"\ + 20.190.60.38/32\",\r\n \"40.64.132.128/28\",\r\n \"40.78.242.168/30\"\ + ,\r\n \"40.78.243.16/29\",\r\n \"40.78.250.104/30\",\r\n\ + \ \"40.78.250.208/29\",\r\n \"51.143.88.183/32\",\r\n \ + \ \"52.151.11.176/32\",\r\n \"52.175.198.74/32\",\r\n \ + \ \"52.175.231.105/32\",\r\n \"52.175.235.148/32\",\r\n \ + \ \"52.183.41.109/32\",\r\n \"52.183.66.112/32\",\r\n \ + \ \"52.183.73.112/32\",\r\n \"52.183.95.86/32\",\r\n \ + \ \"52.183.127.155/32\",\r\n \"52.191.170.253/32\",\r\n \ + \ \"52.229.25.130/32\",\r\n \"52.229.37.75/32\",\r\n \"\ + 52.247.202.90/32\",\r\n \"2603:1030:c02:2::4e1/128\",\r\n \ + \ \"2603:1030:c06:1::280/122\",\r\n \"2603:1030:d00::1d/128\",\r\ + \n \"2603:1030:d00::48/128\",\r\n \"2603:1030:d00::5a/128\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets\"\ + ,\r\n \"id\": \"AzureOpenDatasets\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.73.248.32/28\",\r\n \"20.36.120.192/28\",\r\n \"20.37.64.192/28\"\ + ,\r\n \"20.37.156.224/28\",\r\n \"20.37.195.32/28\",\r\n\ + \ \"20.37.224.192/28\",\r\n \"20.38.84.112/28\",\r\n \ + \ \"20.38.136.192/28\",\r\n \"20.39.11.32/28\",\r\n \ + \ \"20.41.4.192/28\",\r\n \"20.41.65.160/28\",\r\n \"\ + 20.41.193.128/28\",\r\n \"20.42.4.224/28\",\r\n \"20.42.131.0/28\"\ + ,\r\n \"20.42.227.0/28\",\r\n \"20.43.41.160/28\",\r\n \ + \ \"20.43.65.160/28\",\r\n \"20.43.130.112/28\",\r\n \ + \ \"20.45.112.192/28\",\r\n \"20.45.192.192/28\",\r\n \ + \ \"20.150.160.192/28\",\r\n \"20.189.106.208/28\",\r\n \ + \ \"20.192.225.128/28\",\r\n \"40.67.48.192/28\",\r\n \ + \ \"40.74.30.112/28\",\r\n \"40.80.57.128/28\",\r\n \"\ + 40.80.169.128/28\",\r\n \"40.80.188.32/28\",\r\n \"40.82.253.80/28\"\ + ,\r\n \"40.89.17.128/28\",\r\n \"51.12.41.32/28\",\r\n \ + \ \"51.12.193.32/28\",\r\n \"51.104.25.160/28\",\r\n \ + \ \"51.105.80.192/28\",\r\n \"51.105.88.192/28\",\r\n \ + \ \"51.107.48.192/28\",\r\n \"51.107.144.192/28\",\r\n \ + \ \"51.116.48.112/28\",\r\n \"51.116.144.112/28\",\r\n \ + \ \"51.120.40.192/28\",\r\n \"51.120.224.192/28\",\r\n \ + \ \"51.137.161.144/28\",\r\n \"51.143.192.192/28\",\r\n \ + \ \"52.136.48.192/28\",\r\n \"52.140.105.128/28\",\r\n \"\ + 52.150.139.80/28\",\r\n \"52.228.81.144/28\",\r\n \"102.133.56.112/28\"\ + ,\r\n \"102.133.216.112/28\",\r\n \"191.235.225.160/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.AustraliaCentral\"\ + ,\r\n \"id\": \"AzureOpenDatasets.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.224.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.AustraliaCentral2\",\r\n \"id\": \"AzureOpenDatasets.AustraliaCentral2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.36.120.192/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.AustraliaEast\"\ + ,\r\n \"id\": \"AzureOpenDatasets.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.195.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.AustraliaSoutheast\",\r\n \"id\": \"AzureOpenDatasets.AustraliaSoutheast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n\ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.42.227.0/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.BrazilSouth\"\ + ,\r\n \"id\": \"AzureOpenDatasets.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 191.235.225.160/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.CanadaCentral\",\r\n \"id\": \"AzureOpenDatasets.CanadaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.228.81.144/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CanadaEast\"\ + ,\r\n \"id\": \"AzureOpenDatasets.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.89.17.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.CentralIndia\",\r\n \"id\": \"AzureOpenDatasets.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.140.105.128/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.CentralUS\"\ + ,\r\n \"id\": \"AzureOpenDatasets.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.156.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.CentralUSEUAP\",\r\n \"id\": \"AzureOpenDatasets.CentralUSEUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.45.192.192/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.EastAsia\"\ + ,\r\n \"id\": \"AzureOpenDatasets.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.189.106.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.EastUS\",\r\n \"id\": \"AzureOpenDatasets.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\ + \n \"20.42.4.224/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureOpenDatasets.EastUS2\",\r\n \"id\": \"AzureOpenDatasets.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\ + \n \"20.41.4.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureOpenDatasets.EastUS2EUAP\",\r\n \"id\": \"AzureOpenDatasets.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.39.11.32/28\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.FranceCentral\"\ + ,\r\n \"id\": \"AzureOpenDatasets.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.43.41.160/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.FranceSouth\",\r\n \"id\": \"AzureOpenDatasets.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.105.88.192/28\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.GermanyNorth\"\ + ,\r\n \"id\": \"AzureOpenDatasets.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.116.48.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.GermanyWestCentral\",\r\n \"id\": \"AzureOpenDatasets.GermanyWestCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.144.112/28\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureOpenDatasets.JapanEast\",\r\n \"id\"\ + : \"AzureOpenDatasets.JapanEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.65.160/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.JapanWest\"\ + ,\r\n \"id\": \"AzureOpenDatasets.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.57.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.KoreaCentral\",\r\n \"id\": \"AzureOpenDatasets.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.41.65.160/28\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.KoreaSouth\"\ + ,\r\n \"id\": \"AzureOpenDatasets.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.169.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.NorthCentralUS\",\r\n \"id\": \"AzureOpenDatasets.NorthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.80.188.32/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.NorthEurope\"\ + ,\r\n \"id\": \"AzureOpenDatasets.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.38.84.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.NorwayEast\",\r\n \"id\": \"AzureOpenDatasets.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\ + \n \"51.120.40.192/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureOpenDatasets.NorwayWest\",\r\n \"id\":\ + \ \"AzureOpenDatasets.NorwayWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.224.192/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SouthAfricaNorth\"\ + ,\r\n \"id\": \"AzureOpenDatasets.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 102.133.216.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.SouthAfricaWest\",\r\n \"id\": \"AzureOpenDatasets.SouthAfricaWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.133.56.112/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SouthCentralUS\"\ + ,\r\n \"id\": \"AzureOpenDatasets.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.73.248.32/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.SoutheastAsia\",\r\n \"id\": \"AzureOpenDatasets.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.43.130.112/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SouthIndia\"\ + ,\r\n \"id\": \"AzureOpenDatasets.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.41.193.128/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.SwitzerlandNorth\",\r\n \"id\": \"AzureOpenDatasets.SwitzerlandNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.107.48.192/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzureOpenDatasets.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.144.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.UAECentral\",\r\n \"id\": \"AzureOpenDatasets.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.64.192/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureOpenDatasets.UAENorth\",\r\n \"id\"\ + : \"AzureOpenDatasets.UAENorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.38.136.192/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UKNorth\"\ + ,\r\n \"id\": \"AzureOpenDatasets.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.105.80.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.UKSouth\",\r\n \"id\": \"AzureOpenDatasets.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\ + \n \"51.104.25.160/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureOpenDatasets.UKSouth2\",\r\n \"id\": \"\ + AzureOpenDatasets.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\ + \n \"addressPrefixes\": [\r\n \"51.143.192.192/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.UKWest\"\ + ,\r\n \"id\": \"AzureOpenDatasets.UKWest\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.137.161.144/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"AzureOpenDatasets.WestCentralUS\",\r\n \"id\": \"AzureOpenDatasets.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.150.139.80/28\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.WestEurope\"\ + ,\r\n \"id\": \"AzureOpenDatasets.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.74.30.112/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzureOpenDatasets.WestIndia\",\r\n \"id\": \"AzureOpenDatasets.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.136.48.192/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzureOpenDatasets.WestUS\",\r\n \"id\": \"\ + AzureOpenDatasets.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureOpenDatasets\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.82.253.80/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureOpenDatasets.WestUS2\"\ + ,\r\n \"id\": \"AzureOpenDatasets.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureOpenDatasets\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.42.131.0/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"AzurePortal.AustraliaCentral\",\r\n \"id\": \"AzurePortal.AustraliaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"AzurePortal\",\r\n \"\ + addressPrefixes\": [\r\n \"20.37.225.128/27\",\r\n \"20.37.226.56/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.AustraliaCentral2\"\ + ,\r\n \"id\": \"AzurePortal.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.36.121.128/27\"\ + ,\r\n \"20.36.122.56/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzurePortal.AustraliaEast\",\r\n \"id\": \"\ + AzurePortal.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.37.195.224/27\",\r\n \ + \ \"20.37.196.252/30\",\r\n \"20.37.198.64/27\",\r\n \ + \ \"2603:1010:6::100/121\",\r\n \"2603:1010:6:1::680/121\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.AustraliaSoutheast\"\ + ,\r\n \"id\": \"AzurePortal.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.77.1.236/32\"\ + ,\r\n \"13.77.55.208/28\",\r\n \"20.42.227.192/27\",\r\n\ + \ \"20.42.228.220/30\",\r\n \"20.42.228.224/27\",\r\n \ + \ \"20.42.230.80/28\",\r\n \"52.243.76.246/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.BrazilSouth\"\ + ,\r\n \"id\": \"AzurePortal.BrazilSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"191.234.136.0/27\"\ + ,\r\n \"191.234.136.48/30\",\r\n \"191.235.227.160/27\"\ + ,\r\n \"2603:1050:6::100/121\",\r\n \"2603:1050:6:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.CanadaCentral\"\ + ,\r\n \"id\": \"AzurePortal.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.38.149.208/28\"\ + ,\r\n \"52.228.83.160/27\",\r\n \"52.228.84.84/30\",\r\n\ + \ \"52.228.84.96/28\",\r\n \"2603:1030:f05::100/121\",\r\ + \n \"2603:1030:f05:1::680/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzurePortal.CanadaEast\",\r\n \"id\": \"\ + AzurePortal.CanadaEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"canadaeast\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.89.18.160/27\",\r\n \ + \ \"40.89.20.132/30\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzurePortal.CentralIndia\",\r\n \"id\": \"AzurePortal.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.80.53.16/28\",\r\n \"52.140.105.224/27\",\r\ + \n \"52.140.107.112/28\",\r\n \"52.140.108.64/30\",\r\n\ + \ \"52.172.190.71/32\",\r\n \"52.172.191.4/32\",\r\n \ + \ \"104.211.89.213/32\",\r\n \"104.211.101.116/32\",\r\n \ + \ \"2603:1040:a06::200/121\",\r\n \"2603:1040:a06:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.CentralUS\"\ + ,\r\n \"id\": \"AzurePortal.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.40.200.0/27\"\ + ,\r\n \"20.40.200.160/30\",\r\n \"2603:1030:10::100/121\"\ + ,\r\n \"2603:1030:10:1::680/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzurePortal.CentralUSEUAP\",\r\n \"\ + id\": \"AzurePortal.CentralUSEUAP\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.45.195.160/27\"\ + ,\r\n \"20.45.197.192/27\",\r\n \"20.45.197.228/30\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastAsia\"\ + ,\r\n \"id\": \"AzurePortal.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.88.220.109/32\"\ + ,\r\n \"13.88.222.0/32\",\r\n \"20.189.108.96/27\",\r\n\ + \ \"20.189.109.88/30\",\r\n \"20.189.109.160/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastUS\"\ + ,\r\n \"id\": \"AzurePortal.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.68.130.251/32\"\ + ,\r\n \"13.68.235.98/32\",\r\n \"13.90.156.71/32\",\r\n\ + \ \"13.92.138.76/32\",\r\n \"20.42.6.192/27\",\r\n \ + \ \"20.49.109.36/30\",\r\n \"20.49.109.44/31\",\r\n \ + \ \"20.49.109.48/28\",\r\n \"40.71.15.144/28\",\r\n \"40.114.78.132/32\"\ + ,\r\n \"40.117.86.243/32\",\r\n \"40.117.237.78/32\",\r\n\ + \ \"2603:1030:210::100/121\",\r\n \"2603:1030:210:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.EastUS2\"\ + ,\r\n \"id\": \"AzurePortal.EastUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.41.5.192/27\"\ + ,\r\n \"20.44.19.32/28\",\r\n \"20.49.99.16/28\",\r\n \ + \ \"20.49.99.32/30\",\r\n \"2603:1030:40c::100/121\",\r\n\ + \ \"2603:1030:40c:1::680/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzurePortal.EastUS2EUAP\",\r\n \"id\": \"\ + AzurePortal.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.39.12.32/27\",\r\n \ + \ \"20.39.12.232/30\",\r\n \"2603:1030:40b:1::680/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.FranceCentral\"\ + ,\r\n \"id\": \"AzurePortal.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.43.42.64/27\"\ + ,\r\n \"20.43.43.164/30\",\r\n \"2603:1020:805::100/121\"\ + ,\r\n \"2603:1020:805:1::680/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzurePortal.FranceSouth\",\r\n \"\ + id\": \"AzurePortal.FranceSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.105.89.160/27\",\r\n\ + \ \"51.105.90.152/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzurePortal.GermanyNorth\",\r\n \"id\": \"AzurePortal.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.48.192/27\",\r\n \"51.116.49.140/30\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.JapanEast\"\ + ,\r\n \"id\": \"AzurePortal.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.78.49.187/32\"\ + ,\r\n \"20.43.66.64/27\",\r\n \"20.43.67.92/30\",\r\n \ + \ \"20.43.67.96/27\",\r\n \"20.43.70.64/28\",\r\n \ + \ \"23.102.65.134/32\",\r\n \"40.79.189.96/28\",\r\n \"\ + 2603:1040:407::100/121\",\r\n \"2603:1040:407:1::680/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.JapanWest\"\ + ,\r\n \"id\": \"AzurePortal.JapanWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"40.80.58.128/27\"\ + ,\r\n \"40.80.59.28/30\",\r\n \"40.80.59.32/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.KoreaCentral\"\ + ,\r\n \"id\": \"AzurePortal.KoreaCentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.41.65.224/27\"\ + ,\r\n \"20.41.67.88/30\",\r\n \"2603:1040:f05::100/121\"\ + ,\r\n \"2603:1040:f05:1::680/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzurePortal.KoreaSouth\",\r\n \"\ + id\": \"AzurePortal.KoreaSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.169.224/27\",\r\n\ + \ \"40.80.172.16/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzurePortal.NorthCentralUS\",\r\n \"id\": \"AzurePortal.NorthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.80.190.160/27\",\r\n \"40.80.191.200/30\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorthEurope\"\ + ,\r\n \"id\": \"AzurePortal.NorthEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"20.38.85.192/27\"\ + ,\r\n \"20.38.87.224/27\",\r\n \"20.50.65.72/30\",\r\n \ + \ \"104.41.216.228/32\",\r\n \"137.116.247.179/32\",\r\n\ + \ \"2603:1020:5::100/121\",\r\n \"2603:1020:5:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.NorwayEast\"\ + ,\r\n \"id\": \"AzurePortal.NorwayEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.120.41.160/27\"\ + ,\r\n \"51.120.42.60/30\",\r\n \"2603:1020:e04::100/121\"\ + ,\r\n \"2603:1020:e04:1::680/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzurePortal.NorwayWest\",\r\n \"\ + id\": \"AzurePortal.NorwayWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.225.128/27\",\r\n\ + \ \"51.120.226.56/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzurePortal.SouthAfricaWest\",\r\n \"id\": \"AzurePortal.SouthAfricaWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.56.160/27\",\r\n \"102.133.58.192/30\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.SouthCentralUS\"\ + ,\r\n \"id\": \"AzurePortal.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.73.249.32/27\"\ + ,\r\n \"13.73.249.160/28\",\r\n \"20.45.125.240/28\",\r\n\ + \ \"40.84.132.239/32\",\r\n \"40.84.228.255/32\",\r\n \ + \ \"40.119.9.236/30\",\r\n \"104.214.117.155/32\",\r\n \ + \ \"104.215.120.160/32\",\r\n \"2603:1030:807::100/121\",\r\ + \n \"2603:1030:807:1::680/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzurePortal.SoutheastAsia\",\r\n \"id\"\ + : \"AzurePortal.SoutheastAsia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.35.35/32\",\r\n \ + \ \"13.67.35.77/32\",\r\n \"20.43.132.32/27\",\r\n \ + \ \"23.98.104.80/28\",\r\n \"23.98.104.96/27\",\r\n \"\ + 23.98.104.128/30\",\r\n \"40.78.239.48/28\",\r\n \"52.163.207.80/32\"\ + ,\r\n \"104.215.146.128/32\",\r\n \"2603:1040:5::200/121\"\ + ,\r\n \"2603:1040:5:1::680/121\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzurePortal.SouthIndia\",\r\n \"id\": \"\ + AzurePortal.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.41.193.224/27\",\r\n \ + \ \"20.41.197.16/30\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzurePortal.SwitzerlandNorth\",\r\n \"id\": \"AzurePortal.SwitzerlandNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandn\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.49.160/27\",\r\n \"51.107.50.60/30\",\r\ + \n \"2603:1020:a04::100/121\",\r\n \"2603:1020:a04:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.SwitzerlandWest\"\ + ,\r\n \"id\": \"AzurePortal.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.107.145.128/27\"\ + ,\r\n \"51.107.146.56/30\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzurePortal.UAECentral\",\r\n \"id\": \"\ + AzurePortal.UAECentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uaecentral\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.37.65.128/27\",\r\n \ + \ \"20.37.66.56/30\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzurePortal.UAENorth\",\r\n \"id\": \"AzurePortal.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzurePortal\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.137.160/27\",\r\n \"20.38.138.60/30\",\r\ + \n \"2603:1040:904::100/121\",\r\n \"2603:1040:904:1::680/121\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.UKNorth\"\ + ,\r\n \"id\": \"AzurePortal.UKNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"51.105.80.124/30\"\ + ,\r\n \"51.105.81.128/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"AzurePortal.UKSouth\",\r\n \"id\": \"AzurePortal.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.104.27.96/27\",\r\n \"51.104.28.220/30\",\r\n \ + \ \"51.104.28.224/28\",\r\n \"51.140.69.25/32\",\r\n \ + \ \"51.140.138.84/32\",\r\n \"51.140.149.64/28\",\r\n \"\ + 51.145.3.27/32\",\r\n \"51.145.21.195/32\",\r\n \"2603:1020:705::100/121\"\ + ,\r\n \"2603:1020:705:1::680/121\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"AzurePortal.UKSouth2\",\r\n \"id\"\ + : \"AzurePortal.UKSouth2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uksouth2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzurePortal\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.143.192.124/30\",\r\n \ + \ \"51.143.193.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzurePortal.UKWest\",\r\n \"id\": \"AzurePortal.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.137.162.160/27\",\r\n \"51.137.164.80/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestCentralUS\"\ + ,\r\n \"id\": \"AzurePortal.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.77.202.2/32\"\ + ,\r\n \"13.78.132.155/32\",\r\n \"13.78.230.142/32\",\r\n\ + \ \"40.67.121.128/28\",\r\n \"52.150.139.224/27\",\r\n \ + \ \"52.150.140.216/30\",\r\n \"52.150.152.16/28\",\r\n \ + \ \"52.150.152.224/27\",\r\n \"52.161.101.86/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestEurope\"\ + ,\r\n \"id\": \"AzurePortal.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"13.69.112.176/28\"\ + ,\r\n \"13.69.126.92/32\",\r\n \"20.50.1.32/27\",\r\n \ + \ \"20.50.1.160/27\",\r\n \"20.50.1.200/30\",\r\n \ + \ \"20.50.1.208/28\",\r\n \"40.113.117.57/32\",\r\n \"\ + 40.114.236.251/32\",\r\n \"213.199.128.226/32\",\r\n \"\ + 2603:1020:206::100/121\",\r\n \"2603:1020:206:1::680/121\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzurePortal.WestIndia\"\ + ,\r\n \"id\": \"AzurePortal.WestIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \"52.136.49.160/27\"\ + ,\r\n \"52.136.51.72/30\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzurePortal.WestUS2\",\r\n \"id\": \"AzurePortal.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzurePortal\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.64.128.128/27\",\r\n \"40.64.132.88/30\",\r\n \ + \ \"40.64.132.96/28\",\r\n \"40.65.114.234/32\",\r\n \ + \ \"40.78.245.208/28\",\r\n \"52.233.66.46/32\",\r\n \"\ + 2603:1030:c06:1::680/121\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureResourceManager\",\r\n \"id\": \"AzureResourceManager\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.141.176/28\",\r\n \"13.67.18.0/23\",\r\n\ + \ \"13.69.67.32/28\",\r\n \"13.69.114.0/23\",\r\n \ + \ \"13.69.229.224/28\",\r\n \"13.69.234.0/23\",\r\n \"\ + 13.70.74.64/28\",\r\n \"13.70.76.0/23\",\r\n \"13.71.173.192/28\"\ + ,\r\n \"13.71.196.80/28\",\r\n \"13.71.198.0/24\",\r\n \ + \ \"13.73.240.224/28\",\r\n \"13.73.246.0/23\",\r\n \ + \ \"13.75.39.16/28\",\r\n \"13.77.53.32/28\",\r\n \"\ + 13.77.55.0/25\",\r\n \"13.78.109.96/28\",\r\n \"13.86.219.80/28\"\ + ,\r\n \"13.86.222.0/24\",\r\n \"13.87.57.240/28\",\r\n \ + \ \"13.87.60.0/23\",\r\n \"13.87.123.240/28\",\r\n \ + \ \"13.87.126.0/24\",\r\n \"13.89.180.0/23\",\r\n \"\ + 20.36.108.48/28\",\r\n \"20.36.110.0/23\",\r\n \"20.36.115.144/28\"\ + ,\r\n \"20.36.118.0/23\",\r\n \"20.37.76.48/28\",\r\n \ + \ \"20.37.78.0/23\",\r\n \"20.38.128.32/28\",\r\n \ + \ \"20.38.130.0/23\",\r\n \"20.38.150.0/23\",\r\n \"20.43.120.224/28\"\ + ,\r\n \"20.43.124.0/23\",\r\n \"20.44.3.240/28\",\r\n \ + \ \"20.44.6.0/23\",\r\n \"20.44.8.16/28\",\r\n \"\ + 20.44.16.112/28\",\r\n \"20.44.20.0/23\",\r\n \"20.44.30.0/24\"\ + ,\r\n \"20.150.172.32/28\",\r\n \"20.150.174.0/23\",\r\n\ + \ \"20.189.168.0/24\",\r\n \"20.192.236.0/23\",\r\n \ + \ \"20.193.204.0/23\",\r\n \"40.67.59.208/28\",\r\n \ + \ \"40.67.62.0/23\",\r\n \"40.67.120.0/24\",\r\n \"40.69.108.32/28\"\ + ,\r\n \"40.69.112.0/22\",\r\n \"40.71.13.224/28\",\r\n \ + \ \"40.74.102.0/28\",\r\n \"40.75.35.32/28\",\r\n \ + \ \"40.75.38.0/23\",\r\n \"40.78.196.32/28\",\r\n \"40.78.198.0/23\"\ + ,\r\n \"40.78.203.224/28\",\r\n \"40.78.206.0/23\",\r\n\ + \ \"40.78.234.176/28\",\r\n \"40.78.254.0/23\",\r\n \ + \ \"40.79.131.240/28\",\r\n \"40.79.134.0/23\",\r\n \ + \ \"40.79.158.0/23\",\r\n \"40.79.180.0/28\",\r\n \"40.79.182.0/23\"\ + ,\r\n \"40.79.198.0/23\",\r\n \"40.80.178.0/23\",\r\n \ + \ \"51.11.64.0/24\",\r\n \"51.11.96.0/24\",\r\n \"\ + 51.12.102.0/23\",\r\n \"51.12.206.0/23\",\r\n \"51.104.8.224/28\"\ + ,\r\n \"51.105.78.0/23\",\r\n \"51.107.60.32/28\",\r\n \ + \ \"51.107.62.0/23\",\r\n \"51.107.156.32/28\",\r\n \ + \ \"51.107.158.0/23\",\r\n \"51.116.60.32/28\",\r\n \ + \ \"51.116.62.0/23\",\r\n \"51.116.156.32/28\",\r\n \"51.116.159.0/24\"\ + ,\r\n \"51.120.100.32/28\",\r\n \"51.120.102.0/23\",\r\n\ + \ \"51.120.220.32/28\",\r\n \"51.120.222.0/23\",\r\n \ + \ \"51.140.212.16/28\",\r\n \"51.140.214.0/24\",\r\n \ + \ \"52.138.94.0/23\",\r\n \"52.147.96.0/24\",\r\n \"\ + 52.162.110.224/28\",\r\n \"52.231.19.208/28\",\r\n \"52.231.22.0/24\"\ + ,\r\n \"52.231.148.64/28\",\r\n \"52.231.150.0/24\",\r\n\ + \ \"52.240.242.0/23\",\r\n \"65.52.252.48/28\",\r\n \ + \ \"65.52.254.0/23\",\r\n \"102.133.28.16/28\",\r\n \ + \ \"102.133.30.0/23\",\r\n \"102.133.123.224/28\",\r\n \ + \ \"102.133.158.0/23\",\r\n \"104.46.160.0/24\",\r\n \"\ + 104.46.161.0/25\",\r\n \"104.214.162.0/23\",\r\n \"168.61.138.0/23\"\ + ,\r\n \"191.233.52.0/23\",\r\n \"191.233.205.16/28\",\r\n\ + \ \"191.234.158.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.AustraliaCentral\",\r\n \"id\"\ + : \"AzureResourceManager.AustraliaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.108.48/28\",\r\n\ + \ \"20.36.110.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.AustraliaCentral2\",\r\n \"\ + id\": \"AzureResourceManager.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.115.144/28\",\r\n\ + \ \"20.36.118.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.AustraliaSoutheast\",\r\n \"\ + id\": \"AzureResourceManager.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.53.32/28\",\r\n \ + \ \"13.77.55.0/25\",\r\n \"104.46.160.0/24\",\r\n \ + \ \"104.46.161.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureResourceManager.BrazilSouth\",\r\n \"id\": \"AzureResourceManager.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"191.233.205.16/28\",\r\n \"191.234.158.0/23\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CanadaCentral\"\ + ,\r\n \"id\": \"AzureResourceManager.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.173.192/28\",\r\n\ + \ \"20.38.150.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.CanadaEast\",\r\n \"id\": \"\ + AzureResourceManager.CanadaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.69.108.32/28\",\r\n \ + \ \"40.69.112.0/22\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureResourceManager.CentralIndia\",\r\n \"id\": \"AzureResourceManager.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureResourceManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.43.120.224/28\",\r\n \"20.43.124.0/23\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.CentralUS\"\ + ,\r\n \"id\": \"AzureResourceManager.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.89.180.0/23\",\r\n \ + \ \"20.44.8.16/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureResourceManager.CentralUSEUAP\",\r\n \"id\":\ + \ \"AzureResourceManager.CentralUSEUAP\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.203.224/28\",\r\n\ + \ \"40.78.206.0/23\",\r\n \"168.61.138.0/23\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.EastAsia\"\ + ,\r\n \"id\": \"AzureResourceManager.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.75.39.16/28\",\r\n \ + \ \"104.214.162.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.EastUS\",\r\n \"id\": \"AzureResourceManager.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.71.13.224/28\",\r\n\ + \ \"40.79.158.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.EastUS2\",\r\n \"id\": \"AzureResourceManager.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.44.16.112/28\",\r\n\ + \ \"20.44.20.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureResourceManager.EastUS2EUAP\",\r\n \"id\": \"\ + AzureResourceManager.EastUS2EUAP\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.75.35.32/28\",\r\n \ + \ \"40.75.38.0/23\",\r\n \"52.138.94.0/23\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.FranceCentral\"\ + ,\r\n \"id\": \"AzureResourceManager.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.131.240/28\",\r\n\ + \ \"40.79.134.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.GermanyNorth\",\r\n \"id\":\ + \ \"AzureResourceManager.GermanyNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.60.32/28\",\r\n\ + \ \"51.116.62.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.GermanyWestCentral\",\r\n \"\ + id\": \"AzureResourceManager.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.156.32/28\",\r\n\ + \ \"51.116.159.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.JapanEast\",\r\n \"id\": \"\ + AzureResourceManager.JapanEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.78.109.96/28\",\r\n \ + \ \"40.79.198.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureResourceManager.JapanWest\",\r\n \"id\": \"AzureResourceManager.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureResourceManager\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.102.0/28\",\r\n \"40.80.178.0/23\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.KoreaCentral\"\ + ,\r\n \"id\": \"AzureResourceManager.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.44.30.0/24\",\r\n \ + \ \"52.231.19.208/28\",\r\n \"52.231.22.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.KoreaSouth\"\ + ,\r\n \"id\": \"AzureResourceManager.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"52.147.96.0/24\",\r\n \ + \ \"52.231.148.64/28\",\r\n \"52.231.150.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.NorthCentralUS\"\ + ,\r\n \"id\": \"AzureResourceManager.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"52.162.110.224/28\",\r\n\ + \ \"52.240.242.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.NorthEurope\",\r\n \"id\": \"\ + AzureResourceManager.NorthEurope\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.229.224/28\",\r\n\ + \ \"13.69.234.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.SouthAfricaNorth\",\r\n \"id\"\ + : \"AzureResourceManager.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.123.224/28\",\r\ + \n \"102.133.158.0/23\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"AzureResourceManager.SouthAfricaWest\",\r\n \ + \ \"id\": \"AzureResourceManager.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.28.16/28\",\r\n\ + \ \"102.133.30.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.SouthCentralUS\",\r\n \"id\"\ + : \"AzureResourceManager.SouthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.240.224/28\",\r\n\ + \ \"13.73.246.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.SoutheastAsia\",\r\n \"id\"\ + : \"AzureResourceManager.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.18.0/23\",\r\n \ + \ \"40.78.234.176/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.SouthIndia\",\r\n \"id\": \"\ + AzureResourceManager.SouthIndia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.78.196.32/28\",\r\n \ + \ \"40.78.198.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureResourceManager.SwitzerlandNorth\",\r\n \"id\":\ + \ \"AzureResourceManager.SwitzerlandNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.60.32/28\",\r\n\ + \ \"51.107.62.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.SwitzerlandWest\",\r\n \"id\"\ + : \"AzureResourceManager.SwitzerlandWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.156.32/28\",\r\n\ + \ \"51.107.158.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureResourceManager.UAECentral\",\r\n \"id\": \"\ + AzureResourceManager.UAECentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\r\n\ + \ ],\r\n \"systemService\": \"AzureResourceManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.37.76.48/28\",\r\n \ + \ \"20.37.78.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"AzureResourceManager.UKNorth\",\r\n \"id\": \"AzureResourceManager.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.123.240/28\",\r\n\ + \ \"13.87.126.0/24\",\r\n \"51.11.64.0/24\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.UKSouth2\"\ + ,\r\n \"id\": \"AzureResourceManager.UKSouth2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.57.240/28\",\r\n\ + \ \"13.87.60.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureResourceManager.UKWest\",\r\n \"id\": \"AzureResourceManager.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.11.96.0/24\",\r\n \ + \ \"51.140.212.16/28\",\r\n \"51.140.214.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestCentralUS\"\ + ,\r\n \"id\": \"AzureResourceManager.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.196.80/28\",\r\n\ + \ \"13.71.198.0/24\",\r\n \"40.67.120.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestEurope\"\ + ,\r\n \"id\": \"AzureResourceManager.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.67.32/28\",\r\n \ + \ \"13.69.114.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureResourceManager.WestIndia\",\r\n \"id\": \"AzureResourceManager.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureResourceManager\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.128.32/28\",\r\n \"20.38.130.0/23\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestUS\"\ + ,\r\n \"id\": \"AzureResourceManager.WestUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.86.219.80/28\",\r\n\ + \ \"13.86.222.0/24\",\r\n \"20.189.168.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureResourceManager.WestUS2\"\ + ,\r\n \"id\": \"AzureResourceManager.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureResourceManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.141.176/28\",\r\n\ + \ \"40.78.254.0/23\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureSignalR\",\r\n \"id\": \"AzureSignalR\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.145.0/26\",\r\n \"13.69.113.0/24\",\r\n \ + \ \"13.69.232.128/25\",\r\n \"13.70.74.224/27\",\r\n \"\ + 13.71.199.32/27\",\r\n \"13.73.244.64/27\",\r\n \"13.74.111.0/25\"\ + ,\r\n \"13.78.109.224/27\",\r\n \"13.89.175.128/26\",\r\n\ + \ \"20.42.64.128/25\",\r\n \"20.42.72.0/25\",\r\n \ + \ \"20.44.10.128/26\",\r\n \"20.44.17.128/26\",\r\n \"\ + 20.45.123.192/27\",\r\n \"20.189.170.0/24\",\r\n \"40.69.108.192/26\"\ + ,\r\n \"40.69.110.128/27\",\r\n \"40.70.148.192/26\",\r\n\ + \ \"40.71.15.0/25\",\r\n \"40.78.204.96/27\",\r\n \ + \ \"40.78.238.64/26\",\r\n \"40.78.238.128/25\",\r\n \ + \ \"40.78.245.64/26\",\r\n \"40.78.253.0/26\",\r\n \"40.79.132.160/27\"\ + ,\r\n \"40.79.139.96/27\",\r\n \"40.79.148.32/27\",\r\n\ + \ \"40.79.163.96/27\",\r\n \"40.79.171.192/27\",\r\n \ + \ \"40.79.189.0/27\",\r\n \"40.79.197.0/27\",\r\n \ + \ \"51.104.9.64/27\",\r\n \"51.105.69.32/27\",\r\n \"51.105.77.0/27\"\ + ,\r\n \"52.138.229.128/25\",\r\n \"52.167.109.0/26\",\r\n\ + \ \"52.178.16.0/24\",\r\n \"52.182.141.64/26\",\r\n \ + \ \"52.231.20.96/27\",\r\n \"52.231.20.192/26\",\r\n \ + \ \"52.236.190.0/24\",\r\n \"191.233.207.128/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.AustraliaEast\"\ + ,\r\n \"id\": \"AzureSignalR.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"13.70.74.224/27\"\ + ,\r\n \"40.79.163.96/27\",\r\n \"40.79.171.192/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.BrazilSouth\"\ + ,\r\n \"id\": \"AzureSignalR.BrazilSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"191.233.207.128/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.CanadaEast\"\ + ,\r\n \"id\": \"AzureSignalR.CanadaEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\ + \n \"addressPrefixes\": [\r\n \"40.69.108.192/26\",\r\n \ + \ \"40.69.110.128/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureSignalR.CentralUS\",\r\n \"id\": \"AzureSignalR.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \"13.89.175.128/26\"\ + ,\r\n \"20.44.10.128/26\",\r\n \"52.182.141.64/26\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.CentralUSEUAP\"\ + ,\r\n \"id\": \"AzureSignalR.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.204.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.EastUS\"\ + ,\r\n \"id\": \"AzureSignalR.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.42.64.128/25\",\r\n \ + \ \"20.42.72.0/25\",\r\n \"40.71.15.0/25\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.EastUS2\",\r\ + \n \"id\": \"AzureSignalR.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.44.17.128/26\",\r\n \ + \ \"40.70.148.192/26\",\r\n \"52.167.109.0/26\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.FranceCentral\"\ + ,\r\n \"id\": \"AzureSignalR.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.132.160/27\",\r\n\ + \ \"40.79.139.96/27\",\r\n \"40.79.148.32/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.JapanEast\"\ + ,\r\n \"id\": \"AzureSignalR.JapanEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\ + \n \"addressPrefixes\": [\r\n \"13.78.109.224/27\",\r\n \ + \ \"40.79.189.0/27\",\r\n \"40.79.197.0/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.KoreaCentral\"\ + ,\r\n \"id\": \"AzureSignalR.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"52.231.20.96/27\",\r\n\ + \ \"52.231.20.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureSignalR.NorthEurope\",\r\n \"id\": \"AzureSignalR.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.232.128/25\",\r\n \"13.74.111.0/25\",\r\n \ + \ \"52.138.229.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"AzureSignalR.SouthCentralUS\",\r\n \"id\": \"AzureSignalR.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \ + \ \"systemService\": \"AzureSignalR\",\r\n \"addressPrefixes\": [\r\ + \n \"13.73.244.64/27\",\r\n \"20.45.123.192/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.SoutheastAsia\"\ + ,\r\n \"id\": \"AzureSignalR.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.238.64/26\",\r\n\ + \ \"40.78.238.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"AzureSignalR.UKSouth\",\r\n \"id\": \"AzureSignalR.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.104.9.64/27\",\r\n \ + \ \"51.105.69.32/27\",\r\n \"51.105.77.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestCentralUS\"\ + ,\r\n \"id\": \"AzureSignalR.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.199.32/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestEurope\"\ + ,\r\n \"id\": \"AzureSignalR.WestEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\ + \n \"addressPrefixes\": [\r\n \"13.69.113.0/24\",\r\n \ + \ \"52.178.16.0/24\",\r\n \"52.236.190.0/24\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestUS\",\r\ + \n \"id\": \"AzureSignalR.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.189.170.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"AzureSignalR.WestUS2\"\ + ,\r\n \"id\": \"AzureSignalR.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSignalR\",\r\ + \n \"addressPrefixes\": [\r\n \"13.66.145.0/26\",\r\n \ + \ \"40.78.245.64/26\",\r\n \"40.78.253.0/26\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"AzureSiteRecovery\",\r\n\ + \ \"id\": \"AzureSiteRecovery\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSiteRecovery\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.141.240/28\",\r\n\ + \ \"13.67.10.96/28\",\r\n \"13.69.67.80/28\",\r\n \ + \ \"13.69.107.80/28\",\r\n \"13.69.230.16/28\",\r\n \"\ + 13.70.74.96/28\",\r\n \"13.70.159.158/32\",\r\n \"13.71.173.224/28\"\ + ,\r\n \"13.71.196.144/28\",\r\n \"13.73.242.192/28\",\r\n\ + \ \"13.74.108.144/28\",\r\n \"13.75.39.80/28\",\r\n \ + \ \"13.77.53.64/28\",\r\n \"13.78.109.128/28\",\r\n \ + \ \"13.82.88.226/32\",\r\n \"13.84.148.14/32\",\r\n \"\ + 13.86.219.176/28\",\r\n \"13.87.37.4/32\",\r\n \"13.87.58.48/28\"\ + ,\r\n \"13.87.124.48/28\",\r\n \"13.89.174.144/28\",\r\n\ + \ \"20.36.34.70/32\",\r\n \"20.36.69.62/32\",\r\n \ + \ \"20.36.108.96/28\",\r\n \"20.36.115.224/28\",\r\n \ + \ \"20.36.120.80/28\",\r\n \"20.37.64.80/28\",\r\n \"20.37.76.128/28\"\ + ,\r\n \"20.37.156.96/28\",\r\n \"20.37.192.112/28\",\r\n\ + \ \"20.37.224.80/28\",\r\n \"20.38.80.112/28\",\r\n \ + \ \"20.38.128.80/28\",\r\n \"20.38.136.80/28\",\r\n \ + \ \"20.38.147.160/28\",\r\n \"20.39.8.80/28\",\r\n \"20.41.4.64/28\"\ + ,\r\n \"20.41.64.96/28\",\r\n \"20.41.192.80/28\",\r\n \ + \ \"20.42.4.96/28\",\r\n \"20.42.129.128/28\",\r\n \ + \ \"20.42.224.80/28\",\r\n \"20.43.40.112/28\",\r\n \"\ + 20.43.64.112/28\",\r\n \"20.43.121.16/28\",\r\n \"20.43.130.64/28\"\ + ,\r\n \"20.44.4.80/28\",\r\n \"20.44.8.176/28\",\r\n \ + \ \"20.44.17.32/28\",\r\n \"20.44.27.192/28\",\r\n \ + \ \"20.45.75.232/32\",\r\n \"20.45.112.80/28\",\r\n \"\ + 20.45.123.96/28\",\r\n \"20.45.192.80/28\",\r\n \"20.49.83.48/28\"\ + ,\r\n \"20.49.91.48/28\",\r\n \"20.150.160.80/28\",\r\n\ + \ \"20.150.172.48/28\",\r\n \"20.150.179.208/28\",\r\n \ + \ \"20.150.187.208/28\",\r\n \"20.189.106.96/28\",\r\n \ + \ \"20.192.99.208/28\",\r\n \"20.192.160.0/28\",\r\n \ + \ \"20.192.225.0/28\",\r\n \"20.192.235.224/28\",\r\n \ + \ \"20.193.203.208/28\",\r\n \"20.194.67.48/28\",\r\n \ + \ \"23.96.195.247/32\",\r\n \"23.98.83.80/28\",\r\n \"40.67.48.80/28\"\ + ,\r\n \"40.67.60.80/28\",\r\n \"40.69.108.64/28\",\r\n \ + \ \"40.69.144.231/32\",\r\n \"40.69.212.238/32\",\r\n \ + \ \"40.70.148.96/28\",\r\n \"40.71.14.0/28\",\r\n \ + \ \"40.74.24.112/28\",\r\n \"40.74.147.176/28\",\r\n \"\ + 40.75.35.80/28\",\r\n \"40.78.196.64/28\",\r\n \"40.78.204.16/28\"\ + ,\r\n \"40.78.229.48/28\",\r\n \"40.78.236.144/28\",\r\n\ + \ \"40.78.243.160/28\",\r\n \"40.78.251.96/28\",\r\n \ + \ \"40.79.132.64/28\",\r\n \"40.79.139.0/28\",\r\n \ + \ \"40.79.146.192/28\",\r\n \"40.79.156.48/28\",\r\n \"\ + 40.79.163.16/28\",\r\n \"40.79.171.96/28\",\r\n \"40.79.180.32/28\"\ + ,\r\n \"40.79.187.176/28\",\r\n \"40.79.195.160/28\",\r\n\ + \ \"40.80.51.96/28\",\r\n \"40.80.56.80/28\",\r\n \ + \ \"40.80.168.80/28\",\r\n \"40.80.176.16/28\",\r\n \"\ + 40.80.184.96/28\",\r\n \"40.82.248.96/28\",\r\n \"40.83.179.48/32\"\ + ,\r\n \"40.89.16.80/28\",\r\n \"40.119.9.192/28\",\r\n \ + \ \"40.120.75.96/28\",\r\n \"40.123.219.238/32\",\r\n \ + \ \"51.12.100.32/28\",\r\n \"51.12.204.32/28\",\r\n \ + \ \"51.12.227.208/28\",\r\n \"51.12.235.208/28\",\r\n \ + \ \"51.104.9.0/28\",\r\n \"51.104.24.112/28\",\r\n \"51.105.67.192/28\"\ + ,\r\n \"51.105.75.160/28\",\r\n \"51.105.80.80/28\",\r\n\ + \ \"51.105.88.80/28\",\r\n \"51.107.48.80/28\",\r\n \ + \ \"51.107.60.64/28\",\r\n \"51.107.68.31/32\",\r\n \ + \ \"51.107.144.80/28\",\r\n \"51.107.156.80/28\",\r\n \"\ + 51.107.231.223/32\",\r\n \"51.116.48.80/28\",\r\n \"51.116.60.64/28\"\ + ,\r\n \"51.116.144.80/28\",\r\n \"51.116.156.176/28\",\r\ + \n \"51.116.208.58/32\",\r\n \"51.116.243.128/28\",\r\n\ + \ \"51.116.251.48/28\",\r\n \"51.120.40.80/28\",\r\n \ + \ \"51.120.100.64/28\",\r\n \"51.120.107.208/28\",\r\n \ + \ \"51.120.211.208/28\",\r\n \"51.120.220.64/28\",\r\n \ + \ \"51.120.224.80/28\",\r\n \"51.137.160.96/28\",\r\n \ + \ \"51.140.43.158/32\",\r\n \"51.140.212.80/28\",\r\n \ + \ \"51.141.3.203/32\",\r\n \"51.142.209.167/32\",\r\n \"\ + 51.143.192.80/28\",\r\n \"52.136.48.80/28\",\r\n \"52.136.139.227/32\"\ + ,\r\n \"52.138.92.64/28\",\r\n \"52.138.227.144/28\",\r\n\ + \ \"52.140.104.80/28\",\r\n \"52.143.138.106/32\",\r\n \ + \ \"52.150.136.96/28\",\r\n \"52.161.20.168/32\",\r\n \ + \ \"52.162.111.0/28\",\r\n \"52.166.13.64/32\",\r\n \ + \ \"52.167.107.80/28\",\r\n \"52.172.46.220/32\",\r\n \ + \ \"52.172.187.37/32\",\r\n \"52.175.17.132/32\",\r\n \"\ + 52.175.146.69/32\",\r\n \"52.180.178.64/32\",\r\n \"52.182.139.192/28\"\ + ,\r\n \"52.183.45.166/32\",\r\n \"52.184.158.163/32\",\r\ + \n \"52.185.150.140/32\",\r\n \"52.187.58.193/32\",\r\n\ + \ \"52.187.191.206/32\",\r\n \"52.225.188.170/32\",\r\n\ + \ \"52.228.36.192/32\",\r\n \"52.228.80.96/28\",\r\n \ + \ \"52.229.125.98/32\",\r\n \"52.231.20.16/28\",\r\n \ + \ \"52.231.28.253/32\",\r\n \"52.231.148.96/28\",\r\n \ + \ \"52.231.198.185/32\",\r\n \"52.236.187.64/28\",\r\n \ + \ \"52.246.155.160/28\",\r\n \"65.52.252.192/28\",\r\n \"\ + 102.133.28.128/28\",\r\n \"102.133.59.160/28\",\r\n \"102.133.72.51/32\"\ + ,\r\n \"102.133.124.64/28\",\r\n \"102.133.156.96/28\",\r\ + \n \"102.133.160.44/32\",\r\n \"102.133.218.176/28\",\r\n\ + \ \"102.133.251.160/28\",\r\n \"104.210.113.114/32\",\r\n\ + \ \"104.211.177.6/32\",\r\n \"191.233.8.0/28\",\r\n \ + \ \"191.233.51.192/28\",\r\n \"191.233.205.80/28\",\r\n \ + \ \"191.234.147.208/28\",\r\n \"191.234.155.208/28\",\r\n \ + \ \"191.234.185.172/32\",\r\n \"191.235.224.112/28\",\r\n\ + \ \"2603:1000:104:1::/123\",\r\n \"2603:1010:6:1::/123\"\ + ,\r\n \"2603:1020:5:1::/123\",\r\n \"2603:1020:206:1::/123\"\ + ,\r\n \"2603:1020:705:1::/123\",\r\n \"2603:1020:805:1::/123\"\ + ,\r\n \"2603:1020:a04:1::/123\",\r\n \"2603:1020:c04:1::/123\"\ + ,\r\n \"2603:1020:e04:1::/123\",\r\n \"2603:1020:1004::/123\"\ + ,\r\n \"2603:1030:10:1::/123\",\r\n \"2603:1030:104:1::/123\"\ + ,\r\n \"2603:1030:210:1::/123\",\r\n \"2603:1030:40b:1::/123\"\ + ,\r\n \"2603:1030:40c:1::/123\",\r\n \"2603:1030:504:1::/123\"\ + ,\r\n \"2603:1030:807:1::/123\",\r\n \"2603:1030:c06:1::/123\"\ + ,\r\n \"2603:1030:f05:1::/123\",\r\n \"2603:1040:5:1::/123\"\ + ,\r\n \"2603:1040:407:1::/123\",\r\n \"2603:1040:904:1::/123\"\ + ,\r\n \"2603:1040:a06:1::/123\",\r\n \"2603:1040:d04::/123\"\ + ,\r\n \"2603:1040:f05:1::/123\",\r\n \"2603:1050:6:1::/123\"\ + ,\r\n \"2603:1050:403::/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"AzureTrafficManager\",\r\n \"id\": \"AzureTrafficManager\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"AzureTrafficManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.65.92.252/32\",\r\n \ + \ \"13.65.95.152/32\",\r\n \"13.75.124.254/32\",\r\n \"\ + 13.75.127.63/32\",\r\n \"13.75.152.253/32\",\r\n \"13.75.153.124/32\"\ + ,\r\n \"13.84.222.37/32\",\r\n \"23.96.236.252/32\",\r\n\ + \ \"23.101.191.199/32\",\r\n \"40.68.30.66/32\",\r\n \ + \ \"40.68.31.178/32\",\r\n \"40.78.67.110/32\",\r\n \ + \ \"40.87.147.10/32\",\r\n \"40.87.151.34/32\",\r\n \"\ + 40.114.5.197/32\",\r\n \"52.172.155.168/32\",\r\n \"52.172.158.37/32\"\ + ,\r\n \"52.173.90.107/32\",\r\n \"52.173.250.232/32\",\r\ + \n \"52.240.144.45/32\",\r\n \"52.240.151.125/32\",\r\n\ + \ \"65.52.217.19/32\",\r\n \"104.41.187.209/32\",\r\n \ + \ \"104.41.190.203/32\",\r\n \"104.42.192.195/32\",\r\n \ + \ \"104.45.149.110/32\",\r\n \"104.215.91.84/32\",\r\n \ + \ \"137.135.46.163/32\",\r\n \"137.135.47.215/32\",\r\n \ + \ \"137.135.80.149/32\",\r\n \"137.135.82.249/32\",\r\n \ + \ \"191.232.208.52/32\",\r\n \"191.232.214.62/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement\"\ + ,\r\n \"id\": \"BatchNodeManagement\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.65.192.161/32\",\r\n\ + \ \"13.65.208.36/32\",\r\n \"13.66.141.32/27\",\r\n \ + \ \"13.66.225.240/32\",\r\n \"13.66.227.117/32\",\r\n \ + \ \"13.66.227.193/32\",\r\n \"13.67.9.160/27\",\r\n \"\ + 13.67.58.116/32\",\r\n \"13.67.190.3/32\",\r\n \"13.67.237.249/32\"\ + ,\r\n \"13.69.65.64/26\",\r\n \"13.69.106.128/26\",\r\n\ + \ \"13.69.125.173/32\",\r\n \"13.69.229.32/27\",\r\n \ + \ \"13.70.73.0/27\",\r\n \"13.71.144.135/32\",\r\n \ + \ \"13.71.172.96/27\",\r\n \"13.71.195.160/27\",\r\n \"\ + 13.73.117.100/32\",\r\n \"13.73.153.226/32\",\r\n \"13.73.157.134/32\"\ + ,\r\n \"13.73.249.64/27\",\r\n \"13.74.107.128/27\",\r\n\ + \ \"13.75.36.96/27\",\r\n \"13.77.52.128/27\",\r\n \ + \ \"13.77.80.138/32\",\r\n \"13.78.108.128/27\",\r\n \ + \ \"13.78.145.2/32\",\r\n \"13.78.145.73/32\",\r\n \"13.78.150.134/32\"\ + ,\r\n \"13.78.187.18/32\",\r\n \"13.79.172.125/32\",\r\n\ + \ \"13.80.117.88/32\",\r\n \"13.81.1.133/32\",\r\n \ + \ \"13.81.59.254/32\",\r\n \"13.81.63.6/32\",\r\n \"\ + 13.81.104.137/32\",\r\n \"13.86.218.192/27\",\r\n \"13.87.32.176/32\"\ + ,\r\n \"13.87.32.218/32\",\r\n \"13.87.33.133/32\",\r\n\ + \ \"13.87.57.96/27\",\r\n \"13.87.97.57/32\",\r\n \ + \ \"13.87.97.82/32\",\r\n \"13.87.100.219/32\",\r\n \"\ + 13.87.123.96/27\",\r\n \"13.89.55.147/32\",\r\n \"13.89.171.224/27\"\ + ,\r\n \"13.91.55.167/32\",\r\n \"13.91.88.93/32\",\r\n \ + \ \"13.91.107.154/32\",\r\n \"13.92.114.103/32\",\r\n \ + \ \"13.93.206.144/32\",\r\n \"13.94.214.82/32\",\r\n \ + \ \"13.95.9.27/32\",\r\n \"20.36.40.22/32\",\r\n \"20.36.47.197/32\"\ + ,\r\n \"20.36.107.128/27\",\r\n \"20.36.121.160/27\",\r\n\ + \ \"20.37.65.160/27\",\r\n \"20.37.75.224/27\",\r\n \ + \ \"20.37.196.128/27\",\r\n \"20.37.225.160/27\",\r\n \ + \ \"20.38.85.224/27\",\r\n \"20.38.137.192/27\",\r\n \ + \ \"20.38.146.224/27\",\r\n \"20.39.1.125/32\",\r\n \"20.39.1.239/32\"\ + ,\r\n \"20.39.2.44/32\",\r\n \"20.39.2.122/32\",\r\n \ + \ \"20.39.3.157/32\",\r\n \"20.39.3.186/32\",\r\n \ + \ \"20.39.12.64/27\",\r\n \"20.40.137.186/32\",\r\n \"20.40.149.165/32\"\ + ,\r\n \"20.40.200.32/27\",\r\n \"20.41.5.224/27\",\r\n \ + \ \"20.41.66.128/27\",\r\n \"20.41.195.128/27\",\r\n \ + \ \"20.42.6.224/27\",\r\n \"20.42.227.224/27\",\r\n \ + \ \"20.43.42.96/27\",\r\n \"20.43.66.96/27\",\r\n \"20.43.132.64/27\"\ + ,\r\n \"20.44.4.112/29\",\r\n \"20.44.27.64/27\",\r\n \ + \ \"20.45.113.160/27\",\r\n \"20.45.122.224/27\",\r\n \ + \ \"20.45.195.192/27\",\r\n \"20.49.83.64/27\",\r\n \ + \ \"20.49.91.64/27\",\r\n \"20.50.1.64/26\",\r\n \"20.150.161.224/27\"\ + ,\r\n \"20.150.172.0/27\",\r\n \"20.150.179.96/27\",\r\n\ + \ \"20.150.187.96/27\",\r\n \"20.189.109.0/27\",\r\n \ + \ \"20.192.99.96/27\",\r\n \"20.192.161.224/27\",\r\n \ + \ \"20.192.228.160/27\",\r\n \"20.192.235.192/27\",\r\n \ + \ \"20.193.203.128/27\",\r\n \"23.96.12.112/32\",\r\n \ + \ \"23.96.101.73/32\",\r\n \"23.96.109.140/32\",\r\n \"\ + 23.96.232.67/32\",\r\n \"23.97.48.186/32\",\r\n \"23.97.51.12/32\"\ + ,\r\n \"23.97.97.29/32\",\r\n \"23.97.180.74/32\",\r\n \ + \ \"23.98.82.160/27\",\r\n \"23.99.98.61/32\",\r\n \ + \ \"23.99.107.229/32\",\r\n \"23.99.195.236/32\",\r\n \ + \ \"23.100.100.145/32\",\r\n \"23.100.103.112/32\",\r\n \ + \ \"23.101.176.33/32\",\r\n \"23.102.178.148/32\",\r\n \ + \ \"23.102.185.64/32\",\r\n \"40.64.128.160/27\",\r\n \"\ + 40.67.49.160/27\",\r\n \"40.67.60.0/27\",\r\n \"40.68.100.153/32\"\ + ,\r\n \"40.68.191.54/32\",\r\n \"40.68.218.90/32\",\r\n\ + \ \"40.69.107.128/27\",\r\n \"40.70.147.224/27\",\r\n \ + \ \"40.71.12.192/27\",\r\n \"40.74.101.0/27\",\r\n \ + \ \"40.74.140.140/32\",\r\n \"40.74.149.48/29\",\r\n \"\ + 40.74.177.177/32\",\r\n \"40.75.35.136/29\",\r\n \"40.77.18.99/32\"\ + ,\r\n \"40.78.195.128/27\",\r\n \"40.78.203.0/27\",\r\n\ + \ \"40.78.227.0/27\",\r\n \"40.78.234.96/27\",\r\n \ + \ \"40.78.242.224/27\",\r\n \"40.78.250.160/27\",\r\n \ + \ \"40.79.131.96/27\",\r\n \"40.79.138.96/27\",\r\n \"\ + 40.79.146.96/27\",\r\n \"40.79.154.32/27\",\r\n \"40.79.162.96/27\"\ + ,\r\n \"40.79.170.192/27\",\r\n \"40.79.186.128/27\",\r\n\ + \ \"40.79.194.32/27\",\r\n \"40.80.50.224/27\",\r\n \ + \ \"40.80.58.160/27\",\r\n \"40.80.170.128/27\",\r\n \ + \ \"40.80.190.192/27\",\r\n \"40.82.255.64/27\",\r\n \"\ + 40.84.49.170/32\",\r\n \"40.84.62.82/32\",\r\n \"40.85.226.213/32\"\ + ,\r\n \"40.85.227.37/32\",\r\n \"40.86.224.98/32\",\r\n\ + \ \"40.86.224.104/32\",\r\n \"40.88.48.36/32\",\r\n \ + \ \"40.89.18.192/27\",\r\n \"40.89.65.161/32\",\r\n \ + \ \"40.89.66.236/32\",\r\n \"40.89.67.77/32\",\r\n \"40.89.70.17/32\"\ + ,\r\n \"40.112.254.235/32\",\r\n \"40.115.50.9/32\",\r\n\ + \ \"40.118.208.127/32\",\r\n \"40.122.166.234/32\",\r\n\ + \ \"51.12.41.192/27\",\r\n \"51.12.100.0/27\",\r\n \ + \ \"51.12.193.192/27\",\r\n \"51.12.204.0/27\",\r\n \ + \ \"51.12.227.96/27\",\r\n \"51.12.235.96/27\",\r\n \"51.104.28.0/27\"\ + ,\r\n \"51.105.66.224/27\",\r\n \"51.105.74.224/27\",\r\n\ + \ \"51.105.81.160/27\",\r\n \"51.105.89.192/27\",\r\n \ + \ \"51.107.49.192/27\",\r\n \"51.107.59.224/27\",\r\n \ + \ \"51.107.145.160/27\",\r\n \"51.107.155.224/27\",\r\n \ + \ \"51.116.48.224/27\",\r\n \"51.116.59.224/27\",\r\n \ + \ \"51.116.144.224/27\",\r\n \"51.116.154.32/27\",\r\n \ + \ \"51.116.243.0/27\",\r\n \"51.116.251.0/27\",\r\n \"\ + 51.120.41.192/27\",\r\n \"51.120.99.224/27\",\r\n \"51.120.107.96/27\"\ + ,\r\n \"51.120.211.96/27\",\r\n \"51.120.220.0/27\",\r\n\ + \ \"51.120.225.160/27\",\r\n \"51.137.162.192/27\",\r\n\ + \ \"51.140.148.160/27\",\r\n \"51.140.184.59/32\",\r\n \ + \ \"51.140.184.61/32\",\r\n \"51.140.184.63/32\",\r\n \ + \ \"51.140.211.128/27\",\r\n \"51.141.8.61/32\",\r\n \ + \ \"51.141.8.62/32\",\r\n \"51.141.8.64/32\",\r\n \"\ + 51.143.193.160/27\",\r\n \"52.136.49.192/27\",\r\n \"52.136.143.192/31\"\ + ,\r\n \"52.137.105.46/32\",\r\n \"52.138.90.64/27\",\r\n\ + \ \"52.138.226.128/27\",\r\n \"52.140.106.128/27\",\r\n\ + \ \"52.143.139.121/32\",\r\n \"52.143.140.12/32\",\r\n \ + \ \"52.148.148.46/32\",\r\n \"52.150.140.128/27\",\r\n \ + \ \"52.161.95.12/32\",\r\n \"52.161.107.48/32\",\r\n \ + \ \"52.162.110.32/27\",\r\n \"52.164.244.189/32\",\r\n \ + \ \"52.164.245.81/32\",\r\n \"52.165.44.224/32\",\r\n \ + \ \"52.166.19.45/32\",\r\n \"52.167.106.128/27\",\r\n \"\ + 52.169.27.79/32\",\r\n \"52.169.30.175/32\",\r\n \"52.169.235.90/32\"\ + ,\r\n \"52.174.33.113/32\",\r\n \"52.174.34.69/32\",\r\n\ + \ \"52.174.35.218/32\",\r\n \"52.174.38.99/32\",\r\n \ + \ \"52.174.176.203/32\",\r\n \"52.174.179.66/32\",\r\n \ + \ \"52.174.180.164/32\",\r\n \"52.175.218.150/32\",\r\n \ + \ \"52.178.149.188/32\",\r\n \"52.180.176.58/32\",\r\n \ + \ \"52.180.177.108/32\",\r\n \"52.180.177.206/32\",\r\n \ + \ \"52.180.179.94/32\",\r\n \"52.180.181.0/32\",\r\n \ + \ \"52.180.181.239/32\",\r\n \"52.182.139.0/27\",\r\n \"\ + 52.188.222.115/32\",\r\n \"52.189.217.254/32\",\r\n \"52.191.129.21/32\"\ + ,\r\n \"52.191.166.57/32\",\r\n \"52.225.185.38/32\",\r\n\ + \ \"52.225.191.67/32\",\r\n \"52.228.44.187/32\",\r\n \ + \ \"52.228.83.192/27\",\r\n \"52.231.19.96/27\",\r\n \ + \ \"52.231.32.70/31\",\r\n \"52.231.32.82/32\",\r\n \ + \ \"52.231.147.128/27\",\r\n \"52.231.200.112/31\",\r\n \ + \ \"52.231.200.126/32\",\r\n \"52.233.40.34/32\",\r\n \"\ + 52.233.157.9/32\",\r\n \"52.233.157.78/32\",\r\n \"52.233.161.238/32\"\ + ,\r\n \"52.233.172.80/32\",\r\n \"52.235.41.66/32\",\r\n\ + \ \"52.236.186.128/26\",\r\n \"52.237.30.175/32\",\r\n \ + \ \"52.242.22.129/32\",\r\n \"52.242.33.105/32\",\r\n \ + \ \"52.246.154.224/27\",\r\n \"52.249.60.22/32\",\r\n \ + \ \"52.253.227.240/32\",\r\n \"65.52.199.156/32\",\r\n \ + \ \"65.52.199.188/32\",\r\n \"65.52.251.224/27\",\r\n \ + \ \"70.37.49.163/32\",\r\n \"102.133.27.192/27\",\r\n \"\ + 102.133.56.192/27\",\r\n \"102.133.123.64/27\",\r\n \"102.133.155.192/27\"\ + ,\r\n \"102.133.217.224/27\",\r\n \"102.133.250.224/27\"\ + ,\r\n \"104.40.69.159/32\",\r\n \"104.40.183.25/32\",\r\n\ + \ \"104.41.2.182/32\",\r\n \"104.41.129.99/32\",\r\n \ + \ \"104.43.128.78/32\",\r\n \"104.43.131.156/32\",\r\n \ + \ \"104.43.132.75/32\",\r\n \"104.45.13.8/32\",\r\n \ + \ \"104.45.82.201/32\",\r\n \"104.45.88.181/32\",\r\n \"\ + 104.46.232.208/32\",\r\n \"104.46.236.29/32\",\r\n \"104.47.149.96/32\"\ + ,\r\n \"104.208.16.128/27\",\r\n \"104.208.144.128/27\"\ + ,\r\n \"104.208.156.99/32\",\r\n \"104.208.157.18/32\",\r\ + \n \"104.210.3.254/32\",\r\n \"104.210.115.52/32\",\r\n\ + \ \"104.211.82.96/27\",\r\n \"104.211.96.142/32\",\r\n \ + \ \"104.211.96.144/31\",\r\n \"104.211.147.96/27\",\r\n \ + \ \"104.211.160.72/32\",\r\n \"104.211.160.74/31\",\r\n \ + \ \"104.211.224.117/32\",\r\n \"104.211.224.119/32\",\r\n\ + \ \"104.211.224.121/32\",\r\n \"104.214.19.192/27\",\r\n\ + \ \"104.214.65.153/32\",\r\n \"111.221.104.48/32\",\r\n\ + \ \"137.116.33.5/32\",\r\n \"137.116.33.29/32\",\r\n \ + \ \"137.116.33.71/32\",\r\n \"137.116.37.146/32\",\r\n \ + \ \"137.116.46.180/32\",\r\n \"137.116.193.225/32\",\r\n \ + \ \"137.117.45.176/32\",\r\n \"137.117.109.143/32\",\r\n \ + \ \"138.91.1.114/32\",\r\n \"138.91.17.36/32\",\r\n \ + \ \"157.55.167.71/32\",\r\n \"157.55.210.88/32\",\r\n \ + \ \"168.61.161.154/32\",\r\n \"168.61.209.228/32\",\r\n \ + \ \"168.62.4.114/32\",\r\n \"168.62.36.128/32\",\r\n \"\ + 168.62.168.27/32\",\r\n \"168.63.5.53/32\",\r\n \"168.63.36.126/32\"\ + ,\r\n \"168.63.133.23/32\",\r\n \"168.63.208.148/32\",\r\ + \n \"191.232.37.60/32\",\r\n \"191.233.10.0/27\",\r\n \ + \ \"191.233.76.85/32\",\r\n \"191.233.204.96/27\",\r\n \ + \ \"191.234.147.96/27\",\r\n \"191.234.155.96/27\",\r\n \ + \ \"191.235.227.192/27\",\r\n \"191.236.37.239/32\",\r\n \ + \ \"191.236.38.142/32\",\r\n \"191.236.161.35/32\",\r\n \ + \ \"191.236.163.245/32\",\r\n \"191.236.164.44/32\",\r\n \ + \ \"191.239.18.3/32\",\r\n \"191.239.21.73/32\",\r\n \ + \ \"191.239.40.217/32\",\r\n \"191.239.64.139/32\",\r\n \ + \ \"191.239.64.152/32\",\r\n \"191.239.160.161/32\",\r\n \ + \ \"191.239.160.185/32\",\r\n \"207.46.149.75/32\",\r\n \ + \ \"207.46.225.72/32\",\r\n \"2603:1000:104:1::340/122\",\r\ + \n \"2603:1010:6:1::340/122\",\r\n \"2603:1020:5:1::340/122\"\ + ,\r\n \"2603:1020:206:1::340/122\",\r\n \"2603:1020:705:1::340/122\"\ + ,\r\n \"2603:1020:805:1::340/122\",\r\n \"2603:1020:a04:1::340/122\"\ + ,\r\n \"2603:1020:c04:1::340/122\",\r\n \"2603:1020:e04:1::340/122\"\ + ,\r\n \"2603:1020:1004::340/122\",\r\n \"2603:1030:10:1::340/122\"\ + ,\r\n \"2603:1030:104:1::340/122\",\r\n \"2603:1030:210:1::340/122\"\ + ,\r\n \"2603:1030:40b:1::340/122\",\r\n \"2603:1030:40c:1::340/122\"\ + ,\r\n \"2603:1030:504:1::340/122\",\r\n \"2603:1030:807:1::340/122\"\ + ,\r\n \"2603:1030:c06:1::340/122\",\r\n \"2603:1030:f05:1::340/122\"\ + ,\r\n \"2603:1040:5:1::340/122\",\r\n \"2603:1040:407:1::340/122\"\ + ,\r\n \"2603:1040:904:1::340/122\",\r\n \"2603:1040:a06:1::340/122\"\ + ,\r\n \"2603:1040:d04::340/122\",\r\n \"2603:1040:f05:1::340/122\"\ + ,\r\n \"2603:1050:6:1::340/122\",\r\n \"2603:1050:403::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.AustraliaCentral\"\ + ,\r\n \"id\": \"BatchNodeManagement.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.36.40.22/32\",\r\n \"20.36.47.197/32\",\r\n \"20.36.107.128/27\"\ + ,\r\n \"20.37.225.160/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"BatchNodeManagement.AustraliaCentral2\",\r\n \ + \ \"id\": \"BatchNodeManagement.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.121.160/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.AustraliaEast\"\ + ,\r\n \"id\": \"BatchNodeManagement.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.70.73.0/27\",\r\n \"20.37.196.128/27\",\r\n \"40.79.162.96/27\"\ + ,\r\n \"40.79.170.192/27\",\r\n \"104.210.115.52/32\",\r\ + \n \"191.239.64.139/32\",\r\n \"191.239.64.152/32\",\r\n\ + \ \"2603:1010:6:1::340/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"BatchNodeManagement.AustraliaSoutheast\",\r\n\ + \ \"id\": \"BatchNodeManagement.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.73.117.100/32\",\r\n \"13.77.52.128/27\",\r\n \"\ + 20.42.227.224/27\",\r\n \"52.189.217.254/32\",\r\n \"191.239.160.161/32\"\ + ,\r\n \"191.239.160.185/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"BatchNodeManagement.BrazilSouth\",\r\n \"\ + id\": \"BatchNodeManagement.BrazilSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.97.97.29/32\",\r\n \"104.41.2.182/32\",\r\n \"191.232.37.60/32\"\ + ,\r\n \"191.233.204.96/27\",\r\n \"191.234.147.96/27\",\r\ + \n \"191.234.155.96/27\",\r\n \"191.235.227.192/27\",\r\n\ + \ \"2603:1050:6:1::340/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"BatchNodeManagement.CanadaCentral\",\r\n \ + \ \"id\": \"BatchNodeManagement.CanadaCentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.172.96/27\",\r\n \"20.38.146.224/27\",\r\n \"\ + 40.85.226.213/32\",\r\n \"40.85.227.37/32\",\r\n \"52.228.44.187/32\"\ + ,\r\n \"52.228.83.192/27\",\r\n \"52.233.40.34/32\",\r\n\ + \ \"52.237.30.175/32\",\r\n \"52.246.154.224/27\",\r\n \ + \ \"2603:1030:f05:1::340/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"BatchNodeManagement.CanadaEast\",\r\n \"\ + id\": \"BatchNodeManagement.CanadaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.107.128/27\",\r\n \"40.86.224.98/32\",\r\n \"\ + 40.86.224.104/32\",\r\n \"40.89.18.192/27\",\r\n \"52.235.41.66/32\"\ + ,\r\n \"52.242.22.129/32\",\r\n \"52.242.33.105/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralIndia\"\ + ,\r\n \"id\": \"BatchNodeManagement.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.192.99.96/27\",\r\n \"40.80.50.224/27\",\r\n \"52.140.106.128/27\"\ + ,\r\n \"104.211.82.96/27\",\r\n \"104.211.96.142/32\",\r\ + \n \"104.211.96.144/31\",\r\n \"2603:1040:a06:1::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralUS\"\ + ,\r\n \"id\": \"BatchNodeManagement.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.190.3/32\",\r\n \"13.67.237.249/32\",\r\n \"13.89.55.147/32\"\ + ,\r\n \"13.89.171.224/27\",\r\n \"20.40.200.32/27\",\r\n\ + \ \"23.99.195.236/32\",\r\n \"40.77.18.99/32\",\r\n \ + \ \"40.122.166.234/32\",\r\n \"52.165.44.224/32\",\r\n \ + \ \"52.182.139.0/27\",\r\n \"104.43.128.78/32\",\r\n \ + \ \"104.43.131.156/32\",\r\n \"104.43.132.75/32\",\r\n \ + \ \"104.208.16.128/27\",\r\n \"168.61.161.154/32\",\r\n \ + \ \"168.61.209.228/32\",\r\n \"2603:1030:10:1::340/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.CentralUSEUAP\"\ + ,\r\n \"id\": \"BatchNodeManagement.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.45.195.192/27\",\r\n \"40.78.203.0/27\",\r\n \"52.180.176.58/32\"\ + ,\r\n \"52.180.177.108/32\",\r\n \"52.180.177.206/32\",\r\ + \n \"52.180.179.94/32\",\r\n \"52.180.181.0/32\",\r\n \ + \ \"52.180.181.239/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"BatchNodeManagement.EastAsia\",\r\n \"id\": \"BatchNodeManagement.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n \"\ + addressPrefixes\": [\r\n \"13.75.36.96/27\",\r\n \"20.189.109.0/27\"\ + ,\r\n \"23.99.98.61/32\",\r\n \"23.99.107.229/32\",\r\n\ + \ \"168.63.133.23/32\",\r\n \"168.63.208.148/32\",\r\n \ + \ \"207.46.149.75/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"BatchNodeManagement.EastUS\",\r\n \"id\": \"BatchNodeManagement.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\":\ + \ [\r\n \"13.92.114.103/32\",\r\n \"20.42.6.224/27\",\r\n\ + \ \"23.96.12.112/32\",\r\n \"23.96.101.73/32\",\r\n \ + \ \"23.96.109.140/32\",\r\n \"40.71.12.192/27\",\r\n \ + \ \"40.78.227.0/27\",\r\n \"40.79.154.32/27\",\r\n \"\ + 40.88.48.36/32\",\r\n \"52.188.222.115/32\",\r\n \"104.41.129.99/32\"\ + ,\r\n \"137.117.45.176/32\",\r\n \"137.117.109.143/32\"\ + ,\r\n \"168.62.36.128/32\",\r\n \"168.62.168.27/32\",\r\n\ + \ \"191.236.37.239/32\",\r\n \"191.236.38.142/32\",\r\n\ + \ \"2603:1030:210:1::340/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"BatchNodeManagement.EastUS2\",\r\n \"id\"\ + : \"BatchNodeManagement.EastUS2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.80.138/32\",\r\n\ + \ \"20.41.5.224/27\",\r\n \"40.70.147.224/27\",\r\n \ + \ \"40.84.49.170/32\",\r\n \"40.84.62.82/32\",\r\n \ + \ \"52.167.106.128/27\",\r\n \"104.208.144.128/27\",\r\n \ + \ \"104.208.156.99/32\",\r\n \"104.208.157.18/32\",\r\n \ + \ \"104.210.3.254/32\",\r\n \"137.116.33.5/32\",\r\n \"\ + 137.116.33.29/32\",\r\n \"137.116.33.71/32\",\r\n \"137.116.37.146/32\"\ + ,\r\n \"137.116.46.180/32\",\r\n \"2603:1030:40c:1::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.EastUS2EUAP\"\ + ,\r\n \"id\": \"BatchNodeManagement.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.39.1.125/32\",\r\n \"20.39.1.239/32\",\r\n \"20.39.2.44/32\"\ + ,\r\n \"20.39.2.122/32\",\r\n \"20.39.3.157/32\",\r\n \ + \ \"20.39.3.186/32\",\r\n \"20.39.12.64/27\",\r\n \ + \ \"40.74.149.48/29\",\r\n \"40.75.35.136/29\",\r\n \"\ + 40.89.65.161/32\",\r\n \"40.89.66.236/32\",\r\n \"40.89.67.77/32\"\ + ,\r\n \"40.89.70.17/32\",\r\n \"52.138.90.64/27\",\r\n \ + \ \"52.225.185.38/32\",\r\n \"52.225.191.67/32\",\r\n \ + \ \"52.253.227.240/32\",\r\n \"2603:1030:40b:1::340/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.FranceCentral\"\ + ,\r\n \"id\": \"BatchNodeManagement.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.40.137.186/32\",\r\n \"20.40.149.165/32\",\r\n \"\ + 20.43.42.96/27\",\r\n \"40.79.131.96/27\",\r\n \"40.79.138.96/27\"\ + ,\r\n \"40.79.146.96/27\",\r\n \"52.143.139.121/32\",\r\n\ + \ \"52.143.140.12/32\",\r\n \"2603:1020:805:1::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.FranceSouth\"\ + ,\r\n \"id\": \"BatchNodeManagement.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.105.89.192/27\",\r\n \"52.136.143.192/31\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.GermanyNorth\"\ + ,\r\n \"id\": \"BatchNodeManagement.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.116.48.224/27\",\r\n \"51.116.59.224/27\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.GermanyWestCentral\"\ + ,\r\n \"id\": \"BatchNodeManagement.GermanyWestCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"BatchNodeManagement\",\r\n \"addressPrefixes\":\ + \ [\r\n \"51.116.144.224/27\",\r\n \"51.116.154.32/27\"\ + ,\r\n \"51.116.243.0/27\",\r\n \"51.116.251.0/27\",\r\n\ + \ \"2603:1020:c04:1::340/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"BatchNodeManagement.JapanEast\",\r\n \"\ + id\": \"BatchNodeManagement.JapanEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.144.135/32\",\r\n \"13.78.108.128/27\",\r\n \"\ + 20.43.66.96/27\",\r\n \"23.100.100.145/32\",\r\n \"23.100.103.112/32\"\ + ,\r\n \"40.79.186.128/27\",\r\n \"40.79.194.32/27\",\r\n\ + \ \"138.91.1.114/32\",\r\n \"2603:1040:407:1::340/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.JapanWest\"\ + ,\r\n \"id\": \"BatchNodeManagement.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.101.0/27\",\r\n \"40.74.140.140/32\",\r\n \"40.80.58.160/27\"\ + ,\r\n \"104.46.232.208/32\",\r\n \"104.46.236.29/32\",\r\ + \n \"138.91.17.36/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"BatchNodeManagement.KoreaCentral\",\r\n \"id\": \"\ + BatchNodeManagement.KoreaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"20.41.66.128/27\"\ + ,\r\n \"20.44.27.64/27\",\r\n \"52.231.19.96/27\",\r\n \ + \ \"52.231.32.70/31\",\r\n \"52.231.32.82/32\",\r\n \ + \ \"2603:1040:f05:1::340/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"BatchNodeManagement.KoreaSouth\",\r\n \"id\"\ + : \"BatchNodeManagement.KoreaSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \"40.80.170.128/27\"\ + ,\r\n \"52.231.147.128/27\",\r\n \"52.231.200.112/31\",\r\ + \n \"52.231.200.126/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"BatchNodeManagement.NorthCentralUS\",\r\n \"\ + id\": \"BatchNodeManagement.NorthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.96.232.67/32\",\r\n \"40.80.190.192/27\",\r\n \"\ + 52.162.110.32/27\",\r\n \"65.52.199.156/32\",\r\n \"65.52.199.188/32\"\ + ,\r\n \"157.55.167.71/32\",\r\n \"157.55.210.88/32\",\r\n\ + \ \"191.236.161.35/32\",\r\n \"191.236.163.245/32\",\r\n\ + \ \"191.236.164.44/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"BatchNodeManagement.NorthEurope\",\r\n \"id\"\ + : \"BatchNodeManagement.NorthEurope\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.229.32/27\",\r\n \"13.74.107.128/27\",\r\n \"\ + 13.79.172.125/32\",\r\n \"20.38.85.224/27\",\r\n \"52.138.226.128/27\"\ + ,\r\n \"52.164.244.189/32\",\r\n \"52.164.245.81/32\",\r\ + \n \"52.169.27.79/32\",\r\n \"52.169.30.175/32\",\r\n \ + \ \"52.169.235.90/32\",\r\n \"52.178.149.188/32\",\r\n \ + \ \"104.45.82.201/32\",\r\n \"104.45.88.181/32\",\r\n \ + \ \"168.63.36.126/32\",\r\n \"2603:1020:5:1::340/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.NorwayEast\"\ + ,\r\n \"id\": \"BatchNodeManagement.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.41.192/27\",\r\n \"51.120.99.224/27\",\r\n \"\ + 51.120.107.96/27\",\r\n \"51.120.211.96/27\",\r\n \"2603:1020:e04:1::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.NorwayWest\"\ + ,\r\n \"id\": \"BatchNodeManagement.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.220.0/27\",\r\n \"51.120.225.160/27\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SouthAfricaNorth\"\ + ,\r\n \"id\": \"BatchNodeManagement.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"102.133.123.64/27\",\r\n \"102.133.155.192/27\",\r\n \ + \ \"102.133.217.224/27\",\r\n \"102.133.250.224/27\",\r\n \ + \ \"2603:1000:104:1::340/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"BatchNodeManagement.SouthAfricaWest\",\r\n \ + \ \"id\": \"BatchNodeManagement.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"102.133.27.192/27\",\r\n \"102.133.56.192/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SouthCentralUS\"\ + ,\r\n \"id\": \"BatchNodeManagement.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.65.192.161/32\",\r\n \"13.65.208.36/32\",\r\n \"\ + 13.73.249.64/27\",\r\n \"20.45.122.224/27\",\r\n \"20.49.91.64/27\"\ + ,\r\n \"23.101.176.33/32\",\r\n \"23.102.178.148/32\",\r\ + \n \"23.102.185.64/32\",\r\n \"40.74.177.177/32\",\r\n \ + \ \"52.249.60.22/32\",\r\n \"70.37.49.163/32\",\r\n \ + \ \"104.214.19.192/27\",\r\n \"104.214.65.153/32\",\r\n \ + \ \"2603:1030:807:1::340/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"BatchNodeManagement.SoutheastAsia\",\r\n \"\ + id\": \"BatchNodeManagement.SoutheastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.9.160/27\",\r\n \"13.67.58.116/32\",\r\n \"20.43.132.64/27\"\ + ,\r\n \"23.97.48.186/32\",\r\n \"23.97.51.12/32\",\r\n \ + \ \"23.98.82.160/27\",\r\n \"40.78.234.96/27\",\r\n \ + \ \"111.221.104.48/32\",\r\n \"207.46.225.72/32\",\r\n \ + \ \"2603:1040:5:1::340/122\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"BatchNodeManagement.SouthIndia\",\r\n \"id\": \"\ + BatchNodeManagement.SouthIndia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.41.195.128/27\",\r\n\ + \ \"40.78.195.128/27\",\r\n \"104.211.224.117/32\",\r\n\ + \ \"104.211.224.119/32\",\r\n \"104.211.224.121/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.SwitzerlandNorth\"\ + ,\r\n \"id\": \"BatchNodeManagement.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.49.192/27\",\r\n \"51.107.59.224/27\",\r\n \"\ + 2603:1020:a04:1::340/122\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"BatchNodeManagement.SwitzerlandWest\",\r\n \"id\"\ + : \"BatchNodeManagement.SwitzerlandWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.145.160/27\",\r\n \"51.107.155.224/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UAECentral\"\ + ,\r\n \"id\": \"BatchNodeManagement.UAECentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.65.160/27\",\r\n \"20.37.75.224/27\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UAENorth\"\ + ,\r\n \"id\": \"BatchNodeManagement.UAENorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.137.192/27\",\r\n \"65.52.251.224/27\",\r\n \"\ + 2603:1040:904:1::340/122\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"BatchNodeManagement.UKNorth\",\r\n \"id\": \"BatchNodeManagement.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.97.57/32\",\r\n \ + \ \"13.87.97.82/32\",\r\n \"13.87.100.219/32\",\r\n \ + \ \"13.87.123.96/27\",\r\n \"51.105.81.160/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UKSouth\"\ + ,\r\n \"id\": \"BatchNodeManagement.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.104.28.0/27\",\r\n \"51.105.66.224/27\",\r\n \"51.105.74.224/27\"\ + ,\r\n \"51.140.148.160/27\",\r\n \"51.140.184.59/32\",\r\ + \n \"51.140.184.61/32\",\r\n \"51.140.184.63/32\",\r\n \ + \ \"2603:1020:705:1::340/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"BatchNodeManagement.UKSouth2\",\r\n \"id\"\ + : \"BatchNodeManagement.UKSouth2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + \r\n ],\r\n \"systemService\": \"BatchNodeManagement\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.32.176/32\",\r\n \ + \ \"13.87.32.218/32\",\r\n \"13.87.33.133/32\",\r\n \ + \ \"13.87.57.96/27\",\r\n \"51.143.193.160/27\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.UKWest\"\ + ,\r\n \"id\": \"BatchNodeManagement.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.137.162.192/27\",\r\n \"51.140.211.128/27\",\r\n \ + \ \"51.141.8.61/32\",\r\n \"51.141.8.62/32\",\r\n \"51.141.8.64/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestCentralUS\"\ + ,\r\n \"id\": \"BatchNodeManagement.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.195.160/27\",\r\n \"13.78.145.2/32\",\r\n \"13.78.145.73/32\"\ + ,\r\n \"13.78.150.134/32\",\r\n \"13.78.187.18/32\",\r\n\ + \ \"52.150.140.128/27\",\r\n \"52.161.95.12/32\",\r\n \ + \ \"52.161.107.48/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"BatchNodeManagement.WestEurope\",\r\n \"id\": \"\ + BatchNodeManagement.WestEurope\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"BatchNodeManagement\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.65.64/26\",\r\n \ + \ \"13.69.106.128/26\",\r\n \"13.69.125.173/32\",\r\n \ + \ \"13.73.153.226/32\",\r\n \"13.73.157.134/32\",\r\n \ + \ \"13.80.117.88/32\",\r\n \"13.81.1.133/32\",\r\n \"\ + 13.81.59.254/32\",\r\n \"13.81.63.6/32\",\r\n \"13.81.104.137/32\"\ + ,\r\n \"13.94.214.82/32\",\r\n \"13.95.9.27/32\",\r\n \ + \ \"20.50.1.64/26\",\r\n \"23.97.180.74/32\",\r\n \ + \ \"40.68.100.153/32\",\r\n \"40.68.191.54/32\",\r\n \"\ + 40.68.218.90/32\",\r\n \"40.115.50.9/32\",\r\n \"52.166.19.45/32\"\ + ,\r\n \"52.174.33.113/32\",\r\n \"52.174.34.69/32\",\r\n\ + \ \"52.174.35.218/32\",\r\n \"52.174.38.99/32\",\r\n \ + \ \"52.174.176.203/32\",\r\n \"52.174.179.66/32\",\r\n \ + \ \"52.174.180.164/32\",\r\n \"52.233.157.9/32\",\r\n \ + \ \"52.233.157.78/32\",\r\n \"52.233.161.238/32\",\r\n \ + \ \"52.233.172.80/32\",\r\n \"52.236.186.128/26\",\r\n \ + \ \"104.40.183.25/32\",\r\n \"104.45.13.8/32\",\r\n \"\ + 104.47.149.96/32\",\r\n \"137.116.193.225/32\",\r\n \"168.63.5.53/32\"\ + ,\r\n \"191.233.76.85/32\",\r\n \"2603:1020:206:1::340/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestIndia\"\ + ,\r\n \"id\": \"BatchNodeManagement.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.136.49.192/27\",\r\n \"104.211.147.96/27\",\r\n \"\ + 104.211.160.72/32\",\r\n \"104.211.160.74/31\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestUS\"\ + ,\r\n \"id\": \"BatchNodeManagement.WestUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.86.218.192/27\",\r\n \"13.91.55.167/32\",\r\n \"\ + 13.91.88.93/32\",\r\n \"13.91.107.154/32\",\r\n \"13.93.206.144/32\"\ + ,\r\n \"40.82.255.64/27\",\r\n \"40.112.254.235/32\",\r\n\ + \ \"40.118.208.127/32\",\r\n \"104.40.69.159/32\",\r\n \ + \ \"168.62.4.114/32\",\r\n \"191.239.18.3/32\",\r\n \ + \ \"191.239.21.73/32\",\r\n \"191.239.40.217/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"BatchNodeManagement.WestUS2\"\ + ,\r\n \"id\": \"BatchNodeManagement.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"BatchNodeManagement\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.141.32/27\",\r\n \"13.66.225.240/32\",\r\n \"\ + 13.66.227.117/32\",\r\n \"13.66.227.193/32\",\r\n \"40.64.128.160/27\"\ + ,\r\n \"40.78.242.224/27\",\r\n \"40.78.250.160/27\",\r\n\ + \ \"52.137.105.46/32\",\r\n \"52.148.148.46/32\",\r\n \ + \ \"52.175.218.150/32\",\r\n \"52.191.129.21/32\",\r\n \ + \ \"52.191.166.57/32\",\r\n \"2603:1030:c06:1::340/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"CognitiveServicesManagement\"\ + ,\r\n \"id\": \"CognitiveServicesManagement\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.56.76/32\",\r\n \"13.66.141.232/29\",\r\n \ + \ \"13.67.10.80/29\",\r\n \"13.67.35.35/32\",\r\n \"13.67.35.77/32\"\ + ,\r\n \"13.68.82.4/32\",\r\n \"13.68.130.251/32\",\r\n \ + \ \"13.68.211.223/32\",\r\n \"13.68.235.98/32\",\r\n \ + \ \"13.69.67.64/28\",\r\n \"13.69.112.176/28\",\r\n \ + \ \"13.69.126.92/32\",\r\n \"13.69.230.0/29\",\r\n \"13.70.74.88/29\"\ + ,\r\n \"13.70.127.50/32\",\r\n \"13.70.149.125/32\",\r\n\ + \ \"13.71.173.216/29\",\r\n \"13.71.196.136/29\",\r\n \ + \ \"13.73.242.48/29\",\r\n \"13.73.249.0/27\",\r\n \ + \ \"13.73.249.96/27\",\r\n \"13.73.249.128/28\",\r\n \"\ + 13.73.249.160/28\",\r\n \"13.74.139.192/32\",\r\n \"13.74.170.104/32\"\ + ,\r\n \"13.75.39.64/29\",\r\n \"13.75.92.220/32\",\r\n \ + \ \"13.75.137.81/32\",\r\n \"13.75.163.9/32\",\r\n \ + \ \"13.75.168.111/32\",\r\n \"13.77.1.236/32\",\r\n \"\ + 13.77.55.152/30\",\r\n \"13.77.55.208/28\",\r\n \"13.77.202.2/32\"\ + ,\r\n \"13.78.17.188/32\",\r\n \"13.78.49.187/32\",\r\n\ + \ \"13.78.70.7/32\",\r\n \"13.78.132.155/32\",\r\n \ + \ \"13.78.185.44/32\",\r\n \"13.78.187.168/32\",\r\n \ + \ \"13.78.230.142/32\",\r\n \"13.79.2.84/32\",\r\n \"13.83.68.180/32\"\ + ,\r\n \"13.84.42.205/32\",\r\n \"13.86.219.128/27\",\r\n\ + \ \"13.87.216.38/32\",\r\n \"13.88.14.63/32\",\r\n \ + \ \"13.88.26.200/32\",\r\n \"13.88.220.109/32\",\r\n \ + \ \"13.88.222.0/32\",\r\n \"13.89.235.89/32\",\r\n \"13.91.130.201/32\"\ + ,\r\n \"13.91.243.134/32\",\r\n \"13.92.138.76/32\",\r\n\ + \ \"13.92.179.108/32\",\r\n \"13.93.122.1/32\",\r\n \ + \ \"13.94.26.39/32\",\r\n \"20.36.120.224/27\",\r\n \ + \ \"20.36.121.192/27\",\r\n \"20.36.121.224/28\",\r\n \"\ + 20.37.64.224/27\",\r\n \"20.37.65.192/27\",\r\n \"20.37.65.224/28\"\ + ,\r\n \"20.37.76.200/30\",\r\n \"20.37.156.204/30\",\r\n\ + \ \"20.37.157.96/27\",\r\n \"20.37.195.112/28\",\r\n \ + \ \"20.37.195.192/27\",\r\n \"20.37.196.160/27\",\r\n \ + \ \"20.37.224.224/27\",\r\n \"20.37.225.192/27\",\r\n \ + \ \"20.37.225.224/28\",\r\n \"20.38.84.108/30\",\r\n \"\ + 20.38.85.160/27\",\r\n \"20.38.87.128/27\",\r\n \"20.38.87.160/28\"\ + ,\r\n \"20.38.136.240/28\",\r\n \"20.38.137.128/27\",\r\n\ + \ \"20.38.137.224/27\",\r\n \"20.38.149.208/28\",\r\n \ + \ \"20.39.11.112/28\",\r\n \"20.39.12.0/27\",\r\n \ + \ \"20.39.12.96/27\",\r\n \"20.40.125.208/32\",\r\n \"\ + 20.40.164.245/32\",\r\n \"20.40.170.73/32\",\r\n \"20.40.187.210/32\"\ + ,\r\n \"20.40.188.109/32\",\r\n \"20.40.190.135/32\",\r\n\ + \ \"20.40.190.225/32\",\r\n \"20.40.200.64/27\",\r\n \ + \ \"20.40.200.96/28\",\r\n \"20.41.5.160/27\",\r\n \ + \ \"20.41.65.192/27\",\r\n \"20.41.66.160/27\",\r\n \"\ + 20.41.66.192/28\",\r\n \"20.41.193.176/28\",\r\n \"20.41.193.192/27\"\ + ,\r\n \"20.41.195.160/27\",\r\n \"20.41.208.0/30\",\r\n\ + \ \"20.42.4.204/30\",\r\n \"20.42.6.144/28\",\r\n \ + \ \"20.42.6.160/27\",\r\n \"20.42.7.128/27\",\r\n \"\ + 20.42.131.240/28\",\r\n \"20.42.227.144/28\",\r\n \"20.42.227.160/27\"\ + ,\r\n \"20.42.228.128/27\",\r\n \"20.42.230.80/28\",\r\n\ + \ \"20.43.42.16/28\",\r\n \"20.43.42.32/27\",\r\n \ + \ \"20.43.43.0/27\",\r\n \"20.43.66.16/28\",\r\n \"20.43.66.32/27\"\ + ,\r\n \"20.43.67.0/27\",\r\n \"20.43.70.64/28\",\r\n \ + \ \"20.43.88.240/32\",\r\n \"20.43.121.0/29\",\r\n \ + \ \"20.43.131.48/28\",\r\n \"20.43.132.0/27\",\r\n \"20.43.132.96/27\"\ + ,\r\n \"20.44.8.160/29\",\r\n \"20.44.17.16/29\",\r\n \ + \ \"20.44.19.32/28\",\r\n \"20.44.27.120/29\",\r\n \ + \ \"20.45.67.213/32\",\r\n \"20.45.112.224/27\",\r\n \"\ + 20.45.113.192/27\",\r\n \"20.45.113.224/28\",\r\n \"20.45.125.240/28\"\ + ,\r\n \"20.45.195.128/27\",\r\n \"20.45.195.224/27\",\r\n\ + \ \"20.45.196.0/28\",\r\n \"20.49.96.128/27\",\r\n \ + \ \"20.49.96.160/28\",\r\n \"20.49.99.16/28\",\r\n \"\ + 20.49.109.48/28\",\r\n \"20.50.1.16/28\",\r\n \"20.50.1.208/28\"\ + ,\r\n \"20.150.161.160/27\",\r\n \"20.150.164.128/27\",\r\ + \n \"20.150.164.160/28\",\r\n \"20.184.58.62/32\",\r\n \ + \ \"20.184.240.78/32\",\r\n \"20.184.241.66/32\",\r\n \ + \ \"20.184.241.238/32\",\r\n \"20.184.242.113/32\",\r\n \ + \ \"20.184.242.115/32\",\r\n \"20.184.242.189/32\",\r\n \ + \ \"20.189.108.64/27\",\r\n \"20.189.109.32/27\",\r\n \ + \ \"20.189.109.64/28\",\r\n \"20.192.161.144/28\",\r\n \ + \ \"20.192.161.160/27\",\r\n \"20.192.164.128/27\",\r\n \ + \ \"20.192.225.208/28\",\r\n \"20.192.225.224/27\",\r\n \ + \ \"20.192.228.192/27\",\r\n \"23.96.13.121/32\",\r\n \ + \ \"23.96.229.148/32\",\r\n \"23.97.152.121/32\",\r\n \"\ + 23.98.104.80/28\",\r\n \"23.100.0.32/32\",\r\n \"23.100.57.171/32\"\ + ,\r\n \"23.100.59.49/32\",\r\n \"23.102.65.134/32\",\r\n\ + \ \"40.64.128.192/27\",\r\n \"40.64.132.96/28\",\r\n \ + \ \"40.65.114.234/32\",\r\n \"40.67.48.224/27\",\r\n \ + \ \"40.67.49.192/27\",\r\n \"40.67.49.224/28\",\r\n \"\ + 40.67.121.128/28\",\r\n \"40.69.73.194/32\",\r\n \"40.69.104.32/30\"\ + ,\r\n \"40.70.47.165/32\",\r\n \"40.70.241.203/32\",\r\n\ + \ \"40.71.15.144/28\",\r\n \"40.74.30.108/30\",\r\n \ + \ \"40.74.31.64/27\",\r\n \"40.74.31.96/27\",\r\n \"\ + 40.74.64.203/32\",\r\n \"40.78.20.224/32\",\r\n \"40.78.204.0/29\"\ + ,\r\n \"40.78.239.48/28\",\r\n \"40.78.245.208/28\",\r\n\ + \ \"40.79.132.48/29\",\r\n \"40.79.156.64/27\",\r\n \ + \ \"40.79.176.32/30\",\r\n \"40.79.187.168/29\",\r\n \ + \ \"40.79.189.96/28\",\r\n \"40.80.53.16/28\",\r\n \"\ + 40.80.57.208/28\",\r\n \"40.80.57.224/27\",\r\n \"40.80.58.192/27\"\ + ,\r\n \"40.80.169.192/27\",\r\n \"40.80.170.160/27\",\r\n\ + \ \"40.80.170.192/28\",\r\n \"40.80.176.0/29\",\r\n \ + \ \"40.80.188.112/28\",\r\n \"40.80.190.128/27\",\r\n \ + \ \"40.80.190.224/27\",\r\n \"40.82.253.200/30\",\r\n \ + \ \"40.82.253.208/28\",\r\n \"40.82.255.0/26\",\r\n \"\ + 40.82.255.96/27\",\r\n \"40.84.132.239/32\",\r\n \"40.84.228.255/32\"\ + ,\r\n \"40.85.230.100/32\",\r\n \"40.86.227.247/32\",\r\n\ + \ \"40.89.17.240/28\",\r\n \"40.89.18.128/27\",\r\n \ + \ \"40.89.18.224/27\",\r\n \"40.89.133.209/32\",\r\n \ + \ \"40.89.134.214/32\",\r\n \"40.90.138.4/32\",\r\n \"\ + 40.90.139.2/32\",\r\n \"40.90.139.36/32\",\r\n \"40.90.139.163/32\"\ + ,\r\n \"40.90.141.99/32\",\r\n \"40.112.254.71/32\",\r\n\ + \ \"40.113.117.57/32\",\r\n \"40.113.124.208/32\",\r\n \ + \ \"40.113.194.60/32\",\r\n \"40.113.226.173/32\",\r\n \ + \ \"40.114.78.132/32\",\r\n \"40.114.236.251/32\",\r\n \ + \ \"40.115.248.103/32\",\r\n \"40.117.86.243/32\",\r\n \ + \ \"40.117.154.42/32\",\r\n \"40.117.232.90/32\",\r\n \ + \ \"40.117.237.78/32\",\r\n \"40.119.2.134/32\",\r\n \ + \ \"40.121.217.232/32\",\r\n \"40.122.42.111/32\",\r\n \"\ + 40.123.218.49/32\",\r\n \"40.127.76.4/32\",\r\n \"40.127.76.10/32\"\ + ,\r\n \"40.127.165.113/32\",\r\n \"51.12.41.48/28\",\r\n\ + \ \"51.12.41.128/27\",\r\n \"51.12.41.224/27\",\r\n \ + \ \"51.12.193.48/28\",\r\n \"51.12.193.128/27\",\r\n \ + \ \"51.12.193.224/27\",\r\n \"51.104.25.240/28\",\r\n \ + \ \"51.104.27.64/27\",\r\n \"51.104.28.32/27\",\r\n \"51.104.28.224/28\"\ + ,\r\n \"51.105.67.176/29\",\r\n \"51.105.80.224/27\",\r\n\ + \ \"51.105.81.192/27\",\r\n \"51.105.81.224/28\",\r\n \ + \ \"51.105.89.128/27\",\r\n \"51.105.89.224/27\",\r\n \ + \ \"51.105.90.0/28\",\r\n \"51.105.170.64/32\",\r\n \ + \ \"51.107.48.240/28\",\r\n \"51.107.49.128/27\",\r\n \"\ + 51.107.49.224/27\",\r\n \"51.107.144.224/27\",\r\n \"51.107.145.192/27\"\ + ,\r\n \"51.107.145.224/28\",\r\n \"51.116.48.144/28\",\r\ + \n \"51.116.48.160/27\",\r\n \"51.116.49.0/27\",\r\n \ + \ \"51.116.144.144/28\",\r\n \"51.116.144.160/27\",\r\n \ + \ \"51.116.145.0/27\",\r\n \"51.120.40.240/28\",\r\n \ + \ \"51.120.41.128/27\",\r\n \"51.120.41.224/27\",\r\n \ + \ \"51.120.224.224/27\",\r\n \"51.120.225.192/27\",\r\n \ + \ \"51.120.225.224/28\",\r\n \"51.124.95.46/32\",\r\n \"\ + 51.124.140.143/32\",\r\n \"51.137.162.128/27\",\r\n \"51.137.162.224/27\"\ + ,\r\n \"51.137.163.0/28\",\r\n \"51.138.40.194/32\",\r\n\ + \ \"51.138.41.75/32\",\r\n \"51.140.5.56/32\",\r\n \ + \ \"51.140.69.25/32\",\r\n \"51.140.105.165/32\",\r\n \ + \ \"51.140.138.84/32\",\r\n \"51.140.149.64/28\",\r\n \ + \ \"51.140.202.0/32\",\r\n \"51.143.192.224/27\",\r\n \"\ + 51.143.193.192/27\",\r\n \"51.143.193.224/28\",\r\n \"51.144.83.210/32\"\ + ,\r\n \"51.145.3.27/32\",\r\n \"51.145.21.195/32\",\r\n\ + \ \"52.136.48.240/28\",\r\n \"52.136.49.128/27\",\r\n \ + \ \"52.136.49.224/27\",\r\n \"52.138.41.171/32\",\r\n \ + \ \"52.138.92.172/30\",\r\n \"52.140.105.192/27\",\r\n \ + \ \"52.140.106.160/27\",\r\n \"52.140.106.192/28\",\r\n \ + \ \"52.140.107.112/28\",\r\n \"52.142.81.236/32\",\r\n \ + \ \"52.142.83.87/32\",\r\n \"52.142.84.66/32\",\r\n \"\ + 52.142.85.51/32\",\r\n \"52.143.91.192/28\",\r\n \"52.147.43.145/32\"\ + ,\r\n \"52.147.44.12/32\",\r\n \"52.147.97.4/30\",\r\n \ + \ \"52.149.31.64/28\",\r\n \"52.150.139.192/27\",\r\n \ + \ \"52.150.140.160/27\",\r\n \"52.150.140.192/28\",\r\n \ + \ \"52.150.152.16/28\",\r\n \"52.152.207.160/28\",\r\n \ + \ \"52.152.207.192/28\",\r\n \"52.155.218.251/32\",\r\n \ + \ \"52.156.93.240/28\",\r\n \"52.156.103.64/27\",\r\n \ + \ \"52.156.103.96/28\",\r\n \"52.161.16.73/32\",\r\n \ + \ \"52.161.101.86/32\",\r\n \"52.162.110.248/29\",\r\n \"\ + 52.163.56.146/32\",\r\n \"52.163.207.80/32\",\r\n \"52.171.134.140/32\"\ + ,\r\n \"52.172.187.21/32\",\r\n \"52.172.190.71/32\",\r\n\ + \ \"52.172.191.4/32\",\r\n \"52.173.240.242/32\",\r\n \ + \ \"52.174.60.141/32\",\r\n \"52.175.18.186/32\",\r\n \ + \ \"52.175.35.166/32\",\r\n \"52.179.13.227/32\",\r\n \ + \ \"52.179.14.109/32\",\r\n \"52.179.113.96/27\",\r\n \ + \ \"52.179.113.128/28\",\r\n \"52.180.162.194/32\",\r\n \ + \ \"52.180.166.172/32\",\r\n \"52.180.178.146/32\",\r\n \ + \ \"52.180.179.119/32\",\r\n \"52.183.33.203/32\",\r\n \ + \ \"52.186.33.48/28\",\r\n \"52.186.91.216/32\",\r\n \"\ + 52.187.20.181/32\",\r\n \"52.187.39.99/32\",\r\n \"52.190.33.56/32\"\ + ,\r\n \"52.190.33.61/32\",\r\n \"52.190.33.154/32\",\r\n\ + \ \"52.191.14.164/32\",\r\n \"52.191.173.81/32\",\r\n \ + \ \"52.224.200.129/32\",\r\n \"52.225.176.80/32\",\r\n \ + \ \"52.228.83.128/27\",\r\n \"52.228.83.224/27\",\r\n \ + \ \"52.228.84.0/28\",\r\n \"52.228.84.96/28\",\r\n \"\ + 52.229.16.14/32\",\r\n \"52.231.74.63/32\",\r\n \"52.231.79.142/32\"\ + ,\r\n \"52.231.159.35/32\",\r\n \"52.233.66.46/32\",\r\n\ + \ \"52.233.163.218/32\",\r\n \"52.234.229.248/32\",\r\n\ + \ \"52.237.137.4/32\",\r\n \"52.243.76.246/32\",\r\n \ + \ \"52.249.207.163/32\",\r\n \"52.255.83.208/28\",\r\n \ + \ \"52.255.84.176/28\",\r\n \"52.255.84.192/28\",\r\n \ + \ \"52.255.124.16/28\",\r\n \"52.255.124.80/28\",\r\n \ + \ \"52.255.124.96/28\",\r\n \"65.52.205.19/32\",\r\n \"\ + 65.52.252.208/29\",\r\n \"102.133.28.72/29\",\r\n \"102.133.56.144/28\"\ + ,\r\n \"102.133.56.224/27\",\r\n \"102.133.75.174/32\",\r\ + \n \"102.133.123.248/29\",\r\n \"102.133.124.88/29\",\r\n\ + \ \"102.133.156.128/29\",\r\n \"102.133.162.221/32\",\r\n\ + \ \"102.133.217.80/28\",\r\n \"102.133.217.96/27\",\r\n\ + \ \"102.133.218.0/27\",\r\n \"102.133.236.198/32\",\r\n\ + \ \"104.40.225.182/32\",\r\n \"104.41.216.228/32\",\r\n\ + \ \"104.42.100.80/32\",\r\n \"104.42.239.93/32\",\r\n \ + \ \"104.44.89.44/32\",\r\n \"104.46.112.239/32\",\r\n \ + \ \"104.46.239.137/32\",\r\n \"104.211.88.173/32\",\r\n \ + \ \"104.211.89.213/32\",\r\n \"104.211.101.116/32\",\r\n \ + \ \"104.211.222.193/32\",\r\n \"104.214.49.162/32\",\r\n \ + \ \"104.214.117.155/32\",\r\n \"104.214.233.86/32\",\r\n \ + \ \"104.215.9.217/32\",\r\n \"104.215.120.160/32\",\r\n \ + \ \"104.215.146.128/32\",\r\n \"137.116.247.179/32\",\r\n\ + \ \"137.117.70.195/32\",\r\n \"137.135.45.32/32\",\r\n \ + \ \"168.61.158.107/32\",\r\n \"168.61.165.229/32\",\r\n \ + \ \"168.63.20.177/32\",\r\n \"191.232.39.30/32\",\r\n \ + \ \"191.232.162.204/32\",\r\n \"191.233.10.48/28\",\r\n \ + \ \"191.233.10.64/27\",\r\n \"191.233.10.128/27\",\r\n \ + \ \"191.233.205.72/29\",\r\n \"191.235.227.128/27\",\r\n \ + \ \"191.235.227.224/27\",\r\n \"191.235.228.0/28\",\r\n \ + \ \"213.199.128.226/32\",\r\n \"2603:1000:104::180/122\",\r\ + \n \"2603:1000:104::380/122\",\r\n \"2603:1000:104:1::640/122\"\ + ,\r\n \"2603:1010:6::80/122\",\r\n \"2603:1010:6:1::640/122\"\ + ,\r\n \"2603:1020:5::80/122\",\r\n \"2603:1020:5:1::640/122\"\ + ,\r\n \"2603:1020:206::80/122\",\r\n \"2603:1020:206:1::640/122\"\ + ,\r\n \"2603:1020:705::80/122\",\r\n \"2603:1020:705:1::640/122\"\ + ,\r\n \"2603:1020:805::80/122\",\r\n \"2603:1020:805:1::640/122\"\ + ,\r\n \"2603:1020:a04::80/122\",\r\n \"2603:1020:a04:1::640/122\"\ + ,\r\n \"2603:1020:c04::80/122\",\r\n \"2603:1020:c04:1::640/122\"\ + ,\r\n \"2603:1020:e04::80/122\",\r\n \"2603:1020:e04:1::640/122\"\ + ,\r\n \"2603:1020:1004::640/122\",\r\n \"2603:1020:1004:1::80/122\"\ + ,\r\n \"2603:1030:10::80/122\",\r\n \"2603:1030:10:1::640/122\"\ + ,\r\n \"2603:1030:104::80/122\",\r\n \"2603:1030:104:1::640/122\"\ + ,\r\n \"2603:1030:210::80/122\",\r\n \"2603:1030:210:1::640/122\"\ + ,\r\n \"2603:1030:40b:1::640/122\",\r\n \"2603:1030:40c::80/122\"\ + ,\r\n \"2603:1030:40c:1::640/122\",\r\n \"2603:1030:504::80/122\"\ + ,\r\n \"2603:1030:504:1::640/122\",\r\n \"2603:1030:807::80/122\"\ + ,\r\n \"2603:1030:807:1::640/122\",\r\n \"2603:1030:c06:1::640/122\"\ + ,\r\n \"2603:1030:f05::80/122\",\r\n \"2603:1030:f05:1::640/122\"\ + ,\r\n \"2603:1040:5::180/122\",\r\n \"2603:1040:5:1::640/122\"\ + ,\r\n \"2603:1040:407::80/122\",\r\n \"2603:1040:407:1::640/122\"\ + ,\r\n \"2603:1040:904::80/122\",\r\n \"2603:1040:904:1::640/122\"\ + ,\r\n \"2603:1040:a06::180/122\",\r\n \"2603:1040:a06:1::640/122\"\ + ,\r\n \"2603:1040:d04::640/122\",\r\n \"2603:1040:d04:1::80/122\"\ + ,\r\n \"2603:1040:f05::80/122\",\r\n \"2603:1040:f05:1::640/122\"\ + ,\r\n \"2603:1050:6::80/122\",\r\n \"2603:1050:6:1::640/122\"\ + ,\r\n \"2603:1050:403::640/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactory\",\r\n \"id\": \"DataFactory\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.143.128/28\",\r\n \"13.67.10.208/28\",\r\ + \n \"13.69.67.192/28\",\r\n \"13.69.107.112/28\",\r\n \ + \ \"13.69.112.128/28\",\r\n \"13.69.230.96/28\",\r\n \ + \ \"13.70.74.144/28\",\r\n \"13.71.175.80/28\",\r\n \ + \ \"13.71.199.0/28\",\r\n \"13.73.244.32/28\",\r\n \"13.73.253.96/29\"\ + ,\r\n \"13.74.108.224/28\",\r\n \"13.75.39.112/28\",\r\n\ + \ \"13.77.53.160/28\",\r\n \"13.78.109.192/28\",\r\n \ + \ \"13.86.219.208/28\",\r\n \"13.89.174.192/28\",\r\n \ + \ \"13.104.248.64/27\",\r\n \"20.37.154.0/23\",\r\n \ + \ \"20.37.156.0/26\",\r\n \"20.37.193.0/25\",\r\n \"20.37.193.128/26\"\ + ,\r\n \"20.37.198.224/29\",\r\n \"20.38.80.192/26\",\r\n\ + \ \"20.38.82.0/23\",\r\n \"20.38.147.224/28\",\r\n \ + \ \"20.39.8.96/27\",\r\n \"20.39.8.128/26\",\r\n \"\ + 20.39.15.0/29\",\r\n \"20.40.206.224/29\",\r\n \"20.41.2.0/23\"\ + ,\r\n \"20.41.4.0/26\",\r\n \"20.41.64.128/25\",\r\n \ + \ \"20.41.65.0/26\",\r\n \"20.41.69.8/29\",\r\n \"\ + 20.41.192.128/25\",\r\n \"20.41.193.0/26\",\r\n \"20.41.197.112/29\"\ + ,\r\n \"20.41.198.0/25\",\r\n \"20.41.198.128/26\",\r\n\ + \ \"20.42.2.0/23\",\r\n \"20.42.4.0/26\",\r\n \"\ + 20.42.64.0/28\",\r\n \"20.42.129.64/26\",\r\n \"20.42.132.0/23\"\ + ,\r\n \"20.42.225.0/25\",\r\n \"20.42.225.128/26\",\r\n\ + \ \"20.42.230.136/29\",\r\n \"20.43.40.128/25\",\r\n \ + \ \"20.43.41.0/26\",\r\n \"20.43.44.208/29\",\r\n \ + \ \"20.43.64.128/25\",\r\n \"20.43.65.0/26\",\r\n \"20.43.70.120/29\"\ + ,\r\n \"20.43.121.48/28\",\r\n \"20.43.128.128/25\",\r\n\ + \ \"20.43.130.0/26\",\r\n \"20.44.10.64/28\",\r\n \ + \ \"20.44.17.80/28\",\r\n \"20.44.27.240/28\",\r\n \"\ + 20.45.123.160/28\",\r\n \"20.49.83.224/28\",\r\n \"20.49.102.16/29\"\ + ,\r\n \"20.49.111.0/29\",\r\n \"20.49.114.24/29\",\r\n \ + \ \"20.50.68.56/29\",\r\n \"20.150.162.0/23\",\r\n \ + \ \"20.150.173.16/28\",\r\n \"20.150.181.112/28\",\r\n \ + \ \"20.189.104.128/25\",\r\n \"20.189.106.0/26\",\r\n \ + \ \"20.189.109.232/29\",\r\n \"20.192.162.0/23\",\r\n \"\ + 20.192.184.96/28\",\r\n \"20.192.226.0/23\",\r\n \"20.192.238.96/28\"\ + ,\r\n \"20.194.67.192/28\",\r\n \"23.98.83.112/28\",\r\n\ + \ \"23.98.106.128/29\",\r\n \"40.64.132.232/29\",\r\n \ + \ \"40.69.108.160/28\",\r\n \"40.70.148.160/28\",\r\n \ + \ \"40.71.14.32/28\",\r\n \"40.74.24.192/26\",\r\n \ + \ \"40.74.26.0/23\",\r\n \"40.74.149.64/28\",\r\n \"40.75.35.144/28\"\ + ,\r\n \"40.78.196.128/28\",\r\n \"40.78.229.96/28\",\r\n\ + \ \"40.78.236.176/28\",\r\n \"40.78.245.16/28\",\r\n \ + \ \"40.78.251.192/28\",\r\n \"40.79.132.112/28\",\r\n \ + \ \"40.79.139.80/28\",\r\n \"40.79.146.240/28\",\r\n \ + \ \"40.79.163.80/28\",\r\n \"40.79.171.160/28\",\r\n \"\ + 40.79.187.208/28\",\r\n \"40.79.195.224/28\",\r\n \"40.80.51.160/28\"\ + ,\r\n \"40.80.56.128/25\",\r\n \"40.80.57.0/26\",\r\n \ + \ \"40.80.62.24/29\",\r\n \"40.80.168.128/25\",\r\n \ + \ \"40.80.169.0/26\",\r\n \"40.80.172.112/29\",\r\n \"\ + 40.80.176.96/28\",\r\n \"40.80.185.0/24\",\r\n \"40.80.186.0/25\"\ + ,\r\n \"40.82.249.64/26\",\r\n \"40.82.250.0/23\",\r\n \ + \ \"40.89.16.128/25\",\r\n \"40.89.17.0/26\",\r\n \ + \ \"40.89.20.224/29\",\r\n \"40.113.176.232/29\",\r\n \ + \ \"40.119.9.0/25\",\r\n \"40.119.9.128/26\",\r\n \"40.120.75.112/28\"\ + ,\r\n \"51.104.9.32/28\",\r\n \"51.104.24.128/25\",\r\n\ + \ \"51.104.25.0/26\",\r\n \"51.104.29.216/29\",\r\n \ + \ \"51.105.67.240/28\",\r\n \"51.105.75.240/28\",\r\n \ + \ \"51.107.51.40/29\",\r\n \"51.107.52.0/25\",\r\n \"\ + 51.107.52.128/26\",\r\n \"51.107.128.0/28\",\r\n \"51.116.245.112/28\"\ + ,\r\n \"51.116.253.48/28\",\r\n \"51.137.160.128/25\",\r\ + \n \"51.137.161.0/26\",\r\n \"51.137.164.192/29\",\r\n \ + \ \"51.140.212.112/28\",\r\n \"52.138.92.128/28\",\r\n \ + \ \"52.138.229.32/28\",\r\n \"52.140.104.128/25\",\r\n \ + \ \"52.140.105.0/26\",\r\n \"52.140.108.208/29\",\r\n \ + \ \"52.150.136.192/26\",\r\n \"52.150.137.128/25\",\r\n \ + \ \"52.150.154.16/29\",\r\n \"52.162.111.48/28\",\r\n \ + \ \"52.167.107.224/28\",\r\n \"52.182.141.16/28\",\r\n \ + \ \"52.228.80.128/25\",\r\n \"52.228.81.0/26\",\r\n \"\ + 52.228.86.144/29\",\r\n \"52.231.20.64/28\",\r\n \"52.231.148.160/28\"\ + ,\r\n \"52.236.187.112/28\",\r\n \"52.246.155.224/28\",\r\ + \n \"52.250.228.0/29\",\r\n \"102.133.124.104/29\",\r\n\ + \ \"102.133.156.136/29\",\r\n \"102.133.216.128/25\",\r\n\ + \ \"102.133.217.0/26\",\r\n \"102.133.218.248/29\",\r\n\ + \ \"102.133.251.184/29\",\r\n \"191.233.12.0/23\",\r\n \ + \ \"191.233.54.224/28\",\r\n \"191.233.205.160/28\",\r\n\ + \ \"191.234.137.32/29\",\r\n \"191.234.149.0/28\",\r\n \ + \ \"191.234.157.0/28\",\r\n \"191.235.224.128/25\",\r\n \ + \ \"191.235.225.0/26\",\r\n \"2603:1000:104::/121\",\r\n\ + \ \"2603:1000:104::80/122\",\r\n \"2603:1000:104::1c0/122\"\ + ,\r\n \"2603:1000:104::280/121\",\r\n \"2603:1000:104:1::480/121\"\ + ,\r\n \"2603:1000:104:1::500/122\",\r\n \"2603:1000:104:1::700/121\"\ + ,\r\n \"2603:1000:104:1::780/122\",\r\n \"2603:1010:6:1::480/121\"\ + ,\r\n \"2603:1010:6:1::500/122\",\r\n \"2603:1010:6:1::700/121\"\ + ,\r\n \"2603:1010:6:1::780/122\",\r\n \"2603:1020:5:1::480/121\"\ + ,\r\n \"2603:1020:5:1::500/122\",\r\n \"2603:1020:5:1::700/121\"\ + ,\r\n \"2603:1020:5:1::780/122\",\r\n \"2603:1020:206:1::480/121\"\ + ,\r\n \"2603:1020:206:1::500/122\",\r\n \"2603:1020:206:1::700/121\"\ + ,\r\n \"2603:1020:206:1::780/122\",\r\n \"2603:1020:705:1::480/121\"\ + ,\r\n \"2603:1020:705:1::500/122\",\r\n \"2603:1020:705:1::700/121\"\ + ,\r\n \"2603:1020:705:1::780/122\",\r\n \"2603:1020:805:1::480/121\"\ + ,\r\n \"2603:1020:805:1::500/122\",\r\n \"2603:1020:805:1::700/121\"\ + ,\r\n \"2603:1020:805:1::780/122\",\r\n \"2603:1020:a04:1::480/121\"\ + ,\r\n \"2603:1020:a04:1::500/122\",\r\n \"2603:1020:a04:1::700/121\"\ + ,\r\n \"2603:1020:a04:1::780/122\",\r\n \"2603:1020:c04:1::480/121\"\ + ,\r\n \"2603:1020:c04:1::500/122\",\r\n \"2603:1020:c04:1::700/121\"\ + ,\r\n \"2603:1020:c04:1::780/122\",\r\n \"2603:1020:e04:1::480/121\"\ + ,\r\n \"2603:1020:e04:1::500/122\",\r\n \"2603:1020:e04:1::700/121\"\ + ,\r\n \"2603:1020:e04:1::780/122\",\r\n \"2603:1020:1004::480/121\"\ + ,\r\n \"2603:1020:1004::500/122\",\r\n \"2603:1020:1004::700/121\"\ + ,\r\n \"2603:1020:1004::780/122\",\r\n \"2603:1030:10:1::480/121\"\ + ,\r\n \"2603:1030:10:1::500/122\",\r\n \"2603:1030:10:1::700/121\"\ + ,\r\n \"2603:1030:10:1::780/122\",\r\n \"2603:1030:104:1::480/121\"\ + ,\r\n \"2603:1030:104:1::500/122\",\r\n \"2603:1030:104:1::700/121\"\ + ,\r\n \"2603:1030:104:1::780/122\",\r\n \"2603:1030:210:1::480/121\"\ + ,\r\n \"2603:1030:210:1::500/122\",\r\n \"2603:1030:210:1::700/121\"\ + ,\r\n \"2603:1030:210:1::780/122\",\r\n \"2603:1030:40b:1::480/121\"\ + ,\r\n \"2603:1030:40b:1::500/122\",\r\n \"2603:1030:40c:1::480/121\"\ + ,\r\n \"2603:1030:40c:1::500/122\",\r\n \"2603:1030:40c:1::700/121\"\ + ,\r\n \"2603:1030:40c:1::780/122\",\r\n \"2603:1030:504:1::480/121\"\ + ,\r\n \"2603:1030:504:1::500/122\",\r\n \"2603:1030:504:1::700/121\"\ + ,\r\n \"2603:1030:504:1::780/122\",\r\n \"2603:1030:807:1::480/121\"\ + ,\r\n \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::700/121\"\ + ,\r\n \"2603:1030:807:1::780/122\",\r\n \"2603:1030:c06:1::480/121\"\ + ,\r\n \"2603:1030:c06:1::500/122\",\r\n \"2603:1030:f05:1::480/121\"\ + ,\r\n \"2603:1030:f05:1::500/122\",\r\n \"2603:1030:f05:1::700/121\"\ + ,\r\n \"2603:1030:f05:1::780/122\",\r\n \"2603:1040:5::/121\"\ + ,\r\n \"2603:1040:5::80/122\",\r\n \"2603:1040:5:1::480/121\"\ + ,\r\n \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::700/121\"\ + ,\r\n \"2603:1040:5:1::780/122\",\r\n \"2603:1040:407:1::480/121\"\ + ,\r\n \"2603:1040:407:1::500/122\",\r\n \"2603:1040:407:1::700/121\"\ + ,\r\n \"2603:1040:407:1::780/122\",\r\n \"2603:1040:904:1::480/121\"\ + ,\r\n \"2603:1040:904:1::500/122\",\r\n \"2603:1040:904:1::700/121\"\ + ,\r\n \"2603:1040:904:1::780/122\",\r\n \"2603:1040:a06::/121\"\ + ,\r\n \"2603:1040:a06::80/122\",\r\n \"2603:1040:a06:1::480/121\"\ + ,\r\n \"2603:1040:a06:1::500/122\",\r\n \"2603:1040:a06:1::700/121\"\ + ,\r\n \"2603:1040:a06:1::780/122\",\r\n \"2603:1040:d04::480/121\"\ + ,\r\n \"2603:1040:d04::500/122\",\r\n \"2603:1040:d04::700/121\"\ + ,\r\n \"2603:1040:d04::780/122\",\r\n \"2603:1040:f05:1::480/121\"\ + ,\r\n \"2603:1040:f05:1::500/122\",\r\n \"2603:1040:f05:1::700/121\"\ + ,\r\n \"2603:1040:f05:1::780/122\",\r\n \"2603:1050:6:1::480/121\"\ + ,\r\n \"2603:1050:6:1::500/122\",\r\n \"2603:1050:6:1::700/121\"\ + ,\r\n \"2603:1050:6:1::780/122\",\r\n \"2603:1050:403::480/121\"\ + ,\r\n \"2603:1050:403::500/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactory.AustraliaEast\",\r\n \"id\"\ + : \"DataFactory.AustraliaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiaeast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.74.144/28\",\r\n\ + \ \"20.37.193.0/25\",\r\n \"20.37.193.128/26\",\r\n \ + \ \"20.37.198.224/29\",\r\n \"40.79.163.80/28\",\r\n \ + \ \"40.79.171.160/28\",\r\n \"2603:1010:6:1::480/121\",\r\n \ + \ \"2603:1010:6:1::500/122\",\r\n \"2603:1010:6:1::700/121\"\ + ,\r\n \"2603:1010:6:1::780/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactory.AustraliaSoutheast\",\r\n \"\ + id\": \"DataFactory.AustraliaSoutheast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.77.53.160/28\"\ + ,\r\n \"20.42.225.0/25\",\r\n \"20.42.225.128/26\",\r\n\ + \ \"20.42.230.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"DataFactory.BrazilSouth\",\r\n \"id\": \"DataFactory.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"191.233.205.160/28\",\r\n \"191.234.137.32/29\"\ + ,\r\n \"191.234.149.0/28\",\r\n \"191.234.157.0/28\",\r\n\ + \ \"191.235.224.128/25\",\r\n \"191.235.225.0/26\",\r\n\ + \ \"2603:1050:6:1::480/121\",\r\n \"2603:1050:6:1::500/122\"\ + ,\r\n \"2603:1050:6:1::700/121\",\r\n \"2603:1050:6:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.CanadaCentral\"\ + ,\r\n \"id\": \"DataFactory.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.71.175.80/28\"\ + ,\r\n \"20.38.147.224/28\",\r\n \"52.228.80.128/25\",\r\n\ + \ \"52.228.81.0/26\",\r\n \"52.228.86.144/29\",\r\n \ + \ \"52.246.155.224/28\",\r\n \"2603:1030:f05:1::480/121\",\r\ + \n \"2603:1030:f05:1::500/122\",\r\n \"2603:1030:f05:1::700/121\"\ + ,\r\n \"2603:1030:f05:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.CanadaEast\",\r\n \"\ + id\": \"DataFactory.CanadaEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.69.108.160/28\",\r\n\ + \ \"40.89.16.128/25\",\r\n \"40.89.17.0/26\",\r\n \ + \ \"40.89.20.224/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"DataFactory.CentralIndia\",\r\n \"id\": \"DataFactory.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.43.121.48/28\",\r\n \"40.80.51.160/28\",\r\n\ + \ \"52.140.104.128/25\",\r\n \"52.140.105.0/26\",\r\n \ + \ \"52.140.108.208/29\",\r\n \"2603:1040:a06::/121\",\r\n\ + \ \"2603:1040:a06::80/122\",\r\n \"2603:1040:a06:1::480/121\"\ + ,\r\n \"2603:1040:a06:1::500/122\",\r\n \"2603:1040:a06:1::700/121\"\ + ,\r\n \"2603:1040:a06:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.CentralUS\",\r\n \"id\"\ + : \"DataFactory.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.89.174.192/28\",\r\n \ + \ \"20.37.154.0/23\",\r\n \"20.37.156.0/26\",\r\n \"\ + 20.40.206.224/29\",\r\n \"20.44.10.64/28\",\r\n \"52.182.141.16/28\"\ + ,\r\n \"2603:1030:10:1::480/121\",\r\n \"2603:1030:10:1::500/122\"\ + ,\r\n \"2603:1030:10:1::700/121\",\r\n \"2603:1030:10:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.EastAsia\"\ + ,\r\n \"id\": \"DataFactory.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.75.39.112/28\"\ + ,\r\n \"20.189.104.128/25\",\r\n \"20.189.106.0/26\",\r\n\ + \ \"20.189.109.232/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"DataFactory.EastUS\",\r\n \"id\": \"DataFactory.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.42.2.0/23\",\r\n \"20.42.4.0/26\",\r\n \"\ + 20.42.64.0/28\",\r\n \"20.49.111.0/29\",\r\n \"40.71.14.32/28\"\ + ,\r\n \"40.78.229.96/28\",\r\n \"2603:1030:210:1::480/121\"\ + ,\r\n \"2603:1030:210:1::500/122\",\r\n \"2603:1030:210:1::700/121\"\ + ,\r\n \"2603:1030:210:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.EastUS2\",\r\n \"id\"\ + : \"DataFactory.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.41.2.0/23\",\r\n \"\ + 20.41.4.0/26\",\r\n \"20.44.17.80/28\",\r\n \"20.49.102.16/29\"\ + ,\r\n \"40.70.148.160/28\",\r\n \"52.167.107.224/28\",\r\ + \n \"2603:1030:40c:1::480/121\",\r\n \"2603:1030:40c:1::500/122\"\ + ,\r\n \"2603:1030:40c:1::700/121\",\r\n \"2603:1030:40c:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.EastUS2EUAP\"\ + ,\r\n \"id\": \"DataFactory.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"20.39.8.96/27\"\ + ,\r\n \"20.39.8.128/26\",\r\n \"20.39.15.0/29\",\r\n \ + \ \"40.74.149.64/28\",\r\n \"40.75.35.144/28\",\r\n \ + \ \"52.138.92.128/28\",\r\n \"2603:1030:40b:1::480/121\",\r\n \ + \ \"2603:1030:40b:1::500/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactory.FranceCentral\",\r\n \"id\"\ + : \"DataFactory.FranceCentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"centralfrance\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.40.128/25\",\r\n\ + \ \"20.43.41.0/26\",\r\n \"20.43.44.208/29\",\r\n \ + \ \"40.79.132.112/28\",\r\n \"40.79.139.80/28\",\r\n \ + \ \"40.79.146.240/28\",\r\n \"2603:1020:805:1::480/121\",\r\n \ + \ \"2603:1020:805:1::500/122\",\r\n \"2603:1020:805:1::700/121\"\ + ,\r\n \"2603:1020:805:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.GermanyWestCentral\",\r\n\ + \ \"id\": \"DataFactory.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"51.116.245.112/28\"\ + ,\r\n \"51.116.253.48/28\",\r\n \"2603:1020:c04:1::480/121\"\ + ,\r\n \"2603:1020:c04:1::500/122\",\r\n \"2603:1020:c04:1::700/121\"\ + ,\r\n \"2603:1020:c04:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.JapanEast\",\r\n \"id\"\ + : \"DataFactory.JapanEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"japaneast\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.78.109.192/28\",\r\n \ + \ \"20.43.64.128/25\",\r\n \"20.43.65.0/26\",\r\n \"\ + 20.43.70.120/29\",\r\n \"40.79.187.208/28\",\r\n \"40.79.195.224/28\"\ + ,\r\n \"2603:1040:407:1::480/121\",\r\n \"2603:1040:407:1::500/122\"\ + ,\r\n \"2603:1040:407:1::700/121\",\r\n \"2603:1040:407:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.JapanWest\"\ + ,\r\n \"id\": \"DataFactory.JapanWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.80.56.128/25\"\ + ,\r\n \"40.80.57.0/26\",\r\n \"40.80.62.24/29\",\r\n \ + \ \"40.80.176.96/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"DataFactory.KoreaCentral\",\r\n \"id\": \"DataFactory.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.41.64.128/25\",\r\n \"20.41.65.0/26\",\r\n\ + \ \"20.41.69.8/29\",\r\n \"20.44.27.240/28\",\r\n \ + \ \"20.194.67.192/28\",\r\n \"52.231.20.64/28\",\r\n \ + \ \"2603:1040:f05:1::480/121\",\r\n \"2603:1040:f05:1::500/122\"\ + ,\r\n \"2603:1040:f05:1::700/121\",\r\n \"2603:1040:f05:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.KoreaSouth\"\ + ,\r\n \"id\": \"DataFactory.KoreaSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"40.80.168.128/25\"\ + ,\r\n \"40.80.169.0/26\",\r\n \"40.80.172.112/29\",\r\n\ + \ \"52.231.148.160/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"DataFactory.NorthCentralUS\",\r\n \"id\": \"\ + DataFactory.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.49.114.24/29\",\r\n\ + \ \"40.80.185.0/24\",\r\n \"40.80.186.0/25\",\r\n \ + \ \"52.162.111.48/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"DataFactory.NorthEurope\",\r\n \"id\": \"DataFactory.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.230.96/28\",\r\n \"13.74.108.224/28\",\r\ + \n \"20.38.80.192/26\",\r\n \"20.38.82.0/23\",\r\n \ + \ \"20.50.68.56/29\",\r\n \"52.138.229.32/28\",\r\n \ + \ \"2603:1020:5:1::480/121\",\r\n \"2603:1020:5:1::500/122\",\r\n\ + \ \"2603:1020:5:1::700/121\",\r\n \"2603:1020:5:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.NorwayEast\"\ + ,\r\n \"id\": \"DataFactory.NorwayEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"2603:1020:e04:1::480/121\"\ + ,\r\n \"2603:1020:e04:1::500/122\",\r\n \"2603:1020:e04:1::700/121\"\ + ,\r\n \"2603:1020:e04:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.SouthAfricaNorth\",\r\n \ + \ \"id\": \"DataFactory.SouthAfricaNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"102.133.124.104/29\"\ + ,\r\n \"102.133.156.136/29\",\r\n \"102.133.216.128/25\"\ + ,\r\n \"102.133.217.0/26\",\r\n \"102.133.218.248/29\",\r\ + \n \"102.133.251.184/29\",\r\n \"2603:1000:104::/121\",\r\ + \n \"2603:1000:104::80/122\",\r\n \"2603:1000:104::1c0/122\"\ + ,\r\n \"2603:1000:104::280/121\",\r\n \"2603:1000:104:1::480/121\"\ + ,\r\n \"2603:1000:104:1::500/122\",\r\n \"2603:1000:104:1::700/121\"\ + ,\r\n \"2603:1000:104:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.SouthCentralUS\",\r\n \ + \ \"id\": \"DataFactory.SouthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.73.244.32/28\"\ + ,\r\n \"13.73.253.96/29\",\r\n \"13.104.248.64/27\",\r\n\ + \ \"20.45.123.160/28\",\r\n \"40.119.9.0/25\",\r\n \ + \ \"40.119.9.128/26\",\r\n \"2603:1030:807:1::480/121\",\r\n\ + \ \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::700/121\"\ + ,\r\n \"2603:1030:807:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.SoutheastAsia\",\r\n \ + \ \"id\": \"DataFactory.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.67.10.208/28\"\ + ,\r\n \"20.43.128.128/25\",\r\n \"20.43.130.0/26\",\r\n\ + \ \"23.98.83.112/28\",\r\n \"23.98.106.128/29\",\r\n \ + \ \"40.78.236.176/28\",\r\n \"2603:1040:5::/121\",\r\n \ + \ \"2603:1040:5::80/122\",\r\n \"2603:1040:5:1::480/121\",\r\ + \n \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::700/121\"\ + ,\r\n \"2603:1040:5:1::780/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactory.SouthIndia\",\r\n \"id\": \"\ + DataFactory.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.41.192.128/25\",\r\n \ + \ \"20.41.193.0/26\",\r\n \"20.41.197.112/29\",\r\n \"\ + 20.41.198.0/25\",\r\n \"20.41.198.128/26\",\r\n \"20.192.184.96/28\"\ + ,\r\n \"40.78.196.128/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"DataFactory.SwitzerlandNorth\",\r\n \"id\"\ + : \"DataFactory.SwitzerlandNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + DataFactory\",\r\n \"addressPrefixes\": [\r\n \"51.107.51.40/29\"\ + ,\r\n \"51.107.52.0/25\",\r\n \"51.107.52.128/26\",\r\n\ + \ \"51.107.128.0/28\",\r\n \"2603:1020:a04:1::480/121\"\ + ,\r\n \"2603:1020:a04:1::500/122\",\r\n \"2603:1020:a04:1::700/121\"\ + ,\r\n \"2603:1020:a04:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.UAENorth\",\r\n \"id\"\ + : \"DataFactory.UAENorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uaenorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.120.75.112/28\",\r\n \ + \ \"2603:1040:904:1::480/121\",\r\n \"2603:1040:904:1::500/122\"\ + ,\r\n \"2603:1040:904:1::700/121\",\r\n \"2603:1040:904:1::780/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.UKSouth\"\ + ,\r\n \"id\": \"DataFactory.UKSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"51.104.9.32/28\"\ + ,\r\n \"51.104.24.128/25\",\r\n \"51.104.25.0/26\",\r\n\ + \ \"51.104.29.216/29\",\r\n \"51.105.67.240/28\",\r\n \ + \ \"51.105.75.240/28\",\r\n \"2603:1020:705:1::480/121\",\r\ + \n \"2603:1020:705:1::500/122\",\r\n \"2603:1020:705:1::700/121\"\ + ,\r\n \"2603:1020:705:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.UKWest\",\r\n \"id\"\ + : \"DataFactory.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \"\ + addressPrefixes\": [\r\n \"51.137.160.128/25\",\r\n \"51.137.161.0/26\"\ + ,\r\n \"51.137.164.192/29\",\r\n \"51.140.212.112/28\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.WestCentralUS\"\ + ,\r\n \"id\": \"DataFactory.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.71.199.0/28\"\ + ,\r\n \"52.150.136.192/26\",\r\n \"52.150.137.128/25\",\r\ + \n \"52.150.154.16/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"DataFactory.WestEurope\",\r\n \"id\": \"DataFactory.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"DataFactory\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.67.192/28\",\r\n \"13.69.107.112/28\",\r\ + \n \"13.69.112.128/28\",\r\n \"40.74.24.192/26\",\r\n \ + \ \"40.74.26.0/23\",\r\n \"40.113.176.232/29\",\r\n \ + \ \"52.236.187.112/28\",\r\n \"2603:1020:206:1::480/121\",\r\n\ + \ \"2603:1020:206:1::500/122\",\r\n \"2603:1020:206:1::700/121\"\ + ,\r\n \"2603:1020:206:1::780/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"DataFactory.WestUS\",\r\n \"id\"\ + : \"DataFactory.WestUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westus\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"DataFactory\",\r\n \"\ + addressPrefixes\": [\r\n \"13.86.219.208/28\",\r\n \"40.82.249.64/26\"\ + ,\r\n \"40.82.250.0/23\",\r\n \"52.250.228.0/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"DataFactory.WestUS2\"\ + ,\r\n \"id\": \"DataFactory.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"DataFactory\",\r\n \"addressPrefixes\": [\r\n \"13.66.143.128/28\"\ + ,\r\n \"20.42.129.64/26\",\r\n \"20.42.132.0/23\",\r\n \ + \ \"40.64.132.232/29\",\r\n \"40.78.245.16/28\",\r\n \ + \ \"40.78.251.192/28\",\r\n \"2603:1030:c06:1::480/121\",\r\n\ + \ \"2603:1030:c06:1::500/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"DataFactoryManagement\",\r\n \"id\": \"\ + DataFactoryManagement\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"FW\"\r\n ],\r\n \"systemService\": \"DataFactory\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.143.128/28\",\r\n\ + \ \"13.67.10.208/28\",\r\n \"13.69.67.192/28\",\r\n \ + \ \"13.69.107.112/28\",\r\n \"13.69.112.128/28\",\r\n \ + \ \"13.69.230.96/28\",\r\n \"13.70.74.144/28\",\r\n \"\ + 13.71.175.80/28\",\r\n \"13.71.199.0/28\",\r\n \"13.73.244.32/28\"\ + ,\r\n \"13.73.253.96/29\",\r\n \"13.74.108.224/28\",\r\n\ + \ \"13.75.39.112/28\",\r\n \"13.77.53.160/28\",\r\n \ + \ \"13.78.109.192/28\",\r\n \"13.86.219.208/28\",\r\n \ + \ \"13.89.174.192/28\",\r\n \"13.104.248.64/27\",\r\n \ + \ \"20.37.198.224/29\",\r\n \"20.38.147.224/28\",\r\n \"\ + 20.39.15.0/29\",\r\n \"20.40.206.224/29\",\r\n \"20.41.69.8/29\"\ + ,\r\n \"20.41.197.112/29\",\r\n \"20.42.64.0/28\",\r\n \ + \ \"20.42.230.136/29\",\r\n \"20.43.44.208/29\",\r\n \ + \ \"20.43.70.120/29\",\r\n \"20.43.121.48/28\",\r\n \ + \ \"20.44.10.64/28\",\r\n \"20.44.17.80/28\",\r\n \"20.44.27.240/28\"\ + ,\r\n \"20.45.123.160/28\",\r\n \"20.49.83.224/28\",\r\n\ + \ \"20.49.102.16/29\",\r\n \"20.49.111.0/29\",\r\n \ + \ \"20.49.114.24/29\",\r\n \"20.50.68.56/29\",\r\n \"\ + 20.150.173.16/28\",\r\n \"20.150.181.112/28\",\r\n \"20.189.109.232/29\"\ + ,\r\n \"20.192.184.96/28\",\r\n \"20.192.238.96/28\",\r\n\ + \ \"20.194.67.192/28\",\r\n \"23.98.83.112/28\",\r\n \ + \ \"23.98.106.128/29\",\r\n \"40.64.132.232/29\",\r\n \ + \ \"40.69.108.160/28\",\r\n \"40.70.148.160/28\",\r\n \ + \ \"40.71.14.32/28\",\r\n \"40.74.149.64/28\",\r\n \"\ + 40.75.35.144/28\",\r\n \"40.78.196.128/28\",\r\n \"40.78.229.96/28\"\ + ,\r\n \"40.78.236.176/28\",\r\n \"40.78.245.16/28\",\r\n\ + \ \"40.78.251.192/28\",\r\n \"40.79.132.112/28\",\r\n \ + \ \"40.79.139.80/28\",\r\n \"40.79.146.240/28\",\r\n \ + \ \"40.79.163.80/28\",\r\n \"40.79.171.160/28\",\r\n \ + \ \"40.79.187.208/28\",\r\n \"40.79.195.224/28\",\r\n \"\ + 40.80.51.160/28\",\r\n \"40.80.62.24/29\",\r\n \"40.80.172.112/29\"\ + ,\r\n \"40.80.176.96/28\",\r\n \"40.89.20.224/29\",\r\n\ + \ \"40.113.176.232/29\",\r\n \"40.120.75.112/28\",\r\n \ + \ \"51.104.9.32/28\",\r\n \"51.104.29.216/29\",\r\n \ + \ \"51.105.67.240/28\",\r\n \"51.105.75.240/28\",\r\n \ + \ \"51.107.51.40/29\",\r\n \"51.107.128.0/28\",\r\n \"\ + 51.116.245.112/28\",\r\n \"51.116.253.48/28\",\r\n \"51.137.164.192/29\"\ + ,\r\n \"51.140.212.112/28\",\r\n \"52.138.92.128/28\",\r\ + \n \"52.138.229.32/28\",\r\n \"52.140.108.208/29\",\r\n\ + \ \"52.150.154.16/29\",\r\n \"52.162.111.48/28\",\r\n \ + \ \"52.167.107.224/28\",\r\n \"52.182.141.16/28\",\r\n \ + \ \"52.228.86.144/29\",\r\n \"52.231.20.64/28\",\r\n \ + \ \"52.231.148.160/28\",\r\n \"52.236.187.112/28\",\r\n \ + \ \"52.246.155.224/28\",\r\n \"52.250.228.0/29\",\r\n \ + \ \"102.133.124.104/29\",\r\n \"102.133.156.136/29\",\r\n \ + \ \"102.133.218.248/29\",\r\n \"102.133.251.184/29\",\r\n \ + \ \"191.233.54.224/28\",\r\n \"191.233.205.160/28\",\r\n \ + \ \"191.234.137.32/29\",\r\n \"191.234.149.0/28\",\r\n \ + \ \"191.234.157.0/28\",\r\n \"2603:1000:104::80/122\",\r\n \ + \ \"2603:1000:104::1c0/122\",\r\n \"2603:1000:104:1::500/122\"\ + ,\r\n \"2603:1000:104:1::780/122\",\r\n \"2603:1010:6:1::500/122\"\ + ,\r\n \"2603:1010:6:1::780/122\",\r\n \"2603:1020:5:1::500/122\"\ + ,\r\n \"2603:1020:5:1::780/122\",\r\n \"2603:1020:206:1::500/122\"\ + ,\r\n \"2603:1020:206:1::780/122\",\r\n \"2603:1020:705:1::500/122\"\ + ,\r\n \"2603:1020:705:1::780/122\",\r\n \"2603:1020:805:1::500/122\"\ + ,\r\n \"2603:1020:805:1::780/122\",\r\n \"2603:1020:a04:1::500/122\"\ + ,\r\n \"2603:1020:a04:1::780/122\",\r\n \"2603:1020:c04:1::500/122\"\ + ,\r\n \"2603:1020:c04:1::780/122\",\r\n \"2603:1020:e04:1::500/122\"\ + ,\r\n \"2603:1020:e04:1::780/122\",\r\n \"2603:1020:1004::500/122\"\ + ,\r\n \"2603:1020:1004::780/122\",\r\n \"2603:1030:10:1::500/122\"\ + ,\r\n \"2603:1030:10:1::780/122\",\r\n \"2603:1030:104:1::500/122\"\ + ,\r\n \"2603:1030:104:1::780/122\",\r\n \"2603:1030:210:1::500/122\"\ + ,\r\n \"2603:1030:210:1::780/122\",\r\n \"2603:1030:40b:1::500/122\"\ + ,\r\n \"2603:1030:40c:1::500/122\",\r\n \"2603:1030:40c:1::780/122\"\ + ,\r\n \"2603:1030:504:1::500/122\",\r\n \"2603:1030:504:1::780/122\"\ + ,\r\n \"2603:1030:807:1::500/122\",\r\n \"2603:1030:807:1::780/122\"\ + ,\r\n \"2603:1030:c06:1::500/122\",\r\n \"2603:1030:f05:1::500/122\"\ + ,\r\n \"2603:1030:f05:1::780/122\",\r\n \"2603:1040:5::80/122\"\ + ,\r\n \"2603:1040:5:1::500/122\",\r\n \"2603:1040:5:1::780/122\"\ + ,\r\n \"2603:1040:407:1::500/122\",\r\n \"2603:1040:407:1::780/122\"\ + ,\r\n \"2603:1040:904:1::500/122\",\r\n \"2603:1040:904:1::780/122\"\ + ,\r\n \"2603:1040:a06::80/122\",\r\n \"2603:1040:a06:1::500/122\"\ + ,\r\n \"2603:1040:a06:1::780/122\",\r\n \"2603:1040:d04::500/122\"\ + ,\r\n \"2603:1040:d04::780/122\",\r\n \"2603:1040:f05:1::500/122\"\ + ,\r\n \"2603:1040:f05:1::780/122\",\r\n \"2603:1050:6:1::500/122\"\ + ,\r\n \"2603:1050:6:1::780/122\",\r\n \"2603:1050:403::500/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail\"\ + ,\r\n \"id\": \"Dynamics365ForMarketingEmail\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \ + \ \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.138.128/25\",\r\n \"13.69.226.128/25\",\r\ + \n \"13.71.171.0/24\",\r\n \"13.74.106.128/25\",\r\n \ + \ \"13.75.35.0/24\",\r\n \"13.77.51.0/24\",\r\n \"\ + 13.78.107.0/24\",\r\n \"40.78.242.0/25\",\r\n \"40.79.138.192/26\"\ + ,\r\n \"51.140.147.0/24\",\r\n \"65.52.252.128/27\",\r\n\ + \ \"102.133.251.96/27\",\r\n \"104.211.80.0/24\",\r\n \ + \ \"191.233.202.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.AustraliaSoutheast\",\r\n\ + \ \"id\": \"Dynamics365ForMarketingEmail.AustraliaSoutheast\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.51.0/24\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Dynamics365ForMarketingEmail.BrazilSouth\",\r\n\ + \ \"id\": \"Dynamics365ForMarketingEmail.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"191.233.202.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.CanadaCentral\",\r\n \ + \ \"id\": \"Dynamics365ForMarketingEmail.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.71.171.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.CentralIndia\",\r\n \ + \ \"id\": \"Dynamics365ForMarketingEmail.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"104.211.80.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.EastAsia\",\r\n \"id\"\ + : \"Dynamics365ForMarketingEmail.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.75.35.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Dynamics365ForMarketingEmail.FranceCentral\",\r\n \ + \ \"id\": \"Dynamics365ForMarketingEmail.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.79.138.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.JapanEast\",\r\n \"\ + id\": \"Dynamics365ForMarketingEmail.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.78.107.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.NorthEurope\",\r\n \"\ + id\": \"Dynamics365ForMarketingEmail.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.69.226.128/25\",\r\n \"13.74.106.128/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.SouthAfricaNorth\"\ + ,\r\n \"id\": \"Dynamics365ForMarketingEmail.SouthAfricaNorth\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"Dynamics365ForMarketingEmail\",\r\n\ + \ \"addressPrefixes\": [\r\n \"102.133.251.96/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Dynamics365ForMarketingEmail.UAENorth\"\ + ,\r\n \"id\": \"Dynamics365ForMarketingEmail.UAENorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\"\ + : [\r\n \"65.52.252.128/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"Dynamics365ForMarketingEmail.UKSouth\",\r\n \ + \ \"id\": \"Dynamics365ForMarketingEmail.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.140.147.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Dynamics365ForMarketingEmail.WestUS2\",\r\n \"id\"\ + : \"Dynamics365ForMarketingEmail.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"Dynamics365ForMarketingEmail\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.66.138.128/25\",\r\n \"40.78.242.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub\",\r\n \ + \ \"id\": \"EventHub\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.64.195.117/32\"\ + ,\r\n \"13.65.209.24/32\",\r\n \"13.66.138.64/28\",\r\n\ + \ \"13.66.145.128/26\",\r\n \"13.66.228.204/32\",\r\n \ + \ \"13.66.230.42/32\",\r\n \"13.67.8.64/27\",\r\n \ + \ \"13.68.20.101/32\",\r\n \"13.68.21.169/32\",\r\n \"\ + 13.68.77.215/32\",\r\n \"13.69.64.0/26\",\r\n \"13.69.106.0/26\"\ + ,\r\n \"13.69.227.0/26\",\r\n \"13.69.253.135/32\",\r\n\ + \ \"13.69.255.140/32\",\r\n \"13.70.72.0/28\",\r\n \ + \ \"13.70.79.16/28\",\r\n \"13.71.30.214/32\",\r\n \"\ + 13.71.123.78/32\",\r\n \"13.71.154.11/32\",\r\n \"13.71.170.16/28\"\ + ,\r\n \"13.71.194.64/27\",\r\n \"13.72.254.134/32\",\r\n\ + \ \"13.74.107.0/26\",\r\n \"13.75.34.64/26\",\r\n \ + \ \"13.76.179.223/32\",\r\n \"13.76.216.217/32\",\r\n \ + \ \"13.77.50.32/27\",\r\n \"13.78.106.64/28\",\r\n \"13.78.149.209/32\"\ + ,\r\n \"13.78.150.233/32\",\r\n \"13.78.191.44/32\",\r\n\ + \ \"13.84.145.196/32\",\r\n \"13.87.34.139/32\",\r\n \ + \ \"13.87.34.243/32\",\r\n \"13.87.56.32/27\",\r\n \ + \ \"13.87.102.63/32\",\r\n \"13.87.102.68/32\",\r\n \"\ + 13.87.122.32/27\",\r\n \"13.88.20.117/32\",\r\n \"13.88.26.28/32\"\ + ,\r\n \"13.89.58.37/32\",\r\n \"13.89.59.231/32\",\r\n \ + \ \"13.89.170.128/26\",\r\n \"13.90.83.7/32\",\r\n \ + \ \"13.90.208.184/32\",\r\n \"13.91.61.11/32\",\r\n \"\ + 13.92.124.151/32\",\r\n \"13.92.180.208/32\",\r\n \"13.92.190.184/32\"\ + ,\r\n \"13.93.226.138/32\",\r\n \"13.94.47.61/32\",\r\n\ + \ \"20.36.46.142/32\",\r\n \"20.36.74.130/32\",\r\n \ + \ \"20.36.106.192/27\",\r\n \"20.36.114.32/27\",\r\n \ + \ \"20.37.74.0/27\",\r\n \"20.38.146.64/26\",\r\n \"20.42.131.16/28\"\ + ,\r\n \"20.42.131.64/26\",\r\n \"20.44.2.128/26\",\r\n \ + \ \"20.44.26.64/26\",\r\n \"20.45.122.64/26\",\r\n \ + \ \"20.150.160.224/27\",\r\n \"20.150.170.160/27\",\r\n \ + \ \"20.150.178.64/26\",\r\n \"20.150.186.64/26\",\r\n \ + \ \"20.192.98.64/26\",\r\n \"20.192.161.64/27\",\r\n \"\ + 20.192.225.160/27\",\r\n \"20.192.234.32/27\",\r\n \"20.193.202.32/27\"\ + ,\r\n \"23.96.214.181/32\",\r\n \"23.96.253.236/32\",\r\n\ + \ \"23.97.67.90/32\",\r\n \"23.97.97.36/32\",\r\n \ + \ \"23.97.103.3/32\",\r\n \"23.97.226.21/32\",\r\n \"\ + 23.98.64.92/32\",\r\n \"23.98.65.24/32\",\r\n \"23.98.82.64/27\"\ + ,\r\n \"23.99.7.105/32\",\r\n \"23.99.54.235/32\",\r\n \ + \ \"23.99.60.253/32\",\r\n \"23.99.80.186/32\",\r\n \ + \ \"23.99.118.48/32\",\r\n \"23.99.128.69/32\",\r\n \ + \ \"23.99.129.170/32\",\r\n \"23.99.192.254/32\",\r\n \"\ + 23.99.196.56/32\",\r\n \"23.99.228.174/32\",\r\n \"23.100.14.185/32\"\ + ,\r\n \"23.100.100.84/32\",\r\n \"23.101.3.68/32\",\r\n\ + \ \"23.101.8.229/32\",\r\n \"23.102.0.186/32\",\r\n \ + \ \"23.102.0.239/32\",\r\n \"23.102.53.113/32\",\r\n \ + \ \"23.102.128.15/32\",\r\n \"23.102.160.39/32\",\r\n \ + \ \"23.102.161.227/32\",\r\n \"23.102.163.4/32\",\r\n \"\ + 23.102.165.127/32\",\r\n \"23.102.167.73/32\",\r\n \"23.102.180.26/32\"\ + ,\r\n \"23.102.234.49/32\",\r\n \"40.67.58.128/26\",\r\n\ + \ \"40.68.35.230/32\",\r\n \"40.68.39.15/32\",\r\n \ + \ \"40.68.93.145/32\",\r\n \"40.68.205.113/32\",\r\n \ + \ \"40.68.217.242/32\",\r\n \"40.69.29.216/32\",\r\n \"\ + 40.69.106.32/27\",\r\n \"40.69.217.246/32\",\r\n \"40.70.78.154/32\"\ + ,\r\n \"40.70.146.0/26\",\r\n \"40.71.10.128/26\",\r\n \ + \ \"40.71.100.98/32\",\r\n \"40.74.100.0/27\",\r\n \ + \ \"40.74.141.187/32\",\r\n \"40.74.146.16/28\",\r\n \ + \ \"40.75.34.0/28\",\r\n \"40.76.29.197/32\",\r\n \"40.76.40.11/32\"\ + ,\r\n \"40.76.194.119/32\",\r\n \"40.78.110.196/32\",\r\n\ + \ \"40.78.194.32/27\",\r\n \"40.78.202.32/27\",\r\n \ + \ \"40.78.226.128/26\",\r\n \"40.78.234.0/27\",\r\n \ + \ \"40.78.242.128/28\",\r\n \"40.78.247.0/26\",\r\n \"\ + 40.78.250.64/28\",\r\n \"40.78.253.128/26\",\r\n \"40.79.44.59/32\"\ + ,\r\n \"40.79.74.86/32\",\r\n \"40.79.130.16/28\",\r\n \ + \ \"40.79.138.0/28\",\r\n \"40.79.146.0/28\",\r\n \ + \ \"40.79.155.0/26\",\r\n \"40.79.162.0/28\",\r\n \"40.79.170.32/28\"\ + ,\r\n \"40.79.178.32/27\",\r\n \"40.79.186.32/27\",\r\n\ + \ \"40.79.194.192/26\",\r\n \"40.80.50.64/26\",\r\n \ + \ \"40.83.191.202/32\",\r\n \"40.83.222.100/32\",\r\n \ + \ \"40.84.150.241/32\",\r\n \"40.84.185.67/32\",\r\n \ + \ \"40.85.226.62/32\",\r\n \"40.85.229.32/32\",\r\n \"40.86.77.12/32\"\ + ,\r\n \"40.86.102.100/32\",\r\n \"40.86.176.23/32\",\r\n\ + \ \"40.86.225.142/32\",\r\n \"40.86.230.119/32\",\r\n \ + \ \"40.112.185.115/32\",\r\n \"40.112.213.11/32\",\r\n \ + \ \"40.112.242.0/25\",\r\n \"40.115.79.2/32\",\r\n \ + \ \"40.117.88.66/32\",\r\n \"40.120.75.64/27\",\r\n \"\ + 40.121.84.50/32\",\r\n \"40.121.141.232/32\",\r\n \"40.121.148.193/32\"\ + ,\r\n \"40.122.173.108/32\",\r\n \"40.122.213.155/32\",\r\ + \n \"40.127.83.123/32\",\r\n \"40.127.132.254/32\",\r\n\ + \ \"51.12.98.160/27\",\r\n \"51.12.202.160/27\",\r\n \ + \ \"51.12.226.64/26\",\r\n \"51.12.234.64/26\",\r\n \ + \ \"51.105.66.64/26\",\r\n \"51.105.74.64/26\",\r\n \"\ + 51.107.58.128/27\",\r\n \"51.107.154.128/27\",\r\n \"51.116.58.128/27\"\ + ,\r\n \"51.116.154.192/27\",\r\n \"51.116.242.64/26\",\r\ + \n \"51.116.245.192/27\",\r\n \"51.116.250.64/26\",\r\n\ + \ \"51.120.98.128/27\",\r\n \"51.120.106.64/26\",\r\n \ + \ \"51.120.210.64/26\",\r\n \"51.120.218.160/27\",\r\n \ + \ \"51.140.80.99/32\",\r\n \"51.140.87.93/32\",\r\n \ + \ \"51.140.125.8/32\",\r\n \"51.140.146.32/28\",\r\n \"\ + 51.140.189.52/32\",\r\n \"51.140.189.108/32\",\r\n \"51.140.210.32/27\"\ + ,\r\n \"51.141.14.113/32\",\r\n \"51.141.14.168/32\",\r\n\ + \ \"51.141.50.179/32\",\r\n \"51.144.238.23/32\",\r\n \ + \ \"52.136.136.62/32\",\r\n \"52.138.90.0/28\",\r\n \ + \ \"52.138.147.148/32\",\r\n \"52.138.226.0/26\",\r\n \ + \ \"52.143.136.55/32\",\r\n \"52.151.58.121/32\",\r\n \"\ + 52.161.19.160/32\",\r\n \"52.161.24.64/32\",\r\n \"52.162.106.64/26\"\ + ,\r\n \"52.165.34.144/32\",\r\n \"52.165.179.109/32\",\r\ + \n \"52.165.235.119/32\",\r\n \"52.165.237.8/32\",\r\n \ + \ \"52.167.106.0/26\",\r\n \"52.168.14.144/32\",\r\n \ + \ \"52.168.66.180/32\",\r\n \"52.168.146.69/32\",\r\n \ + \ \"52.168.147.11/32\",\r\n \"52.169.18.8/32\",\r\n \"\ + 52.172.221.245/32\",\r\n \"52.172.223.211/32\",\r\n \"52.173.199.106/32\"\ + ,\r\n \"52.174.243.57/32\",\r\n \"52.175.35.235/32\",\r\n\ + \ \"52.176.47.198/32\",\r\n \"52.178.78.61/32\",\r\n \ + \ \"52.178.211.227/32\",\r\n \"52.179.6.240/32\",\r\n \ + \ \"52.179.8.35/32\",\r\n \"52.179.157.59/32\",\r\n \ + \ \"52.180.180.228/32\",\r\n \"52.180.182.75/32\",\r\n \"\ + 52.182.138.128/26\",\r\n \"52.183.46.73/32\",\r\n \"52.183.86.102/32\"\ + ,\r\n \"52.187.2.226/32\",\r\n \"52.187.59.188/32\",\r\n\ + \ \"52.187.61.82/32\",\r\n \"52.187.185.159/32\",\r\n \ + \ \"52.191.213.188/32\",\r\n \"52.225.184.224/32\",\r\n \ + \ \"52.225.186.130/32\",\r\n \"52.226.36.235/32\",\r\n \ + \ \"52.231.18.16/28\",\r\n \"52.231.29.105/32\",\r\n \ + \ \"52.231.32.85/32\",\r\n \"52.231.32.94/32\",\r\n \"\ + 52.231.146.32/27\",\r\n \"52.231.200.144/32\",\r\n \"52.231.200.153/32\"\ + ,\r\n \"52.231.207.155/32\",\r\n \"52.232.27.189/32\",\r\ + \n \"52.233.30.41/32\",\r\n \"52.233.190.35/32\",\r\n \ + \ \"52.233.192.247/32\",\r\n \"52.236.186.0/26\",\r\n \ + \ \"52.237.33.36/32\",\r\n \"52.237.33.104/32\",\r\n \ + \ \"52.237.143.176/32\",\r\n \"52.242.20.204/32\",\r\n \ + \ \"52.243.36.161/32\",\r\n \"52.246.154.64/26\",\r\n \"\ + 65.52.129.16/32\",\r\n \"65.52.250.32/27\",\r\n \"102.133.26.128/26\"\ + ,\r\n \"102.133.122.64/26\",\r\n \"102.133.154.128/26\"\ + ,\r\n \"102.133.250.64/26\",\r\n \"104.40.26.199/32\",\r\ + \n \"104.40.29.113/32\",\r\n \"104.40.68.250/32\",\r\n \ + \ \"104.40.69.64/32\",\r\n \"104.40.150.139/32\",\r\n \ + \ \"104.40.179.185/32\",\r\n \"104.40.216.174/32\",\r\n \ + \ \"104.41.63.213/32\",\r\n \"104.41.201.10/32\",\r\n \ + \ \"104.42.97.95/32\",\r\n \"104.43.18.219/32\",\r\n \ + \ \"104.43.168.200/32\",\r\n \"104.43.192.43/32\",\r\n \ + \ \"104.43.192.222/32\",\r\n \"104.44.129.14/32\",\r\n \"\ + 104.44.129.59/32\",\r\n \"104.45.135.34/32\",\r\n \"104.45.147.24/32\"\ + ,\r\n \"104.46.32.56/32\",\r\n \"104.46.32.58/32\",\r\n\ + \ \"104.46.98.9/32\",\r\n \"104.46.98.73/32\",\r\n \ + \ \"104.46.99.176/32\",\r\n \"104.208.16.0/26\",\r\n \ + \ \"104.208.144.0/26\",\r\n \"104.208.237.147/32\",\r\n \ + \ \"104.209.186.70/32\",\r\n \"104.210.14.49/32\",\r\n \ + \ \"104.210.106.31/32\",\r\n \"104.210.146.250/32\",\r\n \ + \ \"104.211.81.0/28\",\r\n \"104.211.98.185/32\",\r\n \"\ + 104.211.102.58/32\",\r\n \"104.211.146.32/27\",\r\n \"104.211.160.121/32\"\ + ,\r\n \"104.211.160.144/32\",\r\n \"104.211.224.190/32\"\ + ,\r\n \"104.211.224.238/32\",\r\n \"104.214.18.128/27\"\ + ,\r\n \"104.214.70.229/32\",\r\n \"137.116.48.46/32\",\r\ + \n \"137.116.77.157/32\",\r\n \"137.116.91.178/32\",\r\n\ + \ \"137.116.157.26/32\",\r\n \"137.116.158.30/32\",\r\n\ + \ \"137.117.85.236/32\",\r\n \"137.117.89.253/32\",\r\n\ + \ \"137.117.91.152/32\",\r\n \"137.135.102.226/32\",\r\n\ + \ \"138.91.1.105/32\",\r\n \"138.91.17.38/32\",\r\n \ + \ \"138.91.17.85/32\",\r\n \"138.91.193.184/32\",\r\n \ + \ \"168.61.92.197/32\",\r\n \"168.61.148.205/32\",\r\n \ + \ \"168.62.52.235/32\",\r\n \"168.62.234.250/32\",\r\n \ + \ \"168.62.237.3/32\",\r\n \"168.62.249.226/32\",\r\n \"\ + 168.63.141.27/32\",\r\n \"191.233.9.64/27\",\r\n \"191.233.73.228/32\"\ + ,\r\n \"191.233.203.0/28\",\r\n \"191.234.146.64/26\",\r\ + \n \"191.234.154.64/26\",\r\n \"191.236.32.73/32\",\r\n\ + \ \"191.236.32.191/32\",\r\n \"191.236.35.225/32\",\r\n\ + \ \"191.236.128.253/32\",\r\n \"191.236.129.107/32\",\r\n\ + \ \"191.237.47.93/32\",\r\n \"191.237.129.158/32\",\r\n\ + \ \"191.238.99.131/32\",\r\n \"191.238.160.221/32\",\r\n\ + \ \"191.239.64.142/32\",\r\n \"191.239.64.144/32\",\r\n\ + \ \"191.239.160.45/32\",\r\n \"191.239.160.178/32\",\r\n\ + \ \"207.46.153.127/32\",\r\n \"207.46.154.16/32\",\r\n \ + \ \"207.46.227.14/32\",\r\n \"2603:1000:104:1::240/122\"\ + ,\r\n \"2603:1010:6:1::240/122\",\r\n \"2603:1020:5:1::240/122\"\ + ,\r\n \"2603:1020:206:1::240/122\",\r\n \"2603:1020:705:1::240/122\"\ + ,\r\n \"2603:1020:805:1::240/122\",\r\n \"2603:1020:a04:1::240/122\"\ + ,\r\n \"2603:1020:c04:1::240/122\",\r\n \"2603:1020:e04:1::240/122\"\ + ,\r\n \"2603:1020:1004::240/122\",\r\n \"2603:1030:10:1::240/122\"\ + ,\r\n \"2603:1030:104:1::240/122\",\r\n \"2603:1030:210:1::240/122\"\ + ,\r\n \"2603:1030:40b:1::240/122\",\r\n \"2603:1030:40c:1::240/122\"\ + ,\r\n \"2603:1030:504:1::240/122\",\r\n \"2603:1030:807:1::240/122\"\ + ,\r\n \"2603:1030:c06:1::240/122\",\r\n \"2603:1030:f05:1::240/122\"\ + ,\r\n \"2603:1040:5:1::240/122\",\r\n \"2603:1040:407:1::240/122\"\ + ,\r\n \"2603:1040:904:1::240/122\",\r\n \"2603:1040:a06:1::240/122\"\ + ,\r\n \"2603:1040:d04::240/122\",\r\n \"2603:1040:f05:1::240/122\"\ + ,\r\n \"2603:1050:6:1::240/122\",\r\n \"2603:1050:403::240/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.AustraliaCentral\"\ + ,\r\n \"id\": \"EventHub.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"20.36.46.142/32\"\ + ,\r\n \"20.36.106.192/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.AustraliaCentral2\",\r\n \"id\"\ + : \"EventHub.AustraliaCentral2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"20.36.74.130/32\"\ + ,\r\n \"20.36.114.32/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"EventHub.AustraliaEast\",\r\n \"id\": \"EventHub.AustraliaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"\ + addressPrefixes\": [\r\n \"13.70.72.0/28\",\r\n \"13.70.79.16/28\"\ + ,\r\n \"13.72.254.134/32\",\r\n \"40.79.162.0/28\",\r\n\ + \ \"40.79.170.32/28\",\r\n \"104.210.106.31/32\",\r\n \ + \ \"191.239.64.142/32\",\r\n \"191.239.64.144/32\",\r\n \ + \ \"2603:1010:6:1::240/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.AustraliaSoutheast\",\r\n \"id\"\ + : \"EventHub.AustraliaSoutheast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.77.50.32/27\"\ + ,\r\n \"40.115.79.2/32\",\r\n \"40.127.83.123/32\",\r\n\ + \ \"191.239.160.45/32\",\r\n \"191.239.160.178/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.BrazilSouth\"\ + ,\r\n \"id\": \"EventHub.BrazilSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"23.97.97.36/32\"\ + ,\r\n \"23.97.103.3/32\",\r\n \"104.41.63.213/32\",\r\n\ + \ \"191.233.203.0/28\",\r\n \"191.234.146.64/26\",\r\n \ + \ \"191.234.154.64/26\",\r\n \"2603:1050:6:1::240/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.CanadaCentral\"\ + ,\r\n \"id\": \"EventHub.CanadaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.16/28\"\ + ,\r\n \"20.38.146.64/26\",\r\n \"40.85.226.62/32\",\r\n\ + \ \"40.85.229.32/32\",\r\n \"52.233.30.41/32\",\r\n \ + \ \"52.237.33.36/32\",\r\n \"52.237.33.104/32\",\r\n \ + \ \"52.246.154.64/26\",\r\n \"2603:1030:f05:1::240/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.CanadaEast\"\ + ,\r\n \"id\": \"EventHub.CanadaEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.32/27\"\ + ,\r\n \"40.86.225.142/32\",\r\n \"40.86.230.119/32\",\r\n\ + \ \"52.242.20.204/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"EventHub.CentralIndia\",\r\n \"id\": \"EventHub.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"\ + addressPrefixes\": [\r\n \"13.71.30.214/32\",\r\n \"20.192.98.64/26\"\ + ,\r\n \"40.80.50.64/26\",\r\n \"52.172.221.245/32\",\r\n\ + \ \"52.172.223.211/32\",\r\n \"104.211.81.0/28\",\r\n \ + \ \"104.211.98.185/32\",\r\n \"104.211.102.58/32\",\r\n \ + \ \"2603:1040:a06:1::240/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.CentralUS\",\r\n \"id\": \"EventHub.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.89.58.37/32\",\r\n \"13.89.59.231/32\",\r\n\ + \ \"13.89.170.128/26\",\r\n \"23.99.128.69/32\",\r\n \ + \ \"23.99.129.170/32\",\r\n \"23.99.192.254/32\",\r\n \ + \ \"23.99.196.56/32\",\r\n \"23.99.228.174/32\",\r\n \ + \ \"40.86.77.12/32\",\r\n \"40.86.102.100/32\",\r\n \"\ + 40.122.173.108/32\",\r\n \"40.122.213.155/32\",\r\n \"52.165.34.144/32\"\ + ,\r\n \"52.165.179.109/32\",\r\n \"52.165.235.119/32\",\r\ + \n \"52.165.237.8/32\",\r\n \"52.173.199.106/32\",\r\n \ + \ \"52.176.47.198/32\",\r\n \"52.182.138.128/26\",\r\n \ + \ \"104.43.168.200/32\",\r\n \"104.43.192.43/32\",\r\n \ + \ \"104.43.192.222/32\",\r\n \"104.208.16.0/26\",\r\n \ + \ \"168.61.148.205/32\",\r\n \"2603:1030:10:1::240/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.CentralUSEUAP\"\ + ,\r\n \"id\": \"EventHub.CentralUSEUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.32/27\"\ + ,\r\n \"52.180.180.228/32\",\r\n \"52.180.182.75/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.EastAsia\"\ + ,\r\n \"id\": \"EventHub.EastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.75.34.64/26\"\ + ,\r\n \"13.94.47.61/32\",\r\n \"23.97.67.90/32\",\r\n \ + \ \"23.99.118.48/32\",\r\n \"23.101.3.68/32\",\r\n \ + \ \"23.101.8.229/32\",\r\n \"23.102.234.49/32\",\r\n \"\ + 52.175.35.235/32\",\r\n \"168.63.141.27/32\",\r\n \"207.46.153.127/32\"\ + ,\r\n \"207.46.154.16/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.EastUS\",\r\n \"id\": \"EventHub.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.90.83.7/32\",\r\n \"13.90.208.184/32\",\r\n \ + \ \"13.92.124.151/32\",\r\n \"13.92.180.208/32\",\r\n \ + \ \"13.92.190.184/32\",\r\n \"40.71.10.128/26\",\r\n \"\ + 40.71.100.98/32\",\r\n \"40.76.29.197/32\",\r\n \"40.76.40.11/32\"\ + ,\r\n \"40.76.194.119/32\",\r\n \"40.78.226.128/26\",\r\n\ + \ \"40.79.155.0/26\",\r\n \"40.117.88.66/32\",\r\n \ + \ \"40.121.84.50/32\",\r\n \"40.121.141.232/32\",\r\n \ + \ \"40.121.148.193/32\",\r\n \"52.168.14.144/32\",\r\n \ + \ \"52.168.66.180/32\",\r\n \"52.168.146.69/32\",\r\n \"\ + 52.168.147.11/32\",\r\n \"52.179.6.240/32\",\r\n \"52.179.8.35/32\"\ + ,\r\n \"52.191.213.188/32\",\r\n \"52.226.36.235/32\",\r\ + \n \"104.45.135.34/32\",\r\n \"104.45.147.24/32\",\r\n \ + \ \"137.117.85.236/32\",\r\n \"137.117.89.253/32\",\r\n \ + \ \"137.117.91.152/32\",\r\n \"137.135.102.226/32\",\r\n\ + \ \"168.62.52.235/32\",\r\n \"191.236.32.73/32\",\r\n \ + \ \"191.236.32.191/32\",\r\n \"191.236.35.225/32\",\r\n \ + \ \"191.237.47.93/32\",\r\n \"2603:1030:210:1::240/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.EastUS2\"\ + ,\r\n \"id\": \"EventHub.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.68.20.101/32\"\ + ,\r\n \"13.68.21.169/32\",\r\n \"13.68.77.215/32\",\r\n\ + \ \"40.70.78.154/32\",\r\n \"40.70.146.0/26\",\r\n \ + \ \"40.79.44.59/32\",\r\n \"40.79.74.86/32\",\r\n \"\ + 52.167.106.0/26\",\r\n \"52.179.157.59/32\",\r\n \"104.46.98.9/32\"\ + ,\r\n \"104.46.98.73/32\",\r\n \"104.46.99.176/32\",\r\n\ + \ \"104.208.144.0/26\",\r\n \"104.208.237.147/32\",\r\n\ + \ \"104.209.186.70/32\",\r\n \"104.210.14.49/32\",\r\n \ + \ \"137.116.48.46/32\",\r\n \"137.116.77.157/32\",\r\n \ + \ \"137.116.91.178/32\",\r\n \"191.237.129.158/32\",\r\n \ + \ \"2603:1030:40c:1::240/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"EventHub.EastUS2EUAP\",\r\n \"id\": \"EventHub.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.146.16/28\",\r\n \"40.75.34.0/28\",\r\n\ + \ \"52.138.90.0/28\",\r\n \"52.225.184.224/32\",\r\n \ + \ \"52.225.186.130/32\",\r\n \"2603:1030:40b:1::240/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.FranceCentral\"\ + ,\r\n \"id\": \"EventHub.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.79.130.16/28\"\ + ,\r\n \"40.79.138.0/28\",\r\n \"40.79.146.0/28\",\r\n \ + \ \"52.143.136.55/32\",\r\n \"2603:1020:805:1::240/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.FranceSouth\"\ + ,\r\n \"id\": \"EventHub.FranceSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.79.178.32/27\"\ + ,\r\n \"52.136.136.62/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.GermanyNorth\",\r\n \"id\": \"EventHub.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.58.128/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.GermanyWestCentral\",\r\n \"id\"\ + : \"EventHub.GermanyWestCentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.116.154.192/27\",\r\n\ + \ \"51.116.242.64/26\",\r\n \"51.116.245.192/27\",\r\n \ + \ \"51.116.250.64/26\",\r\n \"2603:1020:c04:1::240/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.JapanEast\"\ + ,\r\n \"id\": \"EventHub.JapanEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.154.11/32\"\ + ,\r\n \"13.78.106.64/28\",\r\n \"23.100.100.84/32\",\r\n\ + \ \"40.79.186.32/27\",\r\n \"40.79.194.192/26\",\r\n \ + \ \"52.243.36.161/32\",\r\n \"138.91.1.105/32\",\r\n \ + \ \"2603:1040:407:1::240/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"EventHub.JapanWest\",\r\n \"id\": \"EventHub.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.100.0/27\",\r\n \"40.74.141.187/32\",\r\n\ + \ \"138.91.17.38/32\",\r\n \"138.91.17.85/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.KoreaCentral\"\ + ,\r\n \"id\": \"EventHub.KoreaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"20.44.26.64/26\"\ + ,\r\n \"52.231.18.16/28\",\r\n \"52.231.29.105/32\",\r\n\ + \ \"52.231.32.85/32\",\r\n \"52.231.32.94/32\",\r\n \ + \ \"2603:1040:f05:1::240/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.KoreaSouth\",\r\n \"id\": \"EventHub.KoreaSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.231.146.32/27\",\r\n \"52.231.200.144/32\"\ + ,\r\n \"52.231.200.153/32\",\r\n \"52.231.207.155/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.NorthCentralUS\"\ + ,\r\n \"id\": \"EventHub.NorthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"23.96.214.181/32\"\ + ,\r\n \"23.96.253.236/32\",\r\n \"52.162.106.64/26\",\r\n\ + \ \"52.237.143.176/32\",\r\n \"168.62.234.250/32\",\r\n\ + \ \"168.62.237.3/32\",\r\n \"168.62.249.226/32\",\r\n \ + \ \"191.236.128.253/32\",\r\n \"191.236.129.107/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.NorthEurope\"\ + ,\r\n \"id\": \"EventHub.NorthEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.69.227.0/26\"\ + ,\r\n \"13.69.253.135/32\",\r\n \"13.69.255.140/32\",\r\n\ + \ \"13.74.107.0/26\",\r\n \"23.102.0.186/32\",\r\n \ + \ \"23.102.0.239/32\",\r\n \"23.102.53.113/32\",\r\n \ + \ \"40.69.29.216/32\",\r\n \"40.69.217.246/32\",\r\n \"\ + 40.127.132.254/32\",\r\n \"52.138.147.148/32\",\r\n \"52.138.226.0/26\"\ + ,\r\n \"52.169.18.8/32\",\r\n \"52.178.211.227/32\",\r\n\ + \ \"104.41.201.10/32\",\r\n \"168.61.92.197/32\",\r\n \ + \ \"191.238.99.131/32\",\r\n \"2603:1020:5:1::240/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.NorwayEast\"\ + ,\r\n \"id\": \"EventHub.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"51.120.98.128/27\"\ + ,\r\n \"51.120.106.64/26\",\r\n \"51.120.210.64/26\",\r\n\ + \ \"2603:1020:e04:1::240/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"EventHub.NorwayWest\",\r\n \"id\": \"EventHub.NorwayWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.218.160/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"EventHub.SouthAfricaNorth\",\r\n \"id\": \"\ + EventHub.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southafricanorth\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.122.64/26\",\r\n\ + \ \"102.133.154.128/26\",\r\n \"102.133.250.64/26\",\r\n\ + \ \"2603:1000:104:1::240/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"EventHub.SouthAfricaWest\",\r\n \"id\":\ + \ \"EventHub.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.26.128/26\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SouthCentralUS\"\ + ,\r\n \"id\": \"EventHub.SouthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.65.209.24/32\"\ + ,\r\n \"13.84.145.196/32\",\r\n \"20.45.122.64/26\",\r\n\ + \ \"23.102.128.15/32\",\r\n \"23.102.160.39/32\",\r\n \ + \ \"23.102.161.227/32\",\r\n \"23.102.163.4/32\",\r\n \ + \ \"23.102.165.127/32\",\r\n \"23.102.167.73/32\",\r\n \ + \ \"23.102.180.26/32\",\r\n \"40.84.150.241/32\",\r\n \ + \ \"40.84.185.67/32\",\r\n \"104.44.129.14/32\",\r\n \"\ + 104.44.129.59/32\",\r\n \"104.210.146.250/32\",\r\n \"104.214.18.128/27\"\ + ,\r\n \"104.214.70.229/32\",\r\n \"191.238.160.221/32\"\ + ,\r\n \"2603:1030:807:1::240/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"EventHub.SoutheastAsia\",\r\n \"\ + id\": \"EventHub.SoutheastAsia\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southeastasia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.8.64/27\",\r\n \ + \ \"13.76.179.223/32\",\r\n \"13.76.216.217/32\",\r\n \ + \ \"23.98.64.92/32\",\r\n \"23.98.65.24/32\",\r\n \"\ + 23.98.82.64/27\",\r\n \"40.78.234.0/27\",\r\n \"52.187.2.226/32\"\ + ,\r\n \"52.187.59.188/32\",\r\n \"52.187.61.82/32\",\r\n\ + \ \"52.187.185.159/32\",\r\n \"104.43.18.219/32\",\r\n \ + \ \"137.116.157.26/32\",\r\n \"137.116.158.30/32\",\r\n \ + \ \"207.46.227.14/32\",\r\n \"2603:1040:5:1::240/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.SouthIndia\"\ + ,\r\n \"id\": \"EventHub.SouthIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.71.123.78/32\"\ + ,\r\n \"40.78.194.32/27\",\r\n \"104.211.224.190/32\",\r\ + \n \"104.211.224.238/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"EventHub.SwitzerlandNorth\",\r\n \"id\": \"\ + EventHub.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"switzerlandn\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\ + \n \"addressPrefixes\": [\r\n \"51.107.58.128/27\",\r\n \ + \ \"2603:1020:a04:1::240/122\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"EventHub.SwitzerlandWest\",\r\n \"id\": \"\ + EventHub.SwitzerlandWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"switzerlandw\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\ + \n \"addressPrefixes\": [\r\n \"51.107.154.128/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.UAECentral\"\ + ,\r\n \"id\": \"EventHub.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.0/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.UAENorth\"\ + ,\r\n \"id\": \"EventHub.UAENorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"40.120.75.64/27\"\ + ,\r\n \"65.52.250.32/27\",\r\n \"2603:1040:904:1::240/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.UKNorth\"\ + ,\r\n \"id\": \"EventHub.UKNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.87.102.63/32\",\r\n \ + \ \"13.87.102.68/32\",\r\n \"13.87.122.32/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"EventHub.UKSouth\",\r\n\ + \ \"id\": \"EventHub.UKSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.105.66.64/26\",\r\n\ + \ \"51.105.74.64/26\",\r\n \"51.140.80.99/32\",\r\n \ + \ \"51.140.87.93/32\",\r\n \"51.140.125.8/32\",\r\n \ + \ \"51.140.146.32/28\",\r\n \"51.140.189.52/32\",\r\n \"\ + 51.140.189.108/32\",\r\n \"2603:1020:705:1::240/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.UKSouth2\"\ + ,\r\n \"id\": \"EventHub.UKSouth2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureEventHub\",\r\ + \n \"addressPrefixes\": [\r\n \"13.87.34.139/32\",\r\n \ + \ \"13.87.34.243/32\",\r\n \"13.87.56.32/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"EventHub.UKWest\",\r\n \ + \ \"id\": \"EventHub.UKWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.140.210.32/27\",\r\n\ + \ \"51.141.14.113/32\",\r\n \"51.141.14.168/32\",\r\n \ + \ \"51.141.50.179/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"EventHub.WestCentralUS\",\r\n \"id\": \"EventHub.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureEventHub\",\r\n \"\ + addressPrefixes\": [\r\n \"13.71.194.64/27\",\r\n \"13.78.149.209/32\"\ + ,\r\n \"13.78.150.233/32\",\r\n \"13.78.191.44/32\",\r\n\ + \ \"52.161.19.160/32\",\r\n \"52.161.24.64/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestEurope\"\ + ,\r\n \"id\": \"EventHub.WestEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.69.64.0/26\"\ + ,\r\n \"13.69.106.0/26\",\r\n \"23.97.226.21/32\",\r\n \ + \ \"23.100.14.185/32\",\r\n \"40.68.35.230/32\",\r\n \ + \ \"40.68.39.15/32\",\r\n \"40.68.93.145/32\",\r\n \ + \ \"40.68.205.113/32\",\r\n \"40.68.217.242/32\",\r\n \"\ + 51.144.238.23/32\",\r\n \"52.174.243.57/32\",\r\n \"52.178.78.61/32\"\ + ,\r\n \"52.232.27.189/32\",\r\n \"52.233.190.35/32\",\r\n\ + \ \"52.233.192.247/32\",\r\n \"52.236.186.0/26\",\r\n \ + \ \"65.52.129.16/32\",\r\n \"104.40.150.139/32\",\r\n \ + \ \"104.40.179.185/32\",\r\n \"104.40.216.174/32\",\r\n \ + \ \"104.46.32.56/32\",\r\n \"104.46.32.58/32\",\r\n \ + \ \"191.233.73.228/32\",\r\n \"2603:1020:206:1::240/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestIndia\"\ + ,\r\n \"id\": \"EventHub.WestIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"104.211.146.32/27\"\ + ,\r\n \"104.211.160.121/32\",\r\n \"104.211.160.144/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"EventHub.WestUS\"\ + ,\r\n \"id\": \"EventHub.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureEventHub\",\r\n \"addressPrefixes\": [\r\n \"13.64.195.117/32\"\ + ,\r\n \"13.88.20.117/32\",\r\n \"13.88.26.28/32\",\r\n \ + \ \"13.91.61.11/32\",\r\n \"13.93.226.138/32\",\r\n \ + \ \"23.99.7.105/32\",\r\n \"23.99.54.235/32\",\r\n \"\ + 23.99.60.253/32\",\r\n \"23.99.80.186/32\",\r\n \"40.78.110.196/32\"\ + ,\r\n \"40.83.191.202/32\",\r\n \"40.83.222.100/32\",\r\n\ + \ \"40.86.176.23/32\",\r\n \"40.112.185.115/32\",\r\n \ + \ \"40.112.213.11/32\",\r\n \"40.112.242.0/25\",\r\n \ + \ \"104.40.26.199/32\",\r\n \"104.40.29.113/32\",\r\n \ + \ \"104.40.68.250/32\",\r\n \"104.40.69.64/32\",\r\n \"\ + 104.42.97.95/32\",\r\n \"138.91.193.184/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"EventHub.WestUS2\",\r\n \ + \ \"id\": \"EventHub.WestUS2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureEventHub\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.138.64/28\",\r\n\ + \ \"13.66.145.128/26\",\r\n \"13.66.228.204/32\",\r\n \ + \ \"13.66.230.42/32\",\r\n \"20.42.131.16/28\",\r\n \ + \ \"20.42.131.64/26\",\r\n \"40.78.242.128/28\",\r\n \ + \ \"40.78.247.0/26\",\r\n \"40.78.250.64/28\",\r\n \"40.78.253.128/26\"\ + ,\r\n \"52.151.58.121/32\",\r\n \"52.183.46.73/32\",\r\n\ + \ \"52.183.86.102/32\",\r\n \"2603:1030:c06:1::240/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager\"\ + ,\r\n \"id\": \"GatewayManager\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.65.91.57/32\",\r\n \ + \ \"13.66.140.144/29\",\r\n \"13.67.9.128/29\",\r\n \ + \ \"13.69.64.224/29\",\r\n \"13.69.227.224/29\",\r\n \ + \ \"13.70.72.208/29\",\r\n \"13.70.185.130/32\",\r\n \"\ + 13.71.170.240/29\",\r\n \"13.71.194.232/29\",\r\n \"13.75.36.8/29\"\ + ,\r\n \"13.77.0.146/32\",\r\n \"13.77.50.88/29\",\r\n \ + \ \"13.78.108.16/29\",\r\n \"13.78.188.33/32\",\r\n \ + \ \"13.85.74.21/32\",\r\n \"13.87.35.147/32\",\r\n \"\ + 13.87.36.246/32\",\r\n \"13.87.56.104/29\",\r\n \"13.87.122.104/29\"\ + ,\r\n \"13.89.171.96/29\",\r\n \"13.91.249.235/32\",\r\n\ + \ \"13.91.254.232/32\",\r\n \"13.92.84.128/32\",\r\n \ + \ \"13.93.112.146/32\",\r\n \"13.93.117.26/32\",\r\n \ + \ \"20.36.42.151/32\",\r\n \"20.36.42.152/32\",\r\n \"\ + 20.36.74.91/32\",\r\n \"20.36.74.113/32\",\r\n \"20.36.106.72/29\"\ + ,\r\n \"20.36.114.24/29\",\r\n \"20.36.120.72/29\",\r\n\ + \ \"20.37.53.66/32\",\r\n \"20.37.53.76/32\",\r\n \ + \ \"20.37.64.72/29\",\r\n \"20.37.74.88/29\",\r\n \"\ + 20.37.152.72/29\",\r\n \"20.37.192.72/29\",\r\n \"20.37.224.72/29\"\ + ,\r\n \"20.38.80.72/29\",\r\n \"20.38.136.72/29\",\r\n \ + \ \"20.39.1.56/32\",\r\n \"20.39.1.58/32\",\r\n \ + \ \"20.39.8.72/29\",\r\n \"20.41.0.72/29\",\r\n \"20.41.64.72/29\"\ + ,\r\n \"20.41.192.72/29\",\r\n \"20.42.0.72/29\",\r\n \ + \ \"20.42.128.72/29\",\r\n \"20.42.224.72/29\",\r\n \ + \ \"20.43.40.72/29\",\r\n \"20.43.64.72/29\",\r\n \"\ + 20.43.128.72/29\",\r\n \"20.44.3.16/29\",\r\n \"20.45.112.72/29\"\ + ,\r\n \"20.45.192.72/29\",\r\n \"20.150.160.64/29\",\r\n\ + \ \"20.150.161.0/26\",\r\n \"20.150.171.64/29\",\r\n \ + \ \"20.189.104.72/29\",\r\n \"20.192.160.64/26\",\r\n \ + \ \"20.192.224.192/26\",\r\n \"23.100.231.72/32\",\r\n \ + \ \"23.100.231.96/32\",\r\n \"23.101.173.90/32\",\r\n \ + \ \"40.67.48.72/29\",\r\n \"40.67.59.64/29\",\r\n \"40.69.106.88/29\"\ + ,\r\n \"40.70.146.224/29\",\r\n \"40.71.11.96/29\",\r\n\ + \ \"40.74.24.72/29\",\r\n \"40.74.100.168/29\",\r\n \ + \ \"40.78.194.88/29\",\r\n \"40.78.202.112/29\",\r\n \ + \ \"40.79.130.224/29\",\r\n \"40.79.178.88/29\",\r\n \"\ + 40.80.56.72/29\",\r\n \"40.80.168.72/29\",\r\n \"40.80.184.72/29\"\ + ,\r\n \"40.81.94.172/32\",\r\n \"40.81.94.182/32\",\r\n\ + \ \"40.81.189.24/32\",\r\n \"40.81.189.42/32\",\r\n \ + \ \"40.82.236.2/32\",\r\n \"40.82.236.13/32\",\r\n \ + \ \"40.82.248.240/29\",\r\n \"40.89.16.72/29\",\r\n \"40.90.186.21/32\"\ + ,\r\n \"40.90.186.91/32\",\r\n \"40.112.242.168/29\",\r\n\ + \ \"40.115.248.200/32\",\r\n \"40.115.254.17/32\",\r\n \ + \ \"40.119.8.64/29\",\r\n \"51.12.40.192/26\",\r\n \ + \ \"51.12.192.192/26\",\r\n \"51.104.24.72/29\",\r\n \ + \ \"51.105.80.72/29\",\r\n \"51.105.88.72/29\",\r\n \"51.107.48.72/29\"\ + ,\r\n \"51.107.59.32/29\",\r\n \"51.107.144.72/29\",\r\n\ + \ \"51.107.155.32/29\",\r\n \"51.116.48.72/29\",\r\n \ + \ \"51.116.59.32/29\",\r\n \"51.116.144.72/29\",\r\n \ + \ \"51.116.155.96/29\",\r\n \"51.120.40.72/29\",\r\n \ + \ \"51.120.98.168/29\",\r\n \"51.120.219.64/29\",\r\n \"\ + 51.120.224.72/29\",\r\n \"51.137.160.72/29\",\r\n \"51.140.63.41/32\"\ + ,\r\n \"51.140.114.209/32\",\r\n \"51.140.148.16/29\",\r\ + \n \"51.140.210.200/29\",\r\n \"51.141.25.80/32\",\r\n \ + \ \"51.141.29.178/32\",\r\n \"51.142.209.124/32\",\r\n \ + \ \"51.142.210.184/32\",\r\n \"51.143.192.72/29\",\r\n \ + \ \"52.136.48.72/29\",\r\n \"52.136.137.15/32\",\r\n \ + \ \"52.136.137.16/32\",\r\n \"52.138.70.115/32\",\r\n \ + \ \"52.138.71.153/32\",\r\n \"52.138.90.40/29\",\r\n \"\ + 52.140.104.72/29\",\r\n \"52.143.136.58/31\",\r\n \"52.149.24.100/32\"\ + ,\r\n \"52.149.26.14/32\",\r\n \"52.150.136.72/29\",\r\n\ + \ \"52.159.19.113/32\",\r\n \"52.159.20.67/32\",\r\n \ + \ \"52.161.28.251/32\",\r\n \"52.162.106.168/29\",\r\n \ + \ \"52.163.241.22/32\",\r\n \"52.163.246.27/32\",\r\n \ + \ \"52.165.221.72/32\",\r\n \"52.169.225.171/32\",\r\n \ + \ \"52.169.231.163/32\",\r\n \"52.172.28.183/32\",\r\n \ + \ \"52.172.31.29/32\",\r\n \"52.172.204.73/32\",\r\n \"\ + 52.172.222.13/32\",\r\n \"52.173.250.124/32\",\r\n \"52.177.204.204/32\"\ + ,\r\n \"52.177.207.219/32\",\r\n \"52.179.10.142/32\",\r\ + \n \"52.180.178.35/32\",\r\n \"52.180.178.191/32\",\r\n\ + \ \"52.180.182.210/32\",\r\n \"52.191.140.123/32\",\r\n\ + \ \"52.191.170.38/32\",\r\n \"52.228.80.72/29\",\r\n \ + \ \"52.229.161.220/32\",\r\n \"52.229.166.101/32\",\r\n \ + \ \"52.231.18.224/29\",\r\n \"52.231.24.186/32\",\r\n \ + \ \"52.231.35.84/32\",\r\n \"52.231.146.200/29\",\r\n \ + \ \"52.231.203.87/32\",\r\n \"52.231.204.175/32\",\r\n \ + \ \"52.237.24.145/32\",\r\n \"52.237.30.255/32\",\r\n \"\ + 52.237.208.51/32\",\r\n \"52.237.215.149/32\",\r\n \"52.242.17.200/32\"\ + ,\r\n \"52.242.28.83/32\",\r\n \"52.253.159.209/32\",\r\n\ + \ \"52.253.239.162/32\",\r\n \"65.52.250.24/29\",\r\n \ + \ \"70.37.160.97/32\",\r\n \"70.37.161.124/32\",\r\n \ + \ \"102.133.27.16/29\",\r\n \"102.133.56.72/29\",\r\n \ + \ \"102.133.155.16/29\",\r\n \"102.133.216.72/29\",\r\n \ + \ \"104.211.81.208/29\",\r\n \"104.211.146.88/29\",\r\n \ + \ \"104.211.188.0/32\",\r\n \"104.211.191.94/32\",\r\n \ + \ \"104.214.19.64/29\",\r\n \"104.215.50.115/32\",\r\n \ + \ \"104.215.52.27/32\",\r\n \"168.62.104.154/32\",\r\n \"\ + 168.62.208.162/32\",\r\n \"168.62.209.95/32\",\r\n \"191.233.8.64/26\"\ + ,\r\n \"191.233.203.208/29\",\r\n \"191.233.245.75/32\"\ + ,\r\n \"191.233.245.118/32\",\r\n \"191.234.182.29/32\"\ + ,\r\n \"191.235.81.58/32\",\r\n \"191.235.224.72/29\",\r\ + \n \"2603:1000:104:1::40/122\",\r\n \"2603:1010:6:1::40/122\"\ + ,\r\n \"2603:1020:5:1::40/122\",\r\n \"2603:1020:206:1::40/122\"\ + ,\r\n \"2603:1020:705:1::40/122\",\r\n \"2603:1020:805:1::40/122\"\ + ,\r\n \"2603:1020:a04:1::40/122\",\r\n \"2603:1020:c04:1::40/122\"\ + ,\r\n \"2603:1020:e04:1::40/122\",\r\n \"2603:1020:1004::40/122\"\ + ,\r\n \"2603:1030:10:1::40/122\",\r\n \"2603:1030:104:1::40/122\"\ + ,\r\n \"2603:1030:210:1::40/122\",\r\n \"2603:1030:40b:1::40/122\"\ + ,\r\n \"2603:1030:40c:1::40/122\",\r\n \"2603:1030:504:1::40/122\"\ + ,\r\n \"2603:1030:807:1::40/122\",\r\n \"2603:1030:c06:1::40/122\"\ + ,\r\n \"2603:1030:f05:1::40/122\",\r\n \"2603:1040:5:1::40/122\"\ + ,\r\n \"2603:1040:407:1::40/122\",\r\n \"2603:1040:904:1::40/122\"\ + ,\r\n \"2603:1040:a06:1::40/122\",\r\n \"2603:1040:d04::40/122\"\ + ,\r\n \"2603:1040:f05:1::40/122\",\r\n \"2603:1050:6:1::40/122\"\ + ,\r\n \"2603:1050:403::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.AustraliaCentral\",\r\n \"\ + id\": \"GatewayManager.AustraliaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.36.42.151/32\"\ + ,\r\n \"20.36.42.152/32\",\r\n \"20.36.106.72/29\",\r\n\ + \ \"20.37.53.66/32\",\r\n \"20.37.53.76/32\",\r\n \ + \ \"20.37.224.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"GatewayManager.AustraliaCentral2\",\r\n \"id\": \"GatewayManager.AustraliaCentral2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"GatewayManager\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.36.74.91/32\",\r\n \"\ + 20.36.74.113/32\",\r\n \"20.36.114.24/29\",\r\n \"20.36.120.72/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.AustraliaEast\"\ + ,\r\n \"id\": \"GatewayManager.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.208/29\"\ + ,\r\n \"20.37.192.72/29\",\r\n \"52.237.208.51/32\",\r\n\ + \ \"52.237.215.149/32\",\r\n \"2603:1010:6:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.AustraliaSoutheast\"\ + ,\r\n \"id\": \"GatewayManager.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.70.185.130/32\"\ + ,\r\n \"13.77.0.146/32\",\r\n \"13.77.50.88/29\",\r\n \ + \ \"20.42.224.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GatewayManager.BrazilSouth\",\r\n \"id\": \"GatewayManager.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"\ + addressPrefixes\": [\r\n \"191.233.203.208/29\",\r\n \"\ + 191.233.245.75/32\",\r\n \"191.233.245.118/32\",\r\n \"\ + 191.234.182.29/32\",\r\n \"191.235.81.58/32\",\r\n \"191.235.224.72/29\"\ + ,\r\n \"2603:1050:6:1::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.CanadaCentral\",\r\n \"id\"\ + : \"GatewayManager.CanadaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.240/29\"\ + ,\r\n \"52.228.80.72/29\",\r\n \"52.237.24.145/32\",\r\n\ + \ \"52.237.30.255/32\",\r\n \"2603:1030:f05:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CanadaEast\"\ + ,\r\n \"id\": \"GatewayManager.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.88/29\"\ + ,\r\n \"40.89.16.72/29\",\r\n \"52.242.17.200/32\",\r\n\ + \ \"52.242.28.83/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"GatewayManager.CentralIndia\",\r\n \"id\": \"GatewayManager.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"\ + addressPrefixes\": [\r\n \"52.140.104.72/29\",\r\n \"52.172.204.73/32\"\ + ,\r\n \"52.172.222.13/32\",\r\n \"104.211.81.208/29\",\r\ + \n \"2603:1040:a06:1::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.CentralUS\",\r\n \"id\":\ + \ \"GatewayManager.CentralUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralus\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.89.171.96/29\",\r\n \ + \ \"20.37.152.72/29\",\r\n \"52.165.221.72/32\",\r\n \ + \ \"52.173.250.124/32\",\r\n \"2603:1030:10:1::40/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.CentralUSEUAP\"\ + ,\r\n \"id\": \"GatewayManager.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.45.192.72/29\"\ + ,\r\n \"40.78.202.112/29\",\r\n \"52.180.178.35/32\",\r\n\ + \ \"52.180.178.191/32\",\r\n \"52.180.182.210/32\",\r\n\ + \ \"52.253.159.209/32\",\r\n \"52.253.239.162/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.EastAsia\"\ + ,\r\n \"id\": \"GatewayManager.EastAsia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.75.36.8/29\"\ + ,\r\n \"20.189.104.72/29\",\r\n \"52.229.161.220/32\",\r\ + \n \"52.229.166.101/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"GatewayManager.EastUS\",\r\n \"id\": \"GatewayManager.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.92.84.128/32\",\r\n \"20.42.0.72/29\",\r\n \ + \ \"40.71.11.96/29\",\r\n \"52.179.10.142/32\",\r\n \"\ + 2603:1030:210:1::40/122\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"GatewayManager.EastUS2\",\r\n \"id\": \"GatewayManager.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.41.0.72/29\",\r\n \"40.70.146.224/29\",\r\n \ + \ \"52.177.204.204/32\",\r\n \"52.177.207.219/32\",\r\n \ + \ \"2603:1030:40c:1::40/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"GatewayManager.EastUS2EUAP\",\r\n \"id\": \"\ + GatewayManager.EastUS2EUAP\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus2euap\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.39.1.56/32\",\r\n \ + \ \"20.39.1.58/32\",\r\n \"20.39.8.72/29\",\r\n \"\ + 52.138.70.115/32\",\r\n \"52.138.71.153/32\",\r\n \"52.138.90.40/29\"\ + ,\r\n \"2603:1030:40b:1::40/122\"\r\n ]\r\n }\r\n \ + \ },\r\n {\r\n \"name\": \"GatewayManager.FranceCentral\",\r\n \ + \ \"id\": \"GatewayManager.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.43.40.72/29\"\ + ,\r\n \"40.79.130.224/29\",\r\n \"52.143.136.58/31\",\r\n\ + \ \"2603:1020:805:1::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.FranceSouth\",\r\n \"id\"\ + : \"GatewayManager.FranceSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.178.88/29\",\r\n\ + \ \"40.82.236.2/32\",\r\n \"40.82.236.13/32\",\r\n \ + \ \"51.105.88.72/29\",\r\n \"52.136.137.15/32\",\r\n \ + \ \"52.136.137.16/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"GatewayManager.GermanyNorth\",\r\n \"id\": \"GatewayManager.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.48.72/29\",\r\n \"51.116.59.32/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.GermanyWestCentral\"\ + ,\r\n \"id\": \"GatewayManager.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.116.144.72/29\"\ + ,\r\n \"51.116.155.96/29\",\r\n \"2603:1020:c04:1::40/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.JapanEast\"\ + ,\r\n \"id\": \"GatewayManager.JapanEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.78.108.16/29\"\ + ,\r\n \"20.43.64.72/29\",\r\n \"40.115.248.200/32\",\r\n\ + \ \"40.115.254.17/32\",\r\n \"2603:1040:407:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.JapanWest\"\ + ,\r\n \"id\": \"GatewayManager.JapanWest\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"40.74.100.168/29\"\ + ,\r\n \"40.80.56.72/29\",\r\n \"40.81.189.24/32\",\r\n \ + \ \"40.81.189.42/32\",\r\n \"104.215.50.115/32\",\r\n \ + \ \"104.215.52.27/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GatewayManager.KoreaCentral\",\r\n \"id\": \"GatewayManager.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"\ + addressPrefixes\": [\r\n \"20.41.64.72/29\",\r\n \"52.231.18.224/29\"\ + ,\r\n \"52.231.24.186/32\",\r\n \"52.231.35.84/32\",\r\n\ + \ \"2603:1040:f05:1::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.KoreaSouth\",\r\n \"id\"\ + : \"GatewayManager.KoreaSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.80.168.72/29\",\r\n\ + \ \"52.231.146.200/29\",\r\n \"52.231.203.87/32\",\r\n \ + \ \"52.231.204.175/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"GatewayManager.NorthCentralUS\",\r\n \"id\": \"GatewayManager.NorthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"\ + addressPrefixes\": [\r\n \"23.100.231.72/32\",\r\n \"23.100.231.96/32\"\ + ,\r\n \"23.101.173.90/32\",\r\n \"40.80.184.72/29\",\r\n\ + \ \"52.162.106.168/29\",\r\n \"168.62.104.154/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.NorthEurope\"\ + ,\r\n \"id\": \"GatewayManager.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.69.227.224/29\"\ + ,\r\n \"20.38.80.72/29\",\r\n \"52.169.225.171/32\",\r\n\ + \ \"52.169.231.163/32\",\r\n \"2603:1020:5:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.NorwayEast\"\ + ,\r\n \"id\": \"GatewayManager.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.120.40.72/29\"\ + ,\r\n \"51.120.98.168/29\",\r\n \"2603:1020:e04:1::40/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.NorwayWest\"\ + ,\r\n \"id\": \"GatewayManager.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.120.219.64/29\"\ + ,\r\n \"51.120.224.72/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"GatewayManager.SouthAfricaNorth\",\r\n \"\ + id\": \"GatewayManager.SouthAfricaNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"102.133.155.16/29\"\ + ,\r\n \"102.133.216.72/29\",\r\n \"2603:1000:104:1::40/122\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SouthAfricaWest\"\ + ,\r\n \"id\": \"GatewayManager.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"102.133.27.16/29\"\ + ,\r\n \"102.133.56.72/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"GatewayManager.SouthCentralUS\",\r\n \"id\"\ + : \"GatewayManager.SouthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.65.91.57/32\"\ + ,\r\n \"13.85.74.21/32\",\r\n \"40.119.8.64/29\",\r\n \ + \ \"70.37.160.97/32\",\r\n \"70.37.161.124/32\",\r\n \ + \ \"104.214.19.64/29\",\r\n \"2603:1030:807:1::40/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SoutheastAsia\"\ + ,\r\n \"id\": \"GatewayManager.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.67.9.128/29\"\ + ,\r\n \"20.43.128.72/29\",\r\n \"40.90.186.21/32\",\r\n\ + \ \"40.90.186.91/32\",\r\n \"52.163.241.22/32\",\r\n \ + \ \"52.163.246.27/32\",\r\n \"2603:1040:5:1::40/122\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SouthIndia\"\ + ,\r\n \"id\": \"GatewayManager.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"20.41.192.72/29\"\ + ,\r\n \"40.78.194.88/29\",\r\n \"52.172.28.183/32\",\r\n\ + \ \"52.172.31.29/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"GatewayManager.SwitzerlandNorth\",\r\n \"id\": \"\ + GatewayManager.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.48.72/29\",\r\n\ + \ \"51.107.59.32/29\",\r\n \"2603:1020:a04:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.SwitzerlandWest\"\ + ,\r\n \"id\": \"GatewayManager.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.107.144.72/29\"\ + ,\r\n \"51.107.155.32/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"GatewayManager.UAECentral\",\r\n \"id\":\ + \ \"GatewayManager.UAECentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.37.64.72/29\",\r\n \ + \ \"20.37.74.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GatewayManager.UAENorth\",\r\n \"id\": \"GatewayManager.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.136.72/29\",\r\n \"65.52.250.24/29\",\r\n\ + \ \"2603:1040:904:1::40/122\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"GatewayManager.UKNorth\",\r\n \"id\": \"\ + GatewayManager.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n\ + \ \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.87.122.104/29\",\r\n \"51.105.80.72/29\",\r\ + \n \"51.142.209.124/32\",\r\n \"51.142.210.184/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UKSouth\"\ + ,\r\n \"id\": \"GatewayManager.UKSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"51.104.24.72/29\"\ + ,\r\n \"51.140.63.41/32\",\r\n \"51.140.114.209/32\",\r\n\ + \ \"51.140.148.16/29\",\r\n \"2603:1020:705:1::40/122\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.UKSouth2\"\ + ,\r\n \"id\": \"GatewayManager.UKSouth2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"GatewayManager\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.35.147/32\",\r\n\ + \ \"13.87.36.246/32\",\r\n \"13.87.56.104/29\",\r\n \ + \ \"51.143.192.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GatewayManager.UKWest\",\r\n \"id\": \"GatewayManager.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.137.160.72/29\",\r\n \"51.140.210.200/29\",\r\n \ + \ \"51.141.25.80/32\",\r\n \"51.141.29.178/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.WestCentralUS\"\ + ,\r\n \"id\": \"GatewayManager.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.71.194.232/29\"\ + ,\r\n \"13.78.188.33/32\",\r\n \"52.150.136.72/29\",\r\n\ + \ \"52.159.19.113/32\",\r\n \"52.159.20.67/32\",\r\n \ + \ \"52.161.28.251/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GatewayManager.WestEurope\",\r\n \"id\": \"GatewayManager.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"GatewayManager\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.64.224/29\",\r\n \"13.93.112.146/32\",\r\ + \n \"13.93.117.26/32\",\r\n \"40.74.24.72/29\",\r\n \ + \ \"2603:1020:206:1::40/122\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"GatewayManager.WestIndia\",\r\n \"id\": \"\ + GatewayManager.WestIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"GatewayManager\",\r\n\ + \ \"addressPrefixes\": [\r\n \"40.81.94.172/32\",\r\n \ + \ \"40.81.94.182/32\",\r\n \"52.136.48.72/29\",\r\n \ + \ \"104.211.146.88/29\",\r\n \"104.211.188.0/32\",\r\n \ + \ \"104.211.191.94/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"GatewayManager.WestUS\",\r\n \"id\": \"GatewayManager.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.91.249.235/32\",\r\n \"13.91.254.232/32\",\r\n \ + \ \"40.82.248.240/29\",\r\n \"40.112.242.168/29\",\r\n \ + \ \"168.62.208.162/32\",\r\n \"168.62.209.95/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GatewayManager.WestUS2\"\ + ,\r\n \"id\": \"GatewayManager.WestUS2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"GatewayManager\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.144/29\"\ + ,\r\n \"20.42.128.72/29\",\r\n \"52.149.24.100/32\",\r\n\ + \ \"52.149.26.14/32\",\r\n \"52.191.140.123/32\",\r\n \ + \ \"52.191.170.38/32\",\r\n \"2603:1030:c06:1::40/122\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement\"\ + ,\r\n \"id\": \"GuestAndHybridManagement\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"13.65.24.129/32\"\ + ,\r\n \"13.66.138.94/31\",\r\n \"13.66.141.224/29\",\r\n\ + \ \"13.66.145.80/28\",\r\n \"13.67.8.110/31\",\r\n \ + \ \"13.67.10.72/29\",\r\n \"13.69.64.78/31\",\r\n \"\ + 13.69.67.48/29\",\r\n \"13.69.107.64/29\",\r\n \"13.69.109.128/31\"\ + ,\r\n \"13.69.109.176/28\",\r\n \"13.69.227.78/31\",\r\n\ + \ \"13.69.229.248/29\",\r\n \"13.70.72.30/31\",\r\n \ + \ \"13.70.74.80/29\",\r\n \"13.70.123.166/32\",\r\n \ + \ \"13.71.170.46/31\",\r\n \"13.71.173.208/29\",\r\n \"\ + 13.71.175.144/28\",\r\n \"13.71.194.118/31\",\r\n \"13.71.196.128/29\"\ + ,\r\n \"13.71.199.176/28\",\r\n \"13.73.242.40/29\",\r\n\ + \ \"13.73.242.210/31\",\r\n \"13.73.244.208/28\",\r\n \ + \ \"13.74.107.92/31\",\r\n \"13.74.108.136/29\",\r\n \ + \ \"13.75.34.150/31\",\r\n \"13.75.39.104/29\",\r\n \ + \ \"13.77.1.26/32\",\r\n \"13.77.1.212/32\",\r\n \"13.77.50.70/31\"\ + ,\r\n \"13.77.53.56/29\",\r\n \"13.77.55.192/28\",\r\n \ + \ \"13.78.59.184/32\",\r\n \"13.78.106.94/31\",\r\n \ + \ \"13.78.109.120/29\",\r\n \"13.78.111.208/28\",\r\n \ + \ \"13.86.219.200/29\",\r\n \"13.86.221.216/31\",\r\n \ + \ \"13.86.223.64/28\",\r\n \"13.87.56.86/31\",\r\n \"13.87.58.72/29\"\ + ,\r\n \"13.87.122.86/31\",\r\n \"13.87.124.72/29\",\r\n\ + \ \"13.88.240.74/32\",\r\n \"13.88.244.195/32\",\r\n \ + \ \"13.89.170.206/31\",\r\n \"13.89.174.136/29\",\r\n \ + \ \"13.89.178.96/28\",\r\n \"13.94.240.75/32\",\r\n \ + \ \"20.36.39.150/32\",\r\n \"20.36.106.70/31\",\r\n \"20.36.108.128/29\"\ + ,\r\n \"20.36.108.240/28\",\r\n \"20.36.114.22/31\",\r\n\ + \ \"20.36.117.32/29\",\r\n \"20.36.117.144/28\",\r\n \ + \ \"20.37.74.226/31\",\r\n \"20.37.76.120/29\",\r\n \ + \ \"20.38.128.104/29\",\r\n \"20.38.128.168/31\",\r\n \ + \ \"20.38.132.0/28\",\r\n \"20.38.147.152/29\",\r\n \"20.38.149.128/31\"\ + ,\r\n \"20.42.64.32/31\",\r\n \"20.42.72.128/31\",\r\n \ + \ \"20.42.72.144/28\",\r\n \"20.43.120.248/29\",\r\n \ + \ \"20.43.121.120/31\",\r\n \"20.43.123.48/28\",\r\n \ + \ \"20.44.2.6/31\",\r\n \"20.44.4.104/29\",\r\n \"20.44.8.200/29\"\ + ,\r\n \"20.44.10.120/31\",\r\n \"20.44.17.8/29\",\r\n \ + \ \"20.44.17.216/31\",\r\n \"20.44.19.16/28\",\r\n \ + \ \"20.44.27.112/29\",\r\n \"20.44.29.48/31\",\r\n \"\ + 20.44.29.96/28\",\r\n \"20.45.123.88/29\",\r\n \"20.45.123.232/31\"\ + ,\r\n \"20.49.82.24/29\",\r\n \"20.49.90.24/29\",\r\n \ + \ \"20.150.171.216/29\",\r\n \"20.150.172.224/31\",\r\n \ + \ \"20.150.179.192/29\",\r\n \"20.150.181.24/31\",\r\n \ + \ \"20.150.181.176/28\",\r\n \"20.150.187.192/29\",\r\n \ + \ \"20.150.189.24/31\",\r\n \"20.192.99.192/29\",\r\n \ + \ \"20.192.101.24/31\",\r\n \"20.192.184.64/28\",\r\n \ + \ \"20.192.234.176/28\",\r\n \"20.192.235.8/29\",\r\n \ + \ \"20.192.238.120/31\",\r\n \"20.193.202.176/28\",\r\n \ + \ \"20.193.203.192/29\",\r\n \"20.194.66.24/29\",\r\n \"\ + 23.96.225.107/32\",\r\n \"23.96.225.182/32\",\r\n \"23.98.83.64/29\"\ + ,\r\n \"23.98.86.56/31\",\r\n \"40.67.60.96/29\",\r\n \ + \ \"40.67.60.108/31\",\r\n \"40.69.106.70/31\",\r\n \ + \ \"40.69.108.88/29\",\r\n \"40.69.110.240/28\",\r\n \ + \ \"40.70.146.78/31\",\r\n \"40.70.148.48/29\",\r\n \"40.71.10.206/31\"\ + ,\r\n \"40.71.13.240/29\",\r\n \"40.71.30.252/32\",\r\n\ + \ \"40.74.146.82/31\",\r\n \"40.74.149.32/29\",\r\n \ + \ \"40.74.150.16/28\",\r\n \"40.75.35.128/29\",\r\n \ + \ \"40.75.35.216/31\",\r\n \"40.78.194.70/31\",\r\n \"\ + 40.78.196.88/29\",\r\n \"40.78.202.130/31\",\r\n \"40.78.203.248/29\"\ + ,\r\n \"40.78.229.40/29\",\r\n \"40.78.236.128/29\",\r\n\ + \ \"40.78.238.56/31\",\r\n \"40.78.239.32/28\",\r\n \ + \ \"40.78.242.172/31\",\r\n \"40.78.243.24/29\",\r\n \ + \ \"40.78.250.108/31\",\r\n \"40.78.250.216/29\",\r\n \ + \ \"40.79.130.46/31\",\r\n \"40.79.132.40/29\",\r\n \"40.79.138.44/31\"\ + ,\r\n \"40.79.138.152/29\",\r\n \"40.79.139.208/28\",\r\n\ + \ \"40.79.146.44/31\",\r\n \"40.79.146.152/29\",\r\n \ + \ \"40.79.156.40/29\",\r\n \"40.79.163.8/29\",\r\n \ + \ \"40.79.163.152/31\",\r\n \"40.79.170.248/29\",\r\n \"\ + 40.79.171.224/31\",\r\n \"40.79.173.16/28\",\r\n \"40.79.178.70/31\"\ + ,\r\n \"40.79.180.56/29\",\r\n \"40.79.180.208/28\",\r\n\ + \ \"40.79.187.160/29\",\r\n \"40.79.189.56/31\",\r\n \ + \ \"40.79.194.120/29\",\r\n \"40.79.197.32/31\",\r\n \ + \ \"40.80.51.88/29\",\r\n \"40.80.53.0/31\",\r\n \"40.80.176.48/29\"\ + ,\r\n \"40.80.180.0/31\",\r\n \"40.80.180.96/28\",\r\n \ + \ \"40.85.168.201/32\",\r\n \"40.89.129.151/32\",\r\n \ + \ \"40.89.132.62/32\",\r\n \"40.89.137.16/32\",\r\n \ + \ \"40.89.157.7/32\",\r\n \"40.114.77.89/32\",\r\n \"\ + 40.114.85.4/32\",\r\n \"40.118.103.191/32\",\r\n \"40.120.8.32/28\"\ + ,\r\n \"40.120.64.48/28\",\r\n \"40.120.75.48/29\",\r\n\ + \ \"51.11.97.0/31\",\r\n \"51.11.97.64/28\",\r\n \ + \ \"51.12.99.208/29\",\r\n \"51.12.203.72/29\",\r\n \"\ + 51.12.227.192/29\",\r\n \"51.12.235.192/29\",\r\n \"51.104.8.240/29\"\ + ,\r\n \"51.104.9.96/31\",\r\n \"51.105.67.168/29\",\r\n\ + \ \"51.105.69.80/31\",\r\n \"51.105.75.152/29\",\r\n \ + \ \"51.105.77.48/31\",\r\n \"51.105.77.80/28\",\r\n \ + \ \"51.107.60.80/29\",\r\n \"51.107.60.92/31\",\r\n \"\ + 51.107.60.208/28\",\r\n \"51.107.156.72/29\",\r\n \"51.107.156.132/31\"\ + ,\r\n \"51.107.156.208/28\",\r\n \"51.116.60.80/29\",\r\n\ + \ \"51.116.60.224/28\",\r\n \"51.116.156.160/29\",\r\n \ + \ \"51.116.158.56/31\",\r\n \"51.116.158.80/28\",\r\n \ + \ \"51.116.243.144/29\",\r\n \"51.116.243.216/31\",\r\n \ + \ \"51.116.251.32/29\",\r\n \"51.116.251.184/31\",\r\n \ + \ \"51.120.100.80/29\",\r\n \"51.120.100.92/31\",\r\n \ + \ \"51.120.107.192/29\",\r\n \"51.120.109.24/31\",\r\n \ + \ \"51.120.109.48/28\",\r\n \"51.120.211.192/29\",\r\n \ + \ \"51.120.213.24/31\",\r\n \"51.120.220.80/29\",\r\n \"\ + 51.120.220.92/31\",\r\n \"51.120.220.176/28\",\r\n \"51.140.6.15/32\"\ + ,\r\n \"51.140.51.174/32\",\r\n \"51.140.212.104/29\",\r\ + \n \"52.138.90.52/31\",\r\n \"52.138.92.80/29\",\r\n \ + \ \"52.138.227.136/29\",\r\n \"52.138.229.64/31\",\r\n \ + \ \"52.138.229.80/28\",\r\n \"52.147.97.0/31\",\r\n \ + \ \"52.151.62.99/32\",\r\n \"52.161.14.192/32\",\r\n \"\ + 52.161.28.108/32\",\r\n \"52.162.110.240/29\",\r\n \"52.162.111.128/31\"\ + ,\r\n \"52.163.228.23/32\",\r\n \"52.167.107.72/29\",\r\n\ + \ \"52.167.109.64/31\",\r\n \"52.169.105.82/32\",\r\n \ + \ \"52.172.153.216/32\",\r\n \"52.172.155.142/32\",\r\n \ + \ \"52.178.223.62/32\",\r\n \"52.180.166.238/32\",\r\n \ + \ \"52.180.179.25/32\",\r\n \"52.182.139.56/29\",\r\n \ + \ \"52.182.141.12/31\",\r\n \"52.182.141.144/28\",\r\n \ + \ \"52.183.5.195/32\",\r\n \"52.231.18.46/31\",\r\n \"\ + 52.231.20.0/29\",\r\n \"52.231.64.18/32\",\r\n \"52.231.69.100/32\"\ + ,\r\n \"52.231.148.120/29\",\r\n \"52.231.148.208/28\",\r\ + \n \"52.236.186.240/29\",\r\n \"52.236.189.72/31\",\r\n\ + \ \"52.240.241.64/28\",\r\n \"52.246.155.152/29\",\r\n \ + \ \"52.246.157.0/31\",\r\n \"65.52.250.6/31\",\r\n \ + \ \"65.52.252.120/29\",\r\n \"102.37.64.32/28\",\r\n \ + \ \"102.133.26.6/31\",\r\n \"102.133.28.144/29\",\r\n \"\ + 102.133.124.16/29\",\r\n \"102.133.156.112/29\",\r\n \"\ + 102.133.251.176/29\",\r\n \"102.133.253.32/28\",\r\n \"\ + 104.41.9.106/32\",\r\n \"104.41.178.182/32\",\r\n \"104.208.163.218/32\"\ + ,\r\n \"104.209.137.89/32\",\r\n \"104.210.80.208/32\",\r\ + \n \"104.210.158.71/32\",\r\n \"104.214.164.32/28\",\r\n\ + \ \"104.215.254.56/32\",\r\n \"168.61.140.48/28\",\r\n \ + \ \"191.232.170.251/32\",\r\n \"191.233.51.144/29\",\r\n\ + \ \"191.233.203.30/31\",\r\n \"191.233.205.64/29\",\r\n\ + \ \"191.234.147.192/29\",\r\n \"191.234.149.48/28\",\r\n\ + \ \"191.234.149.136/31\",\r\n \"191.234.155.192/29\",\r\n\ + \ \"191.234.157.40/31\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"GuestAndHybridManagement.BrazilSouth\",\r\n \ + \ \"id\": \"GuestAndHybridManagement.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"104.41.9.106/32\"\ + ,\r\n \"191.232.170.251/32\",\r\n \"191.233.203.30/31\"\ + ,\r\n \"191.233.205.64/29\",\r\n \"191.234.147.192/29\"\ + ,\r\n \"191.234.149.48/28\",\r\n \"191.234.149.136/31\"\ + ,\r\n \"191.234.155.192/29\",\r\n \"191.234.157.40/31\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.CentralUS\"\ + ,\r\n \"id\": \"GuestAndHybridManagement.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"13.89.170.206/31\"\ + ,\r\n \"13.89.174.136/29\",\r\n \"13.89.178.96/28\",\r\n\ + \ \"20.44.8.200/29\",\r\n \"20.44.10.120/31\",\r\n \ + \ \"52.182.139.56/29\",\r\n \"52.182.141.12/31\",\r\n \ + \ \"52.182.141.144/28\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"GuestAndHybridManagement.KoreaCentral\",\r\n \"id\"\ + : \"GuestAndHybridManagement.KoreaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"20.44.27.112/29\"\ + ,\r\n \"20.44.29.48/31\",\r\n \"20.44.29.96/28\",\r\n \ + \ \"20.194.66.24/29\",\r\n \"52.231.18.46/31\",\r\n \ + \ \"52.231.20.0/29\",\r\n \"52.231.64.18/32\",\r\n \"\ + 52.231.69.100/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"GuestAndHybridManagement.NorwayEast\",\r\n \"id\": \"GuestAndHybridManagement.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.100.80/29\",\r\n \"51.120.100.92/31\",\r\n \ + \ \"51.120.107.192/29\",\r\n \"51.120.109.24/31\",\r\n \ + \ \"51.120.109.48/28\",\r\n \"51.120.211.192/29\",\r\n \ + \ \"51.120.213.24/31\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"GuestAndHybridManagement.NorwayWest\",\r\n \"id\"\ + : \"GuestAndHybridManagement.NorwayWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"51.120.220.80/29\"\ + ,\r\n \"51.120.220.92/31\",\r\n \"51.120.220.176/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.SouthIndia\"\ + ,\r\n \"id\": \"GuestAndHybridManagement.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"20.192.184.64/28\"\ + ,\r\n \"40.78.194.70/31\",\r\n \"40.78.196.88/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.SwitzerlandWest\"\ + ,\r\n \"id\": \"GuestAndHybridManagement.SwitzerlandWest\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.107.156.72/29\",\r\n \"51.107.156.132/31\",\r\n \ + \ \"51.107.156.208/28\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"GuestAndHybridManagement.UAECentral\",\r\n \"id\"\ + : \"GuestAndHybridManagement.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.226/31\"\ + ,\r\n \"20.37.76.120/29\",\r\n \"40.120.8.32/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.UKWest\"\ + ,\r\n \"id\": \"GuestAndHybridManagement.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"51.11.97.0/31\"\ + ,\r\n \"51.11.97.64/28\",\r\n \"51.140.212.104/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"GuestAndHybridManagement.WestIndia\"\ + ,\r\n \"id\": \"GuestAndHybridManagement.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureAutomation\",\r\n \"addressPrefixes\": [\r\n \"20.38.128.104/29\"\ + ,\r\n \"20.38.128.168/31\",\r\n \"20.38.132.0/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight\",\r\ + \n \"id\": \"HDInsight\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"HDInsight\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.64.254.98/32\",\r\n \"13.66.141.144/29\",\r\ + \n \"13.67.9.152/29\",\r\n \"13.69.65.8/29\",\r\n \ + \ \"13.69.229.72/29\",\r\n \"13.70.73.96/29\",\r\n \"\ + 13.71.172.240/29\",\r\n \"13.71.196.48/29\",\r\n \"13.73.240.8/29\"\ + ,\r\n \"13.74.153.132/32\",\r\n \"13.75.38.112/29\",\r\n\ + \ \"13.75.152.195/32\",\r\n \"13.76.136.249/32\",\r\n \ + \ \"13.76.245.160/32\",\r\n \"13.77.2.56/32\",\r\n \ + \ \"13.77.2.94/32\",\r\n \"13.77.52.8/29\",\r\n \"13.78.89.60/32\"\ + ,\r\n \"13.78.125.90/32\",\r\n \"13.82.225.233/32\",\r\n\ + \ \"13.86.218.240/29\",\r\n \"13.87.58.32/29\",\r\n \ + \ \"13.87.124.32/29\",\r\n \"13.89.171.120/29\",\r\n \ + \ \"20.36.36.33/32\",\r\n \"20.36.36.196/32\",\r\n \"\ + 20.37.76.96/29\",\r\n \"20.43.120.8/29\",\r\n \"20.44.4.64/29\"\ + ,\r\n \"20.44.16.8/29\",\r\n \"20.44.26.240/29\",\r\n \ + \ \"20.150.172.232/29\",\r\n \"20.192.235.248/29\",\r\n \ + \ \"20.193.203.200/29\",\r\n \"23.99.5.239/32\",\r\n \ + \ \"23.101.196.19/32\",\r\n \"23.102.235.122/32\",\r\n \ + \ \"40.67.60.64/29\",\r\n \"40.69.107.8/29\",\r\n \"\ + 40.71.13.160/29\",\r\n \"40.71.175.99/32\",\r\n \"40.74.101.192/29\"\ + ,\r\n \"40.74.125.69/32\",\r\n \"40.74.146.88/29\",\r\n\ + \ \"40.78.195.8/29\",\r\n \"40.78.202.136/29\",\r\n \ + \ \"40.79.130.248/29\",\r\n \"40.79.180.16/29\",\r\n \ + \ \"40.79.187.0/29\",\r\n \"40.89.65.220/32\",\r\n \"\ + 40.89.68.134/32\",\r\n \"40.89.153.54/32\",\r\n \"40.89.156.151/32\"\ + ,\r\n \"51.104.8.96/29\",\r\n \"51.107.60.48/29\",\r\n \ + \ \"51.107.156.56/29\",\r\n \"51.116.60.48/29\",\r\n \ + \ \"51.116.156.48/29\",\r\n \"51.120.100.48/29\",\r\n \ + \ \"51.120.220.48/29\",\r\n \"51.140.47.39/32\",\r\n \ + \ \"51.140.52.16/32\",\r\n \"51.140.211.24/29\",\r\n \"\ + 51.141.7.20/32\",\r\n \"51.141.13.110/32\",\r\n \"52.161.10.167/32\"\ + ,\r\n \"52.161.23.15/32\",\r\n \"52.162.110.160/29\",\r\n\ + \ \"52.164.210.96/32\",\r\n \"52.166.243.90/32\",\r\n \ + \ \"52.172.152.49/32\",\r\n \"52.172.153.209/32\",\r\n \ + \ \"52.174.36.244/32\",\r\n \"52.175.38.134/32\",\r\n \ + \ \"52.175.211.210/32\",\r\n \"52.175.222.222/32\",\r\n \ + \ \"52.180.183.49/32\",\r\n \"52.180.183.58/32\",\r\n \ + \ \"52.228.37.66/32\",\r\n \"52.228.45.222/32\",\r\n \"\ + 52.229.123.172/32\",\r\n \"52.229.127.96/32\",\r\n \"52.231.36.209/32\"\ + ,\r\n \"52.231.39.142/32\",\r\n \"52.231.147.24/29\",\r\n\ + \ \"52.231.203.16/32\",\r\n \"52.231.205.214/32\",\r\n \ + \ \"65.52.252.96/29\",\r\n \"102.133.28.80/29\",\r\n \ + \ \"102.133.124.0/29\",\r\n \"104.210.84.115/32\",\r\n \ + \ \"104.211.216.210/32\",\r\n \"104.211.223.67/32\",\r\n \ + \ \"138.91.29.150/32\",\r\n \"138.91.141.162/32\",\r\n \ + \ \"157.55.213.99/32\",\r\n \"157.56.8.38/32\",\r\n \ + \ \"168.61.48.131/32\",\r\n \"168.61.49.99/32\",\r\n \"\ + 191.233.51.152/29\",\r\n \"191.233.204.240/29\",\r\n \"\ + 191.235.84.104/32\",\r\n \"191.235.87.113/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"HDInsight.AustraliaCentral\"\ + ,\r\n \"id\": \"HDInsight.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.36.36.33/32\"\ + ,\r\n \"20.36.36.196/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"HDInsight.AustraliaEast\",\r\n \"id\": \"\ + HDInsight.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.70.73.96/29\",\r\n \ + \ \"13.75.152.195/32\",\r\n \"104.210.84.115/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.AustraliaSoutheast\"\ + ,\r\n \"id\": \"HDInsight.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.77.2.56/32\"\ + ,\r\n \"13.77.2.94/32\",\r\n \"13.77.52.8/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.BrazilSouth\"\ + ,\r\n \"id\": \"HDInsight.BrazilSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"191.233.204.240/29\"\ + ,\r\n \"191.235.84.104/32\",\r\n \"191.235.87.113/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.CanadaCentral\"\ + ,\r\n \"id\": \"HDInsight.CanadaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.71.172.240/29\"\ + ,\r\n \"52.228.37.66/32\",\r\n \"52.228.45.222/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.CanadaEast\"\ + ,\r\n \"id\": \"HDInsight.CanadaEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.69.107.8/29\"\ + ,\r\n \"52.229.123.172/32\",\r\n \"52.229.127.96/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.CentralIndia\"\ + ,\r\n \"id\": \"HDInsight.CentralIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.43.120.8/29\"\ + ,\r\n \"52.172.152.49/32\",\r\n \"52.172.153.209/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.CentralUS\"\ + ,\r\n \"id\": \"HDInsight.CentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.89.171.120/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.CentralUSEUAP\"\ + ,\r\n \"id\": \"HDInsight.CentralUSEUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.78.202.136/29\"\ + ,\r\n \"52.180.183.49/32\",\r\n \"52.180.183.58/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastAsia\"\ + ,\r\n \"id\": \"HDInsight.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.75.38.112/29\"\ + ,\r\n \"23.102.235.122/32\",\r\n \"52.175.38.134/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastUS\"\ + ,\r\n \"id\": \"HDInsight.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.82.225.233/32\"\ + ,\r\n \"40.71.13.160/29\",\r\n \"40.71.175.99/32\",\r\n\ + \ \"168.61.48.131/32\",\r\n \"168.61.49.99/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastUS2\"\ + ,\r\n \"id\": \"HDInsight.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.44.16.8/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.EastUS2EUAP\"\ + ,\r\n \"id\": \"HDInsight.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.74.146.88/29\"\ + ,\r\n \"40.89.65.220/32\",\r\n \"40.89.68.134/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.FranceCentral\"\ + ,\r\n \"id\": \"HDInsight.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.79.130.248/29\"\ + ,\r\n \"40.89.153.54/32\",\r\n \"40.89.156.151/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.FranceSouth\"\ + ,\r\n \"id\": \"HDInsight.FranceSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.79.180.16/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.GermanyNorth\"\ + ,\r\n \"id\": \"HDInsight.GermanyNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.116.60.48/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.GermanyWestCentral\"\ + ,\r\n \"id\": \"HDInsight.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\ + \n \"addressPrefixes\": [\r\n \"51.116.156.48/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.JapanEast\"\ + ,\r\n \"id\": \"HDInsight.JapanEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.78.89.60/32\"\ + ,\r\n \"13.78.125.90/32\",\r\n \"40.79.187.0/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.JapanWest\"\ + ,\r\n \"id\": \"HDInsight.JapanWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.74.101.192/29\"\ + ,\r\n \"40.74.125.69/32\",\r\n \"138.91.29.150/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.KoreaCentral\"\ + ,\r\n \"id\": \"HDInsight.KoreaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.44.26.240/29\"\ + ,\r\n \"52.231.36.209/32\",\r\n \"52.231.39.142/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.KoreaSouth\"\ + ,\r\n \"id\": \"HDInsight.KoreaSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"52.231.147.24/29\"\ + ,\r\n \"52.231.203.16/32\",\r\n \"52.231.205.214/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorthCentralUS\"\ + ,\r\n \"id\": \"HDInsight.NorthCentralUS\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"52.162.110.160/29\"\ + ,\r\n \"157.55.213.99/32\",\r\n \"157.56.8.38/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorthEurope\"\ + ,\r\n \"id\": \"HDInsight.NorthEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.69.229.72/29\"\ + ,\r\n \"13.74.153.132/32\",\r\n \"52.164.210.96/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorwayEast\"\ + ,\r\n \"id\": \"HDInsight.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.120.100.48/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.NorwayWest\"\ + ,\r\n \"id\": \"HDInsight.NorwayWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.120.220.48/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SouthAfricaNorth\"\ + ,\r\n \"id\": \"HDInsight.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"102.133.124.0/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SouthAfricaWest\"\ + ,\r\n \"id\": \"HDInsight.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"102.133.28.80/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SouthCentralUS\"\ + ,\r\n \"id\": \"HDInsight.SouthCentralUS\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.73.240.8/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SoutheastAsia\"\ + ,\r\n \"id\": \"HDInsight.SoutheastAsia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.67.9.152/29\"\ + ,\r\n \"13.76.136.249/32\",\r\n \"13.76.245.160/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SouthIndia\"\ + ,\r\n \"id\": \"HDInsight.SouthIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"40.78.195.8/29\"\ + ,\r\n \"104.211.216.210/32\",\r\n \"104.211.223.67/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SwitzerlandNorth\"\ + ,\r\n \"id\": \"HDInsight.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\ + \n \"addressPrefixes\": [\r\n \"51.107.60.48/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.SwitzerlandWest\"\ + ,\r\n \"id\": \"HDInsight.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.107.156.56/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UAECentral\"\ + ,\r\n \"id\": \"HDInsight.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"20.37.76.96/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UAENorth\"\ + ,\r\n \"id\": \"HDInsight.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"65.52.252.96/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKNorth\"\ + ,\r\n \"id\": \"HDInsight.UKNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.87.124.32/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKSouth\"\ + ,\r\n \"id\": \"HDInsight.UKSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.104.8.96/29\"\ + ,\r\n \"51.140.47.39/32\",\r\n \"51.140.52.16/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKSouth2\"\ + ,\r\n \"id\": \"HDInsight.UKSouth2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"HDInsight\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.58.32/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.UKWest\"\ + ,\r\n \"id\": \"HDInsight.UKWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + HDInsight\",\r\n \"addressPrefixes\": [\r\n \"51.140.211.24/29\"\ + ,\r\n \"51.141.7.20/32\",\r\n \"51.141.13.110/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestCentralUS\"\ + ,\r\n \"id\": \"HDInsight.WestCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.71.196.48/29\"\ + ,\r\n \"52.161.10.167/32\",\r\n \"52.161.23.15/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestEurope\"\ + ,\r\n \"id\": \"HDInsight.WestEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.69.65.8/29\"\ + ,\r\n \"52.166.243.90/32\",\r\n \"52.174.36.244/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestUS\"\ + ,\r\n \"id\": \"HDInsight.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.64.254.98/32\"\ + ,\r\n \"13.86.218.240/29\",\r\n \"23.99.5.239/32\",\r\n\ + \ \"23.101.196.19/32\",\r\n \"138.91.141.162/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"HDInsight.WestUS2\"\ + ,\r\n \"id\": \"HDInsight.WestUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"HDInsight\",\r\n \"addressPrefixes\": [\r\n \"13.66.141.144/29\"\ + ,\r\n \"52.175.211.210/32\",\r\n \"52.175.222.222/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps\"\ + ,\r\n \"id\": \"LogicApps\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.65.39.247/32\"\ + ,\r\n \"13.65.82.17/32\",\r\n \"13.65.82.190/32\",\r\n \ + \ \"13.65.86.56/32\",\r\n \"13.65.98.39/32\",\r\n \ + \ \"13.66.52.232/32\",\r\n \"13.66.128.68/32\",\r\n \"\ + 13.66.201.169/32\",\r\n \"13.66.210.167/32\",\r\n \"13.66.224.169/32\"\ + ,\r\n \"13.66.246.219/32\",\r\n \"13.67.13.224/27\",\r\n\ + \ \"13.67.91.135/32\",\r\n \"13.67.107.128/32\",\r\n \ + \ \"13.67.110.109/32\",\r\n \"13.67.236.76/32\",\r\n \ + \ \"13.67.236.125/32\",\r\n \"13.69.71.160/27\",\r\n \ + \ \"13.69.109.144/28\",\r\n \"13.69.231.160/27\",\r\n \"\ + 13.69.233.16/28\",\r\n \"13.70.78.192/27\",\r\n \"13.70.159.205/32\"\ + ,\r\n \"13.71.146.140/32\",\r\n \"13.71.158.3/32\",\r\n\ + \ \"13.71.158.120/32\",\r\n \"13.71.184.150/32\",\r\n \ + \ \"13.71.186.1/32\",\r\n \"13.71.199.128/27\",\r\n \ + \ \"13.71.199.160/28\",\r\n \"13.73.4.207/32\",\r\n \"\ + 13.73.114.207/32\",\r\n \"13.73.115.153/32\",\r\n \"13.73.244.144/28\"\ + ,\r\n \"13.73.244.160/27\",\r\n \"13.75.89.159/32\",\r\n\ + \ \"13.75.94.173/32\",\r\n \"13.75.149.4/32\",\r\n \ + \ \"13.75.153.66/32\",\r\n \"13.76.4.194/32\",\r\n \"\ + 13.76.5.96/32\",\r\n \"13.76.133.155/32\",\r\n \"13.77.3.139/32\"\ + ,\r\n \"13.77.53.224/27\",\r\n \"13.77.55.128/28\",\r\n\ + \ \"13.77.56.167/32\",\r\n \"13.77.58.136/32\",\r\n \ + \ \"13.77.149.159/32\",\r\n \"13.77.152.21/32\",\r\n \ + \ \"13.78.18.168/32\",\r\n \"13.78.20.232/32\",\r\n \"\ + 13.78.21.155/32\",\r\n \"13.78.35.229/32\",\r\n \"13.78.42.223/32\"\ + ,\r\n \"13.78.43.164/32\",\r\n \"13.78.62.130/32\",\r\n\ + \ \"13.78.84.187/32\",\r\n \"13.78.111.160/27\",\r\n \ + \ \"13.78.129.20/32\",\r\n \"13.78.137.179/32\",\r\n \ + \ \"13.78.137.247/32\",\r\n \"13.78.141.75/32\",\r\n \ + \ \"13.78.148.140/32\",\r\n \"13.78.151.161/32\",\r\n \"\ + 13.79.173.49/32\",\r\n \"13.84.41.46/32\",\r\n \"13.84.43.45/32\"\ + ,\r\n \"13.84.159.168/32\",\r\n \"13.85.79.155/32\",\r\n\ + \ \"13.86.221.240/28\",\r\n \"13.86.223.0/27\",\r\n \ + \ \"13.87.58.144/28\",\r\n \"13.87.58.160/27\",\r\n \ + \ \"13.87.124.144/28\",\r\n \"13.87.124.160/27\",\r\n \"\ + 13.88.249.209/32\",\r\n \"13.89.178.48/28\",\r\n \"13.91.252.184/32\"\ + ,\r\n \"13.92.98.111/32\",\r\n \"13.95.147.65/32\",\r\n\ + \ \"13.95.155.53/32\",\r\n \"13.106.118.32/27\",\r\n \ + \ \"13.106.118.96/27\",\r\n \"20.36.108.192/27\",\r\n \ + \ \"20.36.108.224/28\",\r\n \"20.36.117.96/27\",\r\n \ + \ \"20.36.117.128/28\",\r\n \"20.37.76.208/28\",\r\n \"\ + 20.37.76.224/27\",\r\n \"20.38.128.176/28\",\r\n \"20.38.128.192/27\"\ + ,\r\n \"20.38.149.144/28\",\r\n \"20.38.149.160/27\",\r\n\ + \ \"20.42.64.48/28\",\r\n \"20.42.72.160/27\",\r\n \ + \ \"20.43.121.192/27\",\r\n \"20.43.121.224/28\",\r\n \ + \ \"20.44.4.176/28\",\r\n \"20.44.4.192/27\",\r\n \"20.44.17.224/27\"\ + ,\r\n \"20.45.64.29/32\",\r\n \"20.45.64.87/32\",\r\n \ + \ \"20.45.67.134/31\",\r\n \"20.45.67.170/32\",\r\n \ + \ \"20.45.71.213/32\",\r\n \"20.45.72.54/32\",\r\n \"\ + 20.45.72.72/32\",\r\n \"20.45.75.193/32\",\r\n \"20.45.75.200/32\"\ + ,\r\n \"20.45.75.236/32\",\r\n \"20.45.79.239/32\",\r\n\ + \ \"20.150.172.240/28\",\r\n \"20.150.173.192/27\",\r\n\ + \ \"20.150.181.32/27\",\r\n \"20.188.33.169/32\",\r\n \ + \ \"20.188.39.105/32\",\r\n \"20.192.184.0/27\",\r\n \ + \ \"20.192.238.128/27\",\r\n \"20.192.238.160/28\",\r\n \ + \ \"20.193.206.48/28\",\r\n \"20.193.206.128/27\",\r\n \ + \ \"23.96.200.77/32\",\r\n \"23.96.200.227/32\",\r\n \ + \ \"23.96.203.46/32\",\r\n \"23.96.210.49/32\",\r\n \"23.96.212.28/32\"\ + ,\r\n \"23.96.253.219/32\",\r\n \"23.97.68.172/32\",\r\n\ + \ \"23.97.210.126/32\",\r\n \"23.97.211.179/32\",\r\n \ + \ \"23.97.218.130/32\",\r\n \"23.99.125.99/32\",\r\n \ + \ \"23.100.29.190/32\",\r\n \"23.100.82.16/32\",\r\n \ + \ \"23.100.86.139/32\",\r\n \"23.100.87.24/32\",\r\n \"\ + 23.100.87.56/32\",\r\n \"23.100.124.84/32\",\r\n \"23.100.127.172/32\"\ + ,\r\n \"23.101.132.208/32\",\r\n \"23.101.136.201/32\",\r\ + \n \"23.101.139.153/32\",\r\n \"23.101.183.225/32\",\r\n\ + \ \"23.101.191.106/32\",\r\n \"23.102.70.174/32\",\r\n \ + \ \"40.67.60.176/28\",\r\n \"40.67.60.192/27\",\r\n \ + \ \"40.68.209.23/32\",\r\n \"40.68.222.65/32\",\r\n \ + \ \"40.69.110.192/27\",\r\n \"40.69.110.224/28\",\r\n \"\ + 40.70.26.154/32\",\r\n \"40.70.27.236/32\",\r\n \"40.70.27.253/32\"\ + ,\r\n \"40.70.29.214/32\",\r\n \"40.70.131.151/32\",\r\n\ + \ \"40.74.64.207/32\",\r\n \"40.74.66.200/32\",\r\n \ + \ \"40.74.68.85/32\",\r\n \"40.74.74.21/32\",\r\n \"\ + 40.74.76.213/32\",\r\n \"40.74.77.205/32\",\r\n \"40.74.81.13/32\"\ + ,\r\n \"40.74.85.215/32\",\r\n \"40.74.131.151/32\",\r\n\ + \ \"40.74.132.29/32\",\r\n \"40.74.136.23/32\",\r\n \ + \ \"40.74.140.4/32\",\r\n \"40.74.140.162/32\",\r\n \ + \ \"40.74.140.173/32\",\r\n \"40.74.142.133/32\",\r\n \"\ + 40.74.143.215/32\",\r\n \"40.74.149.96/27\",\r\n \"40.75.35.240/28\"\ + ,\r\n \"40.77.31.87/32\",\r\n \"40.77.111.254/32\",\r\n\ + \ \"40.78.196.176/28\",\r\n \"40.78.204.208/28\",\r\n \ + \ \"40.78.204.224/27\",\r\n \"40.78.239.16/28\",\r\n \ + \ \"40.78.245.144/28\",\r\n \"40.78.245.160/27\",\r\n \ + \ \"40.79.44.7/32\",\r\n \"40.79.139.144/28\",\r\n \"\ + 40.79.139.160/27\",\r\n \"40.79.171.240/28\",\r\n \"40.79.180.160/27\"\ + ,\r\n \"40.79.180.192/28\",\r\n \"40.79.197.48/28\",\r\n\ + \ \"40.80.180.16/28\",\r\n \"40.80.180.32/27\",\r\n \ + \ \"40.83.73.39/32\",\r\n \"40.83.75.165/32\",\r\n \ + \ \"40.83.77.208/32\",\r\n \"40.83.98.194/32\",\r\n \"40.83.100.69/32\"\ + ,\r\n \"40.83.127.19/32\",\r\n \"40.83.164.80/32\",\r\n\ + \ \"40.84.25.234/32\",\r\n \"40.84.30.147/32\",\r\n \ + \ \"40.84.59.136/32\",\r\n \"40.84.138.132/32\",\r\n \ + \ \"40.85.241.105/32\",\r\n \"40.85.250.135/32\",\r\n \ + \ \"40.85.250.212/32\",\r\n \"40.85.252.47/32\",\r\n \"\ + 40.86.202.42/32\",\r\n \"40.86.203.228/32\",\r\n \"40.86.216.241/32\"\ + ,\r\n \"40.86.217.241/32\",\r\n \"40.86.226.149/32\",\r\n\ + \ \"40.86.228.93/32\",\r\n \"40.89.186.28/32\",\r\n \ + \ \"40.89.186.30/32\",\r\n \"40.89.188.169/32\",\r\n \ + \ \"40.89.190.104/32\",\r\n \"40.89.191.161/32\",\r\n \ + \ \"40.112.90.39/32\",\r\n \"40.112.92.104/32\",\r\n \"\ + 40.112.95.216/32\",\r\n \"40.113.1.181/32\",\r\n \"40.113.3.202/32\"\ + ,\r\n \"40.113.4.18/32\",\r\n \"40.113.10.90/32\",\r\n \ + \ \"40.113.11.17/32\",\r\n \"40.113.12.95/32\",\r\n \ + \ \"40.113.18.211/32\",\r\n \"40.113.20.202/32\",\r\n \ + \ \"40.113.22.12/32\",\r\n \"40.113.94.31/32\",\r\n \"\ + 40.113.218.230/32\",\r\n \"40.114.8.21/32\",\r\n \"40.114.12.31/32\"\ + ,\r\n \"40.114.13.216/32\",\r\n \"40.114.14.143/32\",\r\n\ + \ \"40.114.40.186/32\",\r\n \"40.114.51.5/32\",\r\n \ + \ \"40.114.82.191/32\",\r\n \"40.115.78.70/32\",\r\n \ + \ \"40.115.78.237/32\",\r\n \"40.117.99.79/32\",\r\n \"\ + 40.117.100.228/32\",\r\n \"40.118.241.243/32\",\r\n \"40.118.244.241/32\"\ + ,\r\n \"40.120.64.0/27\",\r\n \"40.120.64.32/28\",\r\n \ + \ \"40.121.91.41/32\",\r\n \"40.122.41.236/32\",\r\n \ + \ \"40.122.46.197/32\",\r\n \"40.122.170.198/32\",\r\n \ + \ \"40.126.227.199/32\",\r\n \"40.126.240.14/32\",\r\n \ + \ \"40.126.249.73/32\",\r\n \"40.126.252.33/32\",\r\n \ + \ \"40.126.252.85/32\",\r\n \"40.126.252.107/32\",\r\n \ + \ \"40.127.80.231/32\",\r\n \"40.127.83.170/32\",\r\n \"\ + 40.127.84.38/32\",\r\n \"40.127.86.12/32\",\r\n \"40.127.91.18/32\"\ + ,\r\n \"40.127.93.92/32\",\r\n \"51.11.97.16/28\",\r\n \ + \ \"51.11.97.32/27\",\r\n \"51.12.100.112/28\",\r\n \ + \ \"51.12.204.112/28\",\r\n \"51.12.204.192/27\",\r\n \ + \ \"51.12.229.32/27\",\r\n \"51.104.9.112/28\",\r\n \"\ + 51.105.69.96/27\",\r\n \"51.107.60.160/27\",\r\n \"51.107.60.192/28\"\ + ,\r\n \"51.107.156.160/27\",\r\n \"51.107.156.192/28\",\r\ + \n \"51.116.60.144/28\",\r\n \"51.116.60.160/27\",\r\n \ + \ \"51.116.158.64/28\",\r\n \"51.116.168.104/32\",\r\n \ + \ \"51.116.168.222/32\",\r\n \"51.116.171.49/32\",\r\n \ + \ \"51.116.171.209/32\",\r\n \"51.116.175.0/32\",\r\n \ + \ \"51.116.175.17/32\",\r\n \"51.116.175.51/32\",\r\n \ + \ \"51.116.233.22/32\",\r\n \"51.116.233.33/32\",\r\n \ + \ \"51.116.233.35/32\",\r\n \"51.116.233.40/32\",\r\n \"\ + 51.116.233.87/32\",\r\n \"51.116.243.224/27\",\r\n \"51.120.100.160/27\"\ + ,\r\n \"51.120.109.32/28\",\r\n \"51.120.220.128/27\",\r\ + \n \"51.120.220.160/28\",\r\n \"51.140.28.225/32\",\r\n\ + \ \"51.140.73.85/32\",\r\n \"51.140.74.14/32\",\r\n \ + \ \"51.140.78.44/32\",\r\n \"51.140.78.71/32\",\r\n \ + \ \"51.140.79.109/32\",\r\n \"51.140.84.39/32\",\r\n \"\ + 51.140.137.190/32\",\r\n \"51.140.142.28/32\",\r\n \"51.140.153.135/32\"\ + ,\r\n \"51.140.155.81/32\",\r\n \"51.140.158.24/32\",\r\n\ + \ \"51.141.45.238/32\",\r\n \"51.141.47.136/32\",\r\n \ + \ \"51.141.48.98/32\",\r\n \"51.141.51.145/32\",\r\n \ + \ \"51.141.53.164/32\",\r\n \"51.141.54.185/32\",\r\n \ + \ \"51.141.112.112/32\",\r\n \"51.141.113.36/32\",\r\n \ + \ \"51.141.114.77/32\",\r\n \"51.141.118.119/32\",\r\n \ + \ \"51.141.119.63/32\",\r\n \"51.141.119.150/32\",\r\n \"\ + 51.144.176.185/32\",\r\n \"51.144.182.201/32\",\r\n \"52.143.156.55/32\"\ + ,\r\n \"52.143.158.203/32\",\r\n \"52.143.162.83/32\",\r\ + \n \"52.143.164.15/32\",\r\n \"52.143.164.80/32\",\r\n \ + \ \"52.147.97.16/28\",\r\n \"52.147.97.32/27\",\r\n \ + \ \"52.160.90.237/32\",\r\n \"52.160.92.112/32\",\r\n \ + \ \"52.161.8.128/32\",\r\n \"52.161.9.108/32\",\r\n \"\ + 52.161.18.218/32\",\r\n \"52.161.19.82/32\",\r\n \"52.161.26.172/32\"\ + ,\r\n \"52.161.27.190/32\",\r\n \"52.162.111.144/28\",\r\ + \n \"52.162.111.160/27\",\r\n \"52.162.208.216/32\",\r\n\ + \ \"52.162.213.231/32\",\r\n \"52.163.93.214/32\",\r\n \ + \ \"52.163.228.93/32\",\r\n \"52.163.230.166/32\",\r\n \ + \ \"52.167.109.80/28\",\r\n \"52.169.218.253/32\",\r\n \ + \ \"52.169.220.174/32\",\r\n \"52.172.9.47/32\",\r\n \ + \ \"52.172.49.43/32\",\r\n \"52.172.50.24/32\",\r\n \"\ + 52.172.51.140/32\",\r\n \"52.172.52.0/32\",\r\n \"52.172.55.231/32\"\ + ,\r\n \"52.172.154.168/32\",\r\n \"52.172.157.194/32\",\r\ + \n \"52.172.184.192/32\",\r\n \"52.172.185.79/32\",\r\n\ + \ \"52.172.186.159/32\",\r\n \"52.172.191.194/32\",\r\n\ + \ \"52.174.49.6/32\",\r\n \"52.174.54.218/32\",\r\n \ + \ \"52.175.33.254/32\",\r\n \"52.175.198.132/32\",\r\n \ + \ \"52.178.165.215/32\",\r\n \"52.178.166.21/32\",\r\n \ + \ \"52.182.141.160/27\",\r\n \"52.183.29.132/32\",\r\n \ + \ \"52.183.30.10/32\",\r\n \"52.183.30.169/32\",\r\n \"\ + 52.183.39.67/32\",\r\n \"52.187.65.81/32\",\r\n \"52.187.65.155/32\"\ + ,\r\n \"52.187.226.96/32\",\r\n \"52.187.226.139/32\",\r\ + \n \"52.187.227.245/32\",\r\n \"52.187.229.130/32\",\r\n\ + \ \"52.187.231.161/32\",\r\n \"52.187.231.184/32\",\r\n\ + \ \"52.189.214.42/32\",\r\n \"52.189.216.28/32\",\r\n \ + \ \"52.189.220.75/32\",\r\n \"52.189.222.77/32\",\r\n \ + \ \"52.228.39.241/32\",\r\n \"52.228.39.244/32\",\r\n \ + \ \"52.229.120.45/32\",\r\n \"52.229.125.57/32\",\r\n \ + \ \"52.229.126.25/32\",\r\n \"52.231.23.16/28\",\r\n \"\ + 52.231.23.32/27\",\r\n \"52.232.128.155/32\",\r\n \"52.232.129.143/32\"\ + ,\r\n \"52.232.133.109/32\",\r\n \"52.233.29.79/32\",\r\n\ + \ \"52.233.29.92/32\",\r\n \"52.233.30.218/32\",\r\n \ + \ \"65.52.8.225/32\",\r\n \"65.52.9.64/32\",\r\n \"\ + 65.52.9.96/32\",\r\n \"65.52.10.183/32\",\r\n \"65.52.60.5/32\"\ + ,\r\n \"65.52.175.34/32\",\r\n \"65.52.185.96/32\",\r\n\ + \ \"65.52.185.218/32\",\r\n \"65.52.186.153/32\",\r\n \ + \ \"65.52.186.190/32\",\r\n \"65.52.186.225/32\",\r\n \ + \ \"65.52.211.164/32\",\r\n \"70.37.50.6/32\",\r\n \ + \ \"70.37.54.122/32\",\r\n \"102.133.28.208/28\",\r\n \"\ + 102.133.28.224/27\",\r\n \"102.133.72.37/32\",\r\n \"102.133.72.98/32\"\ + ,\r\n \"102.133.72.113/32\",\r\n \"102.133.72.132/32\",\r\ + \n \"102.133.72.145/32\",\r\n \"102.133.72.173/32\",\r\n\ + \ \"102.133.72.179/32\",\r\n \"102.133.72.183/32\",\r\n\ + \ \"102.133.72.184/32\",\r\n \"102.133.72.190/32\",\r\n\ + \ \"102.133.75.169/32\",\r\n \"102.133.75.191/32\",\r\n\ + \ \"102.133.156.176/28\",\r\n \"102.133.224.125/32\",\r\n\ + \ \"102.133.226.199/32\",\r\n \"102.133.227.103/32\",\r\n\ + \ \"102.133.228.4/32\",\r\n \"102.133.228.6/32\",\r\n \ + \ \"102.133.228.9/32\",\r\n \"102.133.230.4/32\",\r\n \ + \ \"102.133.230.82/32\",\r\n \"102.133.231.9/32\",\r\n \ + \ \"102.133.231.51/32\",\r\n \"102.133.231.117/32\",\r\n \ + \ \"102.133.231.188/32\",\r\n \"102.133.251.224/27\",\r\n \ + \ \"104.40.49.140/32\",\r\n \"104.40.54.74/32\",\r\n \ + \ \"104.40.59.188/32\",\r\n \"104.40.61.150/32\",\r\n \ + \ \"104.40.62.178/32\",\r\n \"104.40.218.37/32\",\r\n \ + \ \"104.41.0.115/32\",\r\n \"104.41.33.103/32\",\r\n \"\ + 104.41.162.245/32\",\r\n \"104.41.163.102/32\",\r\n \"104.41.168.76/32\"\ + ,\r\n \"104.41.173.132/32\",\r\n \"104.41.179.165/32\",\r\ + \n \"104.41.181.59/32\",\r\n \"104.41.182.232/32\",\r\n\ + \ \"104.42.38.32/32\",\r\n \"104.42.49.145/32\",\r\n \ + \ \"104.42.224.227/32\",\r\n \"104.42.236.93/32\",\r\n \ + \ \"104.43.166.135/32\",\r\n \"104.43.243.39/32\",\r\n \ + \ \"104.45.9.52/32\",\r\n \"104.45.153.81/32\",\r\n \ + \ \"104.46.32.99/32\",\r\n \"104.46.34.93/32\",\r\n \"104.46.34.208/32\"\ + ,\r\n \"104.46.39.63/32\",\r\n \"104.46.42.167/32\",\r\n\ + \ \"104.46.98.208/32\",\r\n \"104.46.106.158/32\",\r\n \ + \ \"104.47.138.214/32\",\r\n \"104.208.25.27/32\",\r\n \ + \ \"104.208.140.40/32\",\r\n \"104.208.155.200/32\",\r\n \ + \ \"104.208.158.174/32\",\r\n \"104.209.131.77/32\",\r\n\ + \ \"104.209.133.254/32\",\r\n \"104.209.134.133/32\",\r\n\ + \ \"104.210.89.222/32\",\r\n \"104.210.89.244/32\",\r\n\ + \ \"104.210.90.241/32\",\r\n \"104.210.91.55/32\",\r\n \ + \ \"104.210.144.48/32\",\r\n \"104.210.153.89/32\",\r\n \ + \ \"104.211.73.195/32\",\r\n \"104.211.74.145/32\",\r\n \ + \ \"104.211.90.162/32\",\r\n \"104.211.90.169/32\",\r\n \ + \ \"104.211.101.108/32\",\r\n \"104.211.102.62/32\",\r\n\ + \ \"104.211.154.7/32\",\r\n \"104.211.154.59/32\",\r\n \ + \ \"104.211.156.153/32\",\r\n \"104.211.157.237/32\",\r\n\ + \ \"104.211.158.123/32\",\r\n \"104.211.158.127/32\",\r\n\ + \ \"104.211.162.205/32\",\r\n \"104.211.164.25/32\",\r\n\ + \ \"104.211.164.80/32\",\r\n \"104.211.164.112/32\",\r\n\ + \ \"104.211.164.136/32\",\r\n \"104.211.165.81/32\",\r\n\ + \ \"104.211.225.152/32\",\r\n \"104.211.227.229/32\",\r\n\ + \ \"104.211.229.115/32\",\r\n \"104.211.230.126/32\",\r\n\ + \ \"104.211.230.129/32\",\r\n \"104.211.231.39/32\",\r\n\ + \ \"104.214.137.243/32\",\r\n \"104.214.161.64/27\",\r\n\ + \ \"104.214.161.96/28\",\r\n \"104.215.88.156/32\",\r\n\ + \ \"104.215.89.144/32\",\r\n \"104.215.90.86/32\",\r\n \ + \ \"104.215.90.189/32\",\r\n \"104.215.90.203/32\",\r\n \ + \ \"104.215.93.125/32\",\r\n \"104.215.176.31/32\",\r\n \ + \ \"104.215.176.81/32\",\r\n \"104.215.177.5/32\",\r\n \ + \ \"104.215.178.204/32\",\r\n \"104.215.179.133/32\",\r\n\ + \ \"104.215.180.203/32\",\r\n \"104.215.181.6/32\",\r\n\ + \ \"111.221.85.72/32\",\r\n \"111.221.85.74/32\",\r\n \ + \ \"137.116.44.82/32\",\r\n \"137.116.80.70/32\",\r\n \ + \ \"137.116.85.245/32\",\r\n \"137.116.126.165/32\",\r\n \ + \ \"137.117.72.32/32\",\r\n \"137.135.106.54/32\",\r\n \ + \ \"138.91.17.47/32\",\r\n \"138.91.25.99/32\",\r\n \ + \ \"138.91.26.45/32\",\r\n \"138.91.188.137/32\",\r\n \"\ + 157.55.210.61/32\",\r\n \"157.55.212.238/32\",\r\n \"157.56.12.202/32\"\ + ,\r\n \"157.56.160.212/32\",\r\n \"157.56.162.53/32\",\r\ + \n \"157.56.167.147/32\",\r\n \"168.61.86.120/32\",\r\n\ + \ \"168.61.152.201/32\",\r\n \"168.61.172.83/32\",\r\n \ + \ \"168.61.172.225/32\",\r\n \"168.61.173.172/32\",\r\n \ + \ \"168.61.217.177/32\",\r\n \"168.62.109.110/32\",\r\n \ + \ \"168.62.219.52/32\",\r\n \"168.62.219.83/32\",\r\n \ + \ \"168.62.248.37/32\",\r\n \"168.62.249.81/32\",\r\n \ + \ \"168.63.136.37/32\",\r\n \"168.63.200.173/32\",\r\n \ + \ \"191.232.32.19/32\",\r\n \"191.232.32.100/32\",\r\n \ + \ \"191.232.34.78/32\",\r\n \"191.232.34.249/32\",\r\n \ + \ \"191.232.35.177/32\",\r\n \"191.232.36.213/32\",\r\n \ + \ \"191.233.54.240/28\",\r\n \"191.233.68.51/32\",\r\n \ + \ \"191.233.207.0/28\",\r\n \"191.233.207.32/27\",\r\n \"\ + 191.234.161.28/32\",\r\n \"191.234.161.168/32\",\r\n \"\ + 191.234.162.131/32\",\r\n \"191.234.162.178/32\",\r\n \"\ + 191.234.166.198/32\",\r\n \"191.234.182.26/32\",\r\n \"\ + 191.235.82.221/32\",\r\n \"191.235.86.199/32\",\r\n \"191.235.91.7/32\"\ + ,\r\n \"191.235.94.220/32\",\r\n \"191.235.95.229/32\",\r\ + \n \"191.235.180.188/32\",\r\n \"191.237.255.116/32\",\r\ + \n \"191.238.41.107/32\",\r\n \"191.238.161.62/32\",\r\n\ + \ \"191.238.163.65/32\",\r\n \"191.239.67.132/32\",\r\n\ + \ \"191.239.82.62/32\",\r\n \"191.239.161.74/32\",\r\n \ + \ \"191.239.177.86/32\",\r\n \"207.46.148.176/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaCentral\"\ + ,\r\n \"id\": \"LogicApps.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"20.36.108.192/27\"\ + ,\r\n \"20.36.108.224/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.AustraliaCentral2\",\r\n \"id\"\ + : \"LogicApps.AustraliaCentral2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"20.36.117.96/27\"\ + ,\r\n \"20.36.117.128/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.AustraliaEast\",\r\n \"id\": \"\ + LogicApps.AustraliaEast\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"australiaeast\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.70.78.192/27\",\r\n \ + \ \"13.75.149.4/32\",\r\n \"13.75.153.66/32\",\r\n \ + \ \"40.79.171.240/28\",\r\n \"40.126.227.199/32\",\r\n \"\ + 40.126.240.14/32\",\r\n \"40.126.249.73/32\",\r\n \"40.126.252.33/32\"\ + ,\r\n \"40.126.252.85/32\",\r\n \"40.126.252.107/32\",\r\ + \n \"52.187.226.96/32\",\r\n \"52.187.226.139/32\",\r\n\ + \ \"52.187.227.245/32\",\r\n \"52.187.229.130/32\",\r\n\ + \ \"52.187.231.161/32\",\r\n \"52.187.231.184/32\",\r\n\ + \ \"104.210.89.222/32\",\r\n \"104.210.89.244/32\",\r\n\ + \ \"104.210.90.241/32\",\r\n \"104.210.91.55/32\",\r\n \ + \ \"191.239.67.132/32\",\r\n \"191.239.82.62/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.AustraliaSoutheast\"\ + ,\r\n \"id\": \"LogicApps.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.70.159.205/32\"\ + ,\r\n \"13.73.114.207/32\",\r\n \"13.73.115.153/32\",\r\n\ + \ \"13.77.3.139/32\",\r\n \"13.77.53.224/27\",\r\n \ + \ \"13.77.55.128/28\",\r\n \"13.77.56.167/32\",\r\n \ + \ \"13.77.58.136/32\",\r\n \"40.115.78.70/32\",\r\n \"40.115.78.237/32\"\ + ,\r\n \"40.127.80.231/32\",\r\n \"40.127.83.170/32\",\r\n\ + \ \"40.127.84.38/32\",\r\n \"40.127.86.12/32\",\r\n \ + \ \"40.127.91.18/32\",\r\n \"40.127.93.92/32\",\r\n \ + \ \"52.189.214.42/32\",\r\n \"52.189.216.28/32\",\r\n \"\ + 52.189.220.75/32\",\r\n \"52.189.222.77/32\",\r\n \"191.239.161.74/32\"\ + ,\r\n \"191.239.177.86/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.BrazilSouth\",\r\n \"id\": \"LogicApps.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"104.41.0.115/32\",\r\n \"104.41.33.103/32\",\r\ + \n \"191.232.32.19/32\",\r\n \"191.232.32.100/32\",\r\n\ + \ \"191.232.34.78/32\",\r\n \"191.232.34.249/32\",\r\n \ + \ \"191.232.35.177/32\",\r\n \"191.232.36.213/32\",\r\n \ + \ \"191.233.207.0/28\",\r\n \"191.233.207.32/27\",\r\n \ + \ \"191.234.161.28/32\",\r\n \"191.234.161.168/32\",\r\n \ + \ \"191.234.162.131/32\",\r\n \"191.234.162.178/32\",\r\n\ + \ \"191.234.166.198/32\",\r\n \"191.234.182.26/32\",\r\n\ + \ \"191.235.82.221/32\",\r\n \"191.235.86.199/32\",\r\n\ + \ \"191.235.91.7/32\",\r\n \"191.235.94.220/32\",\r\n \ + \ \"191.235.95.229/32\",\r\n \"191.237.255.116/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CanadaCentral\"\ + ,\r\n \"id\": \"LogicApps.CanadaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.71.184.150/32\"\ + ,\r\n \"13.71.186.1/32\",\r\n \"13.88.249.209/32\",\r\n\ + \ \"13.106.118.32/27\",\r\n \"13.106.118.96/27\",\r\n \ + \ \"20.38.149.144/28\",\r\n \"20.38.149.160/27\",\r\n \ + \ \"40.85.241.105/32\",\r\n \"40.85.250.135/32\",\r\n \ + \ \"40.85.250.212/32\",\r\n \"40.85.252.47/32\",\r\n \ + \ \"52.228.39.241/32\",\r\n \"52.228.39.244/32\",\r\n \"\ + 52.233.29.79/32\",\r\n \"52.233.29.92/32\",\r\n \"52.233.30.218/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CanadaEast\"\ + ,\r\n \"id\": \"LogicApps.CanadaEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.69.110.192/27\"\ + ,\r\n \"40.69.110.224/28\",\r\n \"40.86.202.42/32\",\r\n\ + \ \"40.86.203.228/32\",\r\n \"40.86.216.241/32\",\r\n \ + \ \"40.86.217.241/32\",\r\n \"40.86.226.149/32\",\r\n \ + \ \"40.86.228.93/32\",\r\n \"52.229.120.45/32\",\r\n \ + \ \"52.229.125.57/32\",\r\n \"52.229.126.25/32\",\r\n \ + \ \"52.232.128.155/32\",\r\n \"52.232.129.143/32\",\r\n \ + \ \"52.232.133.109/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"LogicApps.CentralIndia\",\r\n \"id\": \"LogicApps.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.43.121.192/27\",\r\n \"20.43.121.224/28\",\r\ + \n \"52.172.154.168/32\",\r\n \"52.172.157.194/32\",\r\n\ + \ \"52.172.184.192/32\",\r\n \"52.172.185.79/32\",\r\n \ + \ \"52.172.186.159/32\",\r\n \"52.172.191.194/32\",\r\n \ + \ \"104.211.73.195/32\",\r\n \"104.211.74.145/32\",\r\n \ + \ \"104.211.90.162/32\",\r\n \"104.211.90.169/32\",\r\n \ + \ \"104.211.101.108/32\",\r\n \"104.211.102.62/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CentralUS\"\ + ,\r\n \"id\": \"LogicApps.CentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.67.236.76/32\"\ + ,\r\n \"13.67.236.125/32\",\r\n \"13.89.178.48/28\",\r\n\ + \ \"23.100.82.16/32\",\r\n \"23.100.86.139/32\",\r\n \ + \ \"23.100.87.24/32\",\r\n \"23.100.87.56/32\",\r\n \ + \ \"40.77.31.87/32\",\r\n \"40.77.111.254/32\",\r\n \"\ + 40.113.218.230/32\",\r\n \"40.122.41.236/32\",\r\n \"40.122.46.197/32\"\ + ,\r\n \"40.122.170.198/32\",\r\n \"52.182.141.160/27\",\r\ + \n \"104.43.166.135/32\",\r\n \"104.43.243.39/32\",\r\n\ + \ \"104.208.25.27/32\",\r\n \"168.61.152.201/32\",\r\n \ + \ \"168.61.172.83/32\",\r\n \"168.61.172.225/32\",\r\n \ + \ \"168.61.173.172/32\",\r\n \"168.61.217.177/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.CentralUSEUAP\"\ + ,\r\n \"id\": \"LogicApps.CentralUSEUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.78.204.208/28\"\ + ,\r\n \"40.78.204.224/27\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.EastAsia\",\r\n \"id\": \"LogicApps.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.75.89.159/32\",\r\n \"13.75.94.173/32\",\r\n\ + \ \"23.97.68.172/32\",\r\n \"23.99.125.99/32\",\r\n \ + \ \"40.83.73.39/32\",\r\n \"40.83.75.165/32\",\r\n \ + \ \"40.83.77.208/32\",\r\n \"40.83.98.194/32\",\r\n \"40.83.100.69/32\"\ + ,\r\n \"40.83.127.19/32\",\r\n \"52.175.33.254/32\",\r\n\ + \ \"65.52.175.34/32\",\r\n \"65.52.185.96/32\",\r\n \ + \ \"65.52.185.218/32\",\r\n \"65.52.186.153/32\",\r\n \ + \ \"65.52.186.190/32\",\r\n \"65.52.186.225/32\",\r\n \ + \ \"104.214.161.64/27\",\r\n \"104.214.161.96/28\",\r\n \ + \ \"168.63.136.37/32\",\r\n \"168.63.200.173/32\",\r\n \ + \ \"207.46.148.176/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"LogicApps.EastUS\",\r\n \"id\": \"LogicApps.EastUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.92.98.111/32\",\r\n \"20.42.64.48/28\",\r\n \ + \ \"20.42.72.160/27\",\r\n \"23.100.29.190/32\",\r\n \"\ + 23.101.132.208/32\",\r\n \"23.101.136.201/32\",\r\n \"23.101.139.153/32\"\ + ,\r\n \"40.114.8.21/32\",\r\n \"40.114.12.31/32\",\r\n \ + \ \"40.114.13.216/32\",\r\n \"40.114.14.143/32\",\r\n \ + \ \"40.114.40.186/32\",\r\n \"40.114.51.5/32\",\r\n \ + \ \"40.114.82.191/32\",\r\n \"40.117.99.79/32\",\r\n \"\ + 40.117.100.228/32\",\r\n \"40.121.91.41/32\",\r\n \"104.45.153.81/32\"\ + ,\r\n \"137.116.126.165/32\",\r\n \"137.117.72.32/32\",\r\ + \n \"137.135.106.54/32\",\r\n \"191.238.41.107/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.EastUS2\"\ + ,\r\n \"id\": \"LogicApps.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"20.44.17.224/27\"\ + ,\r\n \"40.70.26.154/32\",\r\n \"40.70.27.236/32\",\r\n\ + \ \"40.70.27.253/32\",\r\n \"40.70.29.214/32\",\r\n \ + \ \"40.70.131.151/32\",\r\n \"40.79.44.7/32\",\r\n \ + \ \"40.84.25.234/32\",\r\n \"40.84.30.147/32\",\r\n \"40.84.59.136/32\"\ + ,\r\n \"52.167.109.80/28\",\r\n \"104.46.98.208/32\",\r\n\ + \ \"104.46.106.158/32\",\r\n \"104.208.140.40/32\",\r\n\ + \ \"104.208.155.200/32\",\r\n \"104.208.158.174/32\",\r\n\ + \ \"104.209.131.77/32\",\r\n \"104.209.133.254/32\",\r\n\ + \ \"104.209.134.133/32\",\r\n \"137.116.44.82/32\",\r\n\ + \ \"137.116.80.70/32\",\r\n \"137.116.85.245/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.EastUS2EUAP\"\ + ,\r\n \"id\": \"LogicApps.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.74.149.96/27\"\ + ,\r\n \"40.75.35.240/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.FranceCentral\",\r\n \"id\": \"\ + LogicApps.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n\ + \ \"addressPrefixes\": [\r\n \"20.188.33.169/32\",\r\n \ + \ \"20.188.39.105/32\",\r\n \"40.79.139.144/28\",\r\n \ + \ \"40.79.139.160/27\",\r\n \"40.89.186.28/32\",\r\n \ + \ \"40.89.186.30/32\",\r\n \"40.89.188.169/32\",\r\n \"\ + 40.89.190.104/32\",\r\n \"40.89.191.161/32\",\r\n \"52.143.156.55/32\"\ + ,\r\n \"52.143.158.203/32\",\r\n \"52.143.162.83/32\",\r\ + \n \"52.143.164.15/32\",\r\n \"52.143.164.80/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.FranceSouth\"\ + ,\r\n \"id\": \"LogicApps.FranceSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.79.180.160/27\"\ + ,\r\n \"40.79.180.192/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.GermanyNorth\",\r\n \"id\": \"\ + LogicApps.GermanyNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"germanyn\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.116.60.144/28\",\r\n \ + \ \"51.116.60.160/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"LogicApps.GermanyWestCentral\",\r\n \"id\": \"LogicApps.GermanyWestCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanywc\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.158.64/28\",\r\n \"51.116.168.104/32\"\ + ,\r\n \"51.116.168.222/32\",\r\n \"51.116.171.49/32\",\r\ + \n \"51.116.171.209/32\",\r\n \"51.116.175.0/32\",\r\n \ + \ \"51.116.175.17/32\",\r\n \"51.116.175.51/32\",\r\n \ + \ \"51.116.233.22/32\",\r\n \"51.116.233.33/32\",\r\n \ + \ \"51.116.233.35/32\",\r\n \"51.116.233.40/32\",\r\n \ + \ \"51.116.233.87/32\",\r\n \"51.116.243.224/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"LogicApps.JapanEast\",\r\ + \n \"id\": \"LogicApps.JapanEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.71.146.140/32\"\ + ,\r\n \"13.71.158.3/32\",\r\n \"13.71.158.120/32\",\r\n\ + \ \"13.73.4.207/32\",\r\n \"13.78.18.168/32\",\r\n \ + \ \"13.78.20.232/32\",\r\n \"13.78.21.155/32\",\r\n \ + \ \"13.78.35.229/32\",\r\n \"13.78.42.223/32\",\r\n \"13.78.43.164/32\"\ + ,\r\n \"13.78.62.130/32\",\r\n \"13.78.84.187/32\",\r\n\ + \ \"13.78.111.160/27\",\r\n \"23.102.70.174/32\",\r\n \ + \ \"40.79.197.48/28\",\r\n \"104.41.162.245/32\",\r\n \ + \ \"104.41.163.102/32\",\r\n \"104.41.168.76/32\",\r\n \ + \ \"104.41.173.132/32\",\r\n \"104.41.179.165/32\",\r\n \ + \ \"104.41.181.59/32\",\r\n \"104.41.182.232/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.JapanWest\"\ + ,\r\n \"id\": \"LogicApps.JapanWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.74.64.207/32\"\ + ,\r\n \"40.74.66.200/32\",\r\n \"40.74.68.85/32\",\r\n \ + \ \"40.74.74.21/32\",\r\n \"40.74.76.213/32\",\r\n \ + \ \"40.74.77.205/32\",\r\n \"40.74.81.13/32\",\r\n \"\ + 40.74.85.215/32\",\r\n \"40.74.131.151/32\",\r\n \"40.74.132.29/32\"\ + ,\r\n \"40.74.136.23/32\",\r\n \"40.74.140.4/32\",\r\n \ + \ \"40.74.140.162/32\",\r\n \"40.74.140.173/32\",\r\n \ + \ \"40.74.142.133/32\",\r\n \"40.74.143.215/32\",\r\n \ + \ \"40.80.180.16/28\",\r\n \"40.80.180.32/27\",\r\n \ + \ \"104.214.137.243/32\",\r\n \"138.91.17.47/32\",\r\n \"\ + 138.91.25.99/32\",\r\n \"138.91.26.45/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.KoreaCentral\",\r\n\ + \ \"id\": \"LogicApps.KoreaCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"52.231.23.16/28\"\ + ,\r\n \"52.231.23.32/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.KoreaSouth\",\r\n \"id\": \"LogicApps.KoreaSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"52.147.97.16/28\",\r\n \"52.147.97.32/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorthCentralUS\"\ + ,\r\n \"id\": \"LogicApps.NorthCentralUS\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"23.96.200.77/32\"\ + ,\r\n \"23.96.200.227/32\",\r\n \"23.96.203.46/32\",\r\n\ + \ \"23.96.210.49/32\",\r\n \"23.96.212.28/32\",\r\n \ + \ \"23.96.253.219/32\",\r\n \"52.162.111.144/28\",\r\n \ + \ \"52.162.111.160/27\",\r\n \"52.162.208.216/32\",\r\n \ + \ \"52.162.213.231/32\",\r\n \"65.52.8.225/32\",\r\n \ + \ \"65.52.9.64/32\",\r\n \"65.52.9.96/32\",\r\n \"65.52.10.183/32\"\ + ,\r\n \"65.52.60.5/32\",\r\n \"65.52.211.164/32\",\r\n \ + \ \"157.55.210.61/32\",\r\n \"157.55.212.238/32\",\r\n \ + \ \"157.56.12.202/32\",\r\n \"168.62.109.110/32\",\r\n \ + \ \"168.62.248.37/32\",\r\n \"168.62.249.81/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorthEurope\"\ + ,\r\n \"id\": \"LogicApps.NorthEurope\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.69.231.160/27\"\ + ,\r\n \"13.69.233.16/28\",\r\n \"13.79.173.49/32\",\r\n\ + \ \"40.112.90.39/32\",\r\n \"40.112.92.104/32\",\r\n \ + \ \"40.112.95.216/32\",\r\n \"40.113.1.181/32\",\r\n \ + \ \"40.113.3.202/32\",\r\n \"40.113.4.18/32\",\r\n \"\ + 40.113.10.90/32\",\r\n \"40.113.11.17/32\",\r\n \"40.113.12.95/32\"\ + ,\r\n \"40.113.18.211/32\",\r\n \"40.113.20.202/32\",\r\n\ + \ \"40.113.22.12/32\",\r\n \"40.113.94.31/32\",\r\n \ + \ \"52.169.218.253/32\",\r\n \"52.169.220.174/32\",\r\n \ + \ \"52.178.165.215/32\",\r\n \"52.178.166.21/32\",\r\n \ + \ \"168.61.86.120/32\",\r\n \"191.235.180.188/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.NorwayEast\"\ + ,\r\n \"id\": \"LogicApps.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"51.120.100.160/27\"\ + ,\r\n \"51.120.109.32/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.NorwayWest\",\r\n \"id\": \"LogicApps.NorwayWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.220.128/27\",\r\n \"51.120.220.160/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.SouthAfricaNorth\"\ + ,\r\n \"id\": \"LogicApps.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"102.133.156.176/28\"\ + ,\r\n \"102.133.224.125/32\",\r\n \"102.133.226.199/32\"\ + ,\r\n \"102.133.227.103/32\",\r\n \"102.133.228.4/32\",\r\ + \n \"102.133.228.6/32\",\r\n \"102.133.228.9/32\",\r\n \ + \ \"102.133.230.4/32\",\r\n \"102.133.230.82/32\",\r\n \ + \ \"102.133.231.9/32\",\r\n \"102.133.231.51/32\",\r\n \ + \ \"102.133.231.117/32\",\r\n \"102.133.231.188/32\",\r\n \ + \ \"102.133.251.224/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.SouthAfricaWest\",\r\n \"id\": \"\ + LogicApps.SouthAfricaWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southafricawest\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\",\r\ + \n \"addressPrefixes\": [\r\n \"102.133.28.208/28\",\r\n \ + \ \"102.133.28.224/27\",\r\n \"102.133.72.37/32\",\r\n \ + \ \"102.133.72.98/32\",\r\n \"102.133.72.113/32\",\r\n \ + \ \"102.133.72.132/32\",\r\n \"102.133.72.145/32\",\r\n \ + \ \"102.133.72.173/32\",\r\n \"102.133.72.179/32\",\r\n \ + \ \"102.133.72.183/32\",\r\n \"102.133.72.184/32\",\r\n \ + \ \"102.133.72.190/32\",\r\n \"102.133.75.169/32\",\r\n \ + \ \"102.133.75.191/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"LogicApps.SouthCentralUS\",\r\n \"id\": \"LogicApps.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.65.39.247/32\",\r\n \"13.65.82.17/32\",\r\n\ + \ \"13.65.82.190/32\",\r\n \"13.65.86.56/32\",\r\n \ + \ \"13.65.98.39/32\",\r\n \"13.66.52.232/32\",\r\n \"\ + 13.73.244.144/28\",\r\n \"13.73.244.160/27\",\r\n \"13.84.41.46/32\"\ + ,\r\n \"13.84.43.45/32\",\r\n \"13.84.159.168/32\",\r\n\ + \ \"13.85.79.155/32\",\r\n \"23.100.124.84/32\",\r\n \ + \ \"23.100.127.172/32\",\r\n \"23.101.183.225/32\",\r\n \ + \ \"23.101.191.106/32\",\r\n \"40.84.138.132/32\",\r\n \ + \ \"70.37.50.6/32\",\r\n \"70.37.54.122/32\",\r\n \"\ + 104.210.144.48/32\",\r\n \"104.210.153.89/32\",\r\n \"104.215.88.156/32\"\ + ,\r\n \"104.215.89.144/32\",\r\n \"104.215.90.86/32\",\r\ + \n \"104.215.90.189/32\",\r\n \"104.215.90.203/32\",\r\n\ + \ \"104.215.93.125/32\",\r\n \"191.238.161.62/32\",\r\n\ + \ \"191.238.163.65/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.SoutheastAsia\",\r\n \"id\": \"LogicApps.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.67.13.224/27\",\r\n \"13.67.91.135/32\",\r\n\ + \ \"13.67.107.128/32\",\r\n \"13.67.110.109/32\",\r\n \ + \ \"13.76.4.194/32\",\r\n \"13.76.5.96/32\",\r\n \ + \ \"13.76.133.155/32\",\r\n \"40.78.239.16/28\",\r\n \"\ + 52.163.93.214/32\",\r\n \"52.163.228.93/32\",\r\n \"52.163.230.166/32\"\ + ,\r\n \"52.187.65.81/32\",\r\n \"52.187.65.155/32\",\r\n\ + \ \"104.215.176.31/32\",\r\n \"104.215.176.81/32\",\r\n\ + \ \"104.215.177.5/32\",\r\n \"104.215.178.204/32\",\r\n\ + \ \"104.215.179.133/32\",\r\n \"104.215.180.203/32\",\r\n\ + \ \"104.215.181.6/32\",\r\n \"111.221.85.72/32\",\r\n \ + \ \"111.221.85.74/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"LogicApps.SouthIndia\",\r\n \"id\": \"LogicApps.SouthIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.192.184.0/27\",\r\n \"40.78.196.176/28\",\r\ + \n \"52.172.9.47/32\",\r\n \"52.172.49.43/32\",\r\n \ + \ \"52.172.50.24/32\",\r\n \"52.172.51.140/32\",\r\n \ + \ \"52.172.52.0/32\",\r\n \"52.172.55.231/32\",\r\n \"\ + 104.211.225.152/32\",\r\n \"104.211.227.229/32\",\r\n \"\ + 104.211.229.115/32\",\r\n \"104.211.230.126/32\",\r\n \"\ + 104.211.230.129/32\",\r\n \"104.211.231.39/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"LogicApps.SwitzerlandNorth\"\ + ,\r\n \"id\": \"LogicApps.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"51.107.60.160/27\"\ + ,\r\n \"51.107.60.192/28\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.SwitzerlandWest\",\r\n \"id\":\ + \ \"LogicApps.SwitzerlandWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"LogicApps\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.156.160/27\",\r\n\ + \ \"51.107.156.192/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.UAECentral\",\r\n \"id\": \"LogicApps.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.76.208/28\",\r\n \"20.37.76.224/27\",\r\n\ + \ \"20.45.64.29/32\",\r\n \"20.45.64.87/32\",\r\n \ + \ \"20.45.67.134/31\",\r\n \"20.45.67.170/32\",\r\n \"\ + 20.45.71.213/32\",\r\n \"20.45.72.54/32\",\r\n \"20.45.72.72/32\"\ + ,\r\n \"20.45.75.193/32\",\r\n \"20.45.75.200/32\",\r\n\ + \ \"20.45.75.236/32\",\r\n \"20.45.79.239/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UAENorth\"\ + ,\r\n \"id\": \"LogicApps.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"40.120.64.0/27\"\ + ,\r\n \"40.120.64.32/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.UKNorth\",\r\n \"id\": \"LogicApps.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.87.124.144/28\",\r\n \"13.87.124.160/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKSouth\"\ + ,\r\n \"id\": \"LogicApps.UKSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"51.104.9.112/28\"\ + ,\r\n \"51.105.69.96/27\",\r\n \"51.140.28.225/32\",\r\n\ + \ \"51.140.73.85/32\",\r\n \"51.140.74.14/32\",\r\n \ + \ \"51.140.78.44/32\",\r\n \"51.140.78.71/32\",\r\n \ + \ \"51.140.79.109/32\",\r\n \"51.140.84.39/32\",\r\n \"\ + 51.140.137.190/32\",\r\n \"51.140.142.28/32\",\r\n \"51.140.153.135/32\"\ + ,\r\n \"51.140.155.81/32\",\r\n \"51.140.158.24/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.UKSouth2\"\ + ,\r\n \"id\": \"LogicApps.UKSouth2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.87.58.144/28\"\ + ,\r\n \"13.87.58.160/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"LogicApps.UKWest\",\r\n \"id\": \"LogicApps.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.11.97.16/28\",\r\n \"51.11.97.32/27\",\r\n \"\ + 51.141.45.238/32\",\r\n \"51.141.47.136/32\",\r\n \"51.141.48.98/32\"\ + ,\r\n \"51.141.51.145/32\",\r\n \"51.141.53.164/32\",\r\n\ + \ \"51.141.54.185/32\",\r\n \"51.141.112.112/32\",\r\n \ + \ \"51.141.113.36/32\",\r\n \"51.141.114.77/32\",\r\n \ + \ \"51.141.118.119/32\",\r\n \"51.141.119.63/32\",\r\n \ + \ \"51.141.119.150/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"LogicApps.WestCentralUS\",\r\n \"id\": \"LogicApps.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.199.128/27\",\r\n \"13.71.199.160/28\",\r\ + \n \"13.78.129.20/32\",\r\n \"13.78.137.179/32\",\r\n \ + \ \"13.78.137.247/32\",\r\n \"13.78.141.75/32\",\r\n \ + \ \"13.78.148.140/32\",\r\n \"13.78.151.161/32\",\r\n \ + \ \"52.161.8.128/32\",\r\n \"52.161.9.108/32\",\r\n \"\ + 52.161.18.218/32\",\r\n \"52.161.19.82/32\",\r\n \"52.161.26.172/32\"\ + ,\r\n \"52.161.27.190/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"LogicApps.WestEurope\",\r\n \"id\": \"LogicApps.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.71.160/27\",\r\n \"13.69.109.144/28\",\r\ + \n \"13.95.147.65/32\",\r\n \"13.95.155.53/32\",\r\n \ + \ \"23.97.210.126/32\",\r\n \"23.97.211.179/32\",\r\n \ + \ \"23.97.218.130/32\",\r\n \"40.68.209.23/32\",\r\n \ + \ \"40.68.222.65/32\",\r\n \"51.144.176.185/32\",\r\n \"\ + 51.144.182.201/32\",\r\n \"52.174.49.6/32\",\r\n \"52.174.54.218/32\"\ + ,\r\n \"104.40.218.37/32\",\r\n \"104.45.9.52/32\",\r\n\ + \ \"104.46.32.99/32\",\r\n \"104.46.34.93/32\",\r\n \ + \ \"104.46.34.208/32\",\r\n \"104.46.39.63/32\",\r\n \ + \ \"104.46.42.167/32\",\r\n \"104.47.138.214/32\",\r\n \ + \ \"191.233.68.51/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"LogicApps.WestIndia\",\r\n \"id\": \"LogicApps.WestIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.128.176/28\",\r\n \"20.38.128.192/27\",\r\ + \n \"104.211.154.7/32\",\r\n \"104.211.154.59/32\",\r\n\ + \ \"104.211.156.153/32\",\r\n \"104.211.157.237/32\",\r\n\ + \ \"104.211.158.123/32\",\r\n \"104.211.158.127/32\",\r\n\ + \ \"104.211.162.205/32\",\r\n \"104.211.164.25/32\",\r\n\ + \ \"104.211.164.80/32\",\r\n \"104.211.164.112/32\",\r\n\ + \ \"104.211.164.136/32\",\r\n \"104.211.165.81/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"LogicApps.WestUS\"\ + ,\r\n \"id\": \"LogicApps.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + LogicApps\",\r\n \"addressPrefixes\": [\r\n \"13.86.221.240/28\"\ + ,\r\n \"13.86.223.0/27\",\r\n \"13.91.252.184/32\",\r\n\ + \ \"40.83.164.80/32\",\r\n \"40.118.241.243/32\",\r\n \ + \ \"40.118.244.241/32\",\r\n \"52.160.90.237/32\",\r\n \ + \ \"52.160.92.112/32\",\r\n \"104.40.49.140/32\",\r\n \ + \ \"104.40.54.74/32\",\r\n \"104.40.59.188/32\",\r\n \ + \ \"104.40.61.150/32\",\r\n \"104.40.62.178/32\",\r\n \"\ + 104.42.38.32/32\",\r\n \"104.42.49.145/32\",\r\n \"104.42.224.227/32\"\ + ,\r\n \"104.42.236.93/32\",\r\n \"138.91.188.137/32\",\r\ + \n \"157.56.160.212/32\",\r\n \"157.56.162.53/32\",\r\n\ + \ \"157.56.167.147/32\",\r\n \"168.62.219.52/32\",\r\n \ + \ \"168.62.219.83/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"LogicApps.WestUS2\",\r\n \"id\": \"LogicApps.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"LogicApps\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.128.68/32\",\r\n \"13.66.201.169/32\",\r\n \ + \ \"13.66.210.167/32\",\r\n \"13.66.224.169/32\",\r\n \ + \ \"13.66.246.219/32\",\r\n \"13.77.149.159/32\",\r\n \"\ + 13.77.152.21/32\",\r\n \"40.78.245.144/28\",\r\n \"40.78.245.160/27\"\ + ,\r\n \"52.175.198.132/32\",\r\n \"52.183.29.132/32\",\r\ + \n \"52.183.30.10/32\",\r\n \"52.183.30.169/32\",\r\n \ + \ \"52.183.39.67/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"LogicAppsManagement\",\r\n \"id\": \"LogicAppsManagement\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"LogicApps\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.65.39.247/32\",\r\n \"13.65.98.39/32\",\r\n\ + \ \"13.66.128.68/32\",\r\n \"13.66.224.169/32\",\r\n \ + \ \"13.67.236.76/32\",\r\n \"13.69.109.144/28\",\r\n \ + \ \"13.69.233.16/28\",\r\n \"13.71.146.140/32\",\r\n \ + \ \"13.71.199.160/28\",\r\n \"13.73.115.153/32\",\r\n \"\ + 13.73.244.144/28\",\r\n \"13.75.89.159/32\",\r\n \"13.75.153.66/32\"\ + ,\r\n \"13.77.55.128/28\",\r\n \"13.78.43.164/32\",\r\n\ + \ \"13.78.62.130/32\",\r\n \"13.78.84.187/32\",\r\n \ + \ \"13.78.137.247/32\",\r\n \"13.79.173.49/32\",\r\n \ + \ \"13.84.41.46/32\",\r\n \"13.84.43.45/32\",\r\n \"13.85.79.155/32\"\ + ,\r\n \"13.86.221.240/28\",\r\n \"13.87.58.144/28\",\r\n\ + \ \"13.87.124.144/28\",\r\n \"13.88.249.209/32\",\r\n \ + \ \"13.89.178.48/28\",\r\n \"13.91.252.184/32\",\r\n \ + \ \"13.95.155.53/32\",\r\n \"13.106.118.32/27\",\r\n \ + \ \"20.36.108.224/28\",\r\n \"20.36.117.128/28\",\r\n \"\ + 20.37.76.208/28\",\r\n \"20.38.128.176/28\",\r\n \"20.38.149.144/28\"\ + ,\r\n \"20.42.64.48/28\",\r\n \"20.43.121.224/28\",\r\n\ + \ \"20.44.4.176/28\",\r\n \"20.45.64.29/32\",\r\n \ + \ \"20.45.64.87/32\",\r\n \"20.45.71.213/32\",\r\n \"\ + 20.45.75.193/32\",\r\n \"20.150.172.240/28\",\r\n \"20.192.238.160/28\"\ + ,\r\n \"20.193.206.48/28\",\r\n \"23.97.68.172/32\",\r\n\ + \ \"40.67.60.176/28\",\r\n \"40.69.110.224/28\",\r\n \ + \ \"40.70.27.253/32\",\r\n \"40.74.66.200/32\",\r\n \ + \ \"40.74.81.13/32\",\r\n \"40.74.85.215/32\",\r\n \"\ + 40.74.140.173/32\",\r\n \"40.75.35.240/28\",\r\n \"40.77.31.87/32\"\ + ,\r\n \"40.77.111.254/32\",\r\n \"40.78.196.176/28\",\r\n\ + \ \"40.78.204.208/28\",\r\n \"40.78.239.16/28\",\r\n \ + \ \"40.78.245.144/28\",\r\n \"40.79.44.7/32\",\r\n \ + \ \"40.79.139.144/28\",\r\n \"40.79.171.240/28\",\r\n \"\ + 40.79.180.192/28\",\r\n \"40.79.197.48/28\",\r\n \"40.80.180.16/28\"\ + ,\r\n \"40.83.98.194/32\",\r\n \"40.84.25.234/32\",\r\n\ + \ \"40.84.59.136/32\",\r\n \"40.84.138.132/32\",\r\n \ + \ \"40.85.241.105/32\",\r\n \"40.86.202.42/32\",\r\n \ + \ \"40.112.90.39/32\",\r\n \"40.115.78.70/32\",\r\n \"\ + 40.115.78.237/32\",\r\n \"40.117.99.79/32\",\r\n \"40.117.100.228/32\"\ + ,\r\n \"40.120.64.32/28\",\r\n \"51.11.97.16/28\",\r\n \ + \ \"51.12.100.112/28\",\r\n \"51.12.204.112/28\",\r\n \ + \ \"51.104.9.112/28\",\r\n \"51.107.60.192/28\",\r\n \ + \ \"51.107.156.192/28\",\r\n \"51.116.60.144/28\",\r\n \ + \ \"51.116.158.64/28\",\r\n \"51.116.168.222/32\",\r\n \ + \ \"51.116.171.209/32\",\r\n \"51.116.175.0/32\",\r\n \"\ + 51.116.233.40/32\",\r\n \"51.120.109.32/28\",\r\n \"51.120.220.160/28\"\ + ,\r\n \"51.140.78.71/32\",\r\n \"51.140.79.109/32\",\r\n\ + \ \"51.140.84.39/32\",\r\n \"51.140.155.81/32\",\r\n \ + \ \"51.141.48.98/32\",\r\n \"51.141.51.145/32\",\r\n \ + \ \"51.141.53.164/32\",\r\n \"51.141.119.150/32\",\r\n \ + \ \"51.144.176.185/32\",\r\n \"52.147.97.16/28\",\r\n \ + \ \"52.160.90.237/32\",\r\n \"52.161.8.128/32\",\r\n \"\ + 52.161.19.82/32\",\r\n \"52.161.26.172/32\",\r\n \"52.162.111.144/28\"\ + ,\r\n \"52.163.93.214/32\",\r\n \"52.167.109.80/28\",\r\n\ + \ \"52.169.218.253/32\",\r\n \"52.169.220.174/32\",\r\n\ + \ \"52.172.9.47/32\",\r\n \"52.172.49.43/32\",\r\n \ + \ \"52.172.51.140/32\",\r\n \"52.172.157.194/32\",\r\n \ + \ \"52.172.184.192/32\",\r\n \"52.172.191.194/32\",\r\n \ + \ \"52.174.49.6/32\",\r\n \"52.174.54.218/32\",\r\n \"\ + 52.183.30.10/32\",\r\n \"52.183.39.67/32\",\r\n \"52.187.65.81/32\"\ + ,\r\n \"52.187.65.155/32\",\r\n \"52.187.231.161/32\",\r\ + \n \"52.189.216.28/32\",\r\n \"52.229.125.57/32\",\r\n \ + \ \"52.231.23.16/28\",\r\n \"52.232.129.143/32\",\r\n \ + \ \"52.232.133.109/32\",\r\n \"52.233.29.79/32\",\r\n \ + \ \"52.233.30.218/32\",\r\n \"65.52.9.64/32\",\r\n \"\ + 65.52.211.164/32\",\r\n \"102.133.28.208/28\",\r\n \"102.133.72.145/32\"\ + ,\r\n \"102.133.72.173/32\",\r\n \"102.133.72.184/32\",\r\ + \n \"102.133.72.190/32\",\r\n \"102.133.156.176/28\",\r\n\ + \ \"102.133.224.125/32\",\r\n \"102.133.226.199/32\",\r\n\ + \ \"102.133.228.4/32\",\r\n \"102.133.228.9/32\",\r\n \ + \ \"104.43.243.39/32\",\r\n \"104.210.89.222/32\",\r\n \ + \ \"104.210.89.244/32\",\r\n \"104.210.153.89/32\",\r\n \ + \ \"104.211.73.195/32\",\r\n \"104.211.157.237/32\",\r\n \ + \ \"104.211.164.25/32\",\r\n \"104.211.164.112/32\",\r\n \ + \ \"104.211.165.81/32\",\r\n \"104.211.225.152/32\",\r\n\ + \ \"104.214.161.96/28\",\r\n \"104.215.181.6/32\",\r\n \ + \ \"137.116.126.165/32\",\r\n \"137.135.106.54/32\",\r\n\ + \ \"138.91.188.137/32\",\r\n \"157.56.12.202/32\",\r\n \ + \ \"157.56.160.212/32\",\r\n \"168.62.249.81/32\",\r\n \ + \ \"168.63.200.173/32\",\r\n \"191.233.54.240/28\",\r\n \ + \ \"191.233.207.0/28\",\r\n \"191.234.166.198/32\",\r\n \ + \ \"191.235.86.199/32\",\r\n \"191.235.94.220/32\",\r\n \ + \ \"191.235.95.229/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftCloudAppSecurity\",\r\n \"id\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.64.26.88/32\",\r\n \ + \ \"13.64.28.87/32\",\r\n \"13.64.29.32/32\",\r\n \"\ + 13.64.29.161/32\",\r\n \"13.64.30.76/32\",\r\n \"13.64.30.117/32\"\ + ,\r\n \"13.64.30.118/32\",\r\n \"13.64.31.116/32\",\r\n\ + \ \"13.64.196.27/32\",\r\n \"13.64.198.19/32\",\r\n \ + \ \"13.64.198.97/32\",\r\n \"13.64.199.41/32\",\r\n \ + \ \"13.64.252.115/32\",\r\n \"13.66.134.18/32\",\r\n \"\ + 13.66.142.80/28\",\r\n \"13.66.158.8/32\",\r\n \"13.66.168.209/32\"\ + ,\r\n \"13.66.173.192/32\",\r\n \"13.66.210.205/32\",\r\n\ + \ \"13.67.10.192/28\",\r\n \"13.67.48.221/32\",\r\n \ + \ \"13.69.67.96/28\",\r\n \"13.69.107.96/28\",\r\n \ + \ \"13.69.190.115/32\",\r\n \"13.69.230.48/28\",\r\n \"\ + 13.70.74.160/27\",\r\n \"13.71.175.0/27\",\r\n \"13.71.196.192/27\"\ + ,\r\n \"13.73.242.224/27\",\r\n \"13.74.108.176/28\",\r\n\ + \ \"13.74.168.152/32\",\r\n \"13.75.39.128/27\",\r\n \ + \ \"13.76.43.73/32\",\r\n \"13.76.129.255/32\",\r\n \ + \ \"13.77.53.96/27\",\r\n \"13.77.80.28/32\",\r\n \"13.77.136.80/32\"\ + ,\r\n \"13.77.148.229/32\",\r\n \"13.77.160.162/32\",\r\n\ + \ \"13.77.163.148/32\",\r\n \"13.77.165.61/32\",\r\n \ + \ \"13.80.7.94/32\",\r\n \"13.80.22.71/32\",\r\n \"\ + 13.80.125.22/32\",\r\n \"13.81.123.49/32\",\r\n \"13.81.204.189/32\"\ + ,\r\n \"13.81.212.71/32\",\r\n \"13.86.176.189/32\",\r\n\ + \ \"13.86.176.211/32\",\r\n \"13.86.219.224/27\",\r\n \ + \ \"13.86.235.202/32\",\r\n \"13.86.239.236/32\",\r\n \ + \ \"13.88.224.38/32\",\r\n \"13.88.224.211/32\",\r\n \ + \ \"13.88.224.222/32\",\r\n \"13.88.226.74/32\",\r\n \"\ + 13.88.227.7/32\",\r\n \"13.89.178.0/28\",\r\n \"13.91.61.249/32\"\ + ,\r\n \"13.91.91.243/32\",\r\n \"13.91.98.185/32\",\r\n\ + \ \"13.93.32.114/32\",\r\n \"13.93.113.192/32\",\r\n \ + \ \"13.93.196.52/32\",\r\n \"13.93.216.68/32\",\r\n \ + \ \"13.93.233.42/32\",\r\n \"13.95.1.33/32\",\r\n \"13.95.29.177/32\"\ + ,\r\n \"13.95.30.46/32\",\r\n \"20.36.220.93/32\",\r\n \ + \ \"20.36.222.59/32\",\r\n \"20.36.222.60/32\",\r\n \ + \ \"20.36.240.76/32\",\r\n \"20.36.244.208/32\",\r\n \ + \ \"20.36.245.0/32\",\r\n \"20.36.245.182/32\",\r\n \"\ + 20.36.245.235/32\",\r\n \"20.36.246.188/32\",\r\n \"20.36.248.40/32\"\ + ,\r\n \"20.40.106.50/31\",\r\n \"20.40.107.84/32\",\r\n\ + \ \"20.40.132.195/32\",\r\n \"20.40.134.79/32\",\r\n \ + \ \"20.40.134.94/32\",\r\n \"20.40.160.184/32\",\r\n \ + \ \"20.40.161.119/32\",\r\n \"20.40.161.131/32\",\r\n \ + \ \"20.40.161.132/32\",\r\n \"20.40.161.135/32\",\r\n \"\ + 20.40.161.140/30\",\r\n \"20.40.161.160/31\",\r\n \"20.40.162.86/32\"\ + ,\r\n \"20.40.162.200/32\",\r\n \"20.40.163.88/32\",\r\n\ + \ \"20.40.163.96/31\",\r\n \"20.40.163.130/32\",\r\n \ + \ \"20.40.163.133/32\",\r\n \"20.40.163.178/31\",\r\n \ + \ \"20.42.29.162/32\",\r\n \"20.42.31.48/32\",\r\n \"\ + 20.42.31.251/32\",\r\n \"20.44.8.208/28\",\r\n \"20.44.17.64/28\"\ + ,\r\n \"20.44.72.173/32\",\r\n \"20.44.72.217/32\",\r\n\ + \ \"20.44.73.253/32\",\r\n \"20.45.3.127/32\",\r\n \ + \ \"20.184.57.4/32\",\r\n \"20.184.57.218/32\",\r\n \ + \ \"20.184.58.46/32\",\r\n \"20.184.58.110/32\",\r\n \"\ + 20.184.60.77/32\",\r\n \"20.184.61.67/32\",\r\n \"20.184.61.253/32\"\ + ,\r\n \"20.184.63.158/32\",\r\n \"20.184.63.216/32\",\r\n\ + \ \"20.184.63.232/32\",\r\n \"20.188.72.248/32\",\r\n \ + \ \"23.97.54.160/32\",\r\n \"23.97.55.165/32\",\r\n \ + \ \"23.98.83.96/28\",\r\n \"23.100.67.153/32\",\r\n \"\ + 40.65.169.46/32\",\r\n \"40.65.169.97/32\",\r\n \"40.65.169.196/32\"\ + ,\r\n \"40.65.169.236/32\",\r\n \"40.65.170.17/32\",\r\n\ + \ \"40.65.170.26/32\",\r\n \"40.65.170.80/30\",\r\n \ + \ \"40.65.170.112/31\",\r\n \"40.65.170.123/32\",\r\n \ + \ \"40.65.170.125/32\",\r\n \"40.65.170.128/32\",\r\n \ + \ \"40.65.170.133/32\",\r\n \"40.65.170.137/32\",\r\n \"\ + 40.65.233.253/32\",\r\n \"40.65.235.54/32\",\r\n \"40.66.56.158/32\"\ + ,\r\n \"40.66.57.164/32\",\r\n \"40.66.57.203/32\",\r\n\ + \ \"40.66.59.41/32\",\r\n \"40.66.59.193/32\",\r\n \ + \ \"40.66.59.195/32\",\r\n \"40.66.59.196/32\",\r\n \ + \ \"40.66.59.246/32\",\r\n \"40.66.60.101/32\",\r\n \"40.66.60.118/32\"\ + ,\r\n \"40.66.60.180/32\",\r\n \"40.66.60.185/32\",\r\n\ + \ \"40.66.60.200/32\",\r\n \"40.66.60.206/31\",\r\n \ + \ \"40.66.60.208/31\",\r\n \"40.66.60.210/32\",\r\n \ + \ \"40.66.60.215/32\",\r\n \"40.66.60.216/31\",\r\n \"\ + 40.66.60.219/32\",\r\n \"40.66.60.220/31\",\r\n \"40.66.60.222/32\"\ + ,\r\n \"40.66.60.224/31\",\r\n \"40.66.60.226/32\",\r\n\ + \ \"40.66.60.232/32\",\r\n \"40.66.61.61/32\",\r\n \ + \ \"40.66.61.158/32\",\r\n \"40.66.61.193/32\",\r\n \ + \ \"40.66.61.226/32\",\r\n \"40.66.62.7/32\",\r\n \"40.66.62.9/32\"\ + ,\r\n \"40.66.62.78/32\",\r\n \"40.66.62.130/32\",\r\n \ + \ \"40.66.62.154/32\",\r\n \"40.66.62.225/32\",\r\n \ + \ \"40.66.63.148/32\",\r\n \"40.66.63.255/32\",\r\n \ + \ \"40.67.152.91/32\",\r\n \"40.67.152.227/32\",\r\n \"\ + 40.67.154.160/32\",\r\n \"40.67.155.146/32\",\r\n \"40.67.159.55/32\"\ + ,\r\n \"40.67.216.253/32\",\r\n \"40.67.219.133/32\",\r\n\ + \ \"40.67.251.0/32\",\r\n \"40.67.254.233/32\",\r\n \ + \ \"40.68.245.184/32\",\r\n \"40.69.108.96/27\",\r\n \ + \ \"40.70.0.255/32\",\r\n \"40.70.29.49/32\",\r\n \"40.70.29.200/32\"\ + ,\r\n \"40.70.148.112/28\",\r\n \"40.70.184.90/32\",\r\n\ + \ \"40.71.14.16/28\",\r\n \"40.74.1.235/32\",\r\n \ + \ \"40.74.6.204/32\",\r\n \"40.76.78.217/32\",\r\n \"\ + 40.78.23.204/32\",\r\n \"40.78.56.129/32\",\r\n \"40.78.229.64/28\"\ + ,\r\n \"40.78.236.160/28\",\r\n \"40.78.245.0/28\",\r\n\ + \ \"40.78.251.128/28\",\r\n \"40.79.132.96/28\",\r\n \ + \ \"40.79.139.16/28\",\r\n \"40.79.146.224/28\",\r\n \ + \ \"40.79.156.112/28\",\r\n \"40.79.180.64/27\",\r\n \ + \ \"40.80.219.49/32\",\r\n \"40.80.220.215/32\",\r\n \"\ + 40.80.220.246/32\",\r\n \"40.80.221.77/32\",\r\n \"40.80.222.91/32\"\ + ,\r\n \"40.80.222.197/32\",\r\n \"40.81.56.80/32\",\r\n\ + \ \"40.81.57.138/32\",\r\n \"40.81.57.141/32\",\r\n \ + \ \"40.81.57.144/32\",\r\n \"40.81.57.157/32\",\r\n \ + \ \"40.81.57.164/32\",\r\n \"40.81.57.169/32\",\r\n \"\ + 40.81.58.180/32\",\r\n \"40.81.58.184/32\",\r\n \"40.81.58.193/32\"\ + ,\r\n \"40.81.59.4/32\",\r\n \"40.81.59.90/32\",\r\n \ + \ \"40.81.59.93/32\",\r\n \"40.81.62.162/32\",\r\n \ + \ \"40.81.62.179/32\",\r\n \"40.81.62.193/32\",\r\n \"\ + 40.81.62.199/32\",\r\n \"40.81.62.206/32\",\r\n \"40.81.62.209/32\"\ + ,\r\n \"40.81.62.212/32\",\r\n \"40.81.62.220/30\",\r\n\ + \ \"40.81.62.224/32\",\r\n \"40.81.62.255/32\",\r\n \ + \ \"40.81.63.1/32\",\r\n \"40.81.63.2/32\",\r\n \"\ + 40.81.63.4/31\",\r\n \"40.81.63.7/32\",\r\n \"40.81.63.8/32\"\ + ,\r\n \"40.81.63.235/32\",\r\n \"40.81.63.245/32\",\r\n\ + \ \"40.81.63.248/32\",\r\n \"40.81.120.13/32\",\r\n \ + \ \"40.81.120.24/31\",\r\n \"40.81.120.97/32\",\r\n \ + \ \"40.81.120.187/32\",\r\n \"40.81.120.191/32\",\r\n \"\ + 40.81.120.192/32\",\r\n \"40.81.121.66/32\",\r\n \"40.81.121.76/32\"\ + ,\r\n \"40.81.121.78/32\",\r\n \"40.81.121.107/32\",\r\n\ + \ \"40.81.121.108/32\",\r\n \"40.81.121.111/32\",\r\n \ + \ \"40.81.121.127/32\",\r\n \"40.81.121.135/32\",\r\n \ + \ \"40.81.121.140/32\",\r\n \"40.81.121.175/32\",\r\n \ + \ \"40.81.122.4/32\",\r\n \"40.81.122.62/31\",\r\n \"\ + 40.81.122.76/32\",\r\n \"40.81.122.203/32\",\r\n \"40.81.123.124/32\"\ + ,\r\n \"40.81.123.157/32\",\r\n \"40.81.124.185/32\",\r\n\ + \ \"40.81.124.219/32\",\r\n \"40.81.127.25/32\",\r\n \ + \ \"40.81.127.139/32\",\r\n \"40.81.127.140/31\",\r\n \ + \ \"40.81.127.229/32\",\r\n \"40.81.127.230/32\",\r\n \ + \ \"40.81.127.239/32\",\r\n \"40.81.152.126/32\",\r\n \ + \ \"40.81.152.171/32\",\r\n \"40.81.152.172/32\",\r\n \"\ + 40.81.156.153/32\",\r\n \"40.81.156.154/31\",\r\n \"40.81.156.156/32\"\ + ,\r\n \"40.81.159.35/32\",\r\n \"40.81.159.77/32\",\r\n\ + \ \"40.82.184.80/32\",\r\n \"40.82.185.36/32\",\r\n \ + \ \"40.82.185.117/32\",\r\n \"40.82.185.229/32\",\r\n \ + \ \"40.82.186.166/32\",\r\n \"40.82.186.168/31\",\r\n \ + \ \"40.82.186.176/31\",\r\n \"40.82.186.180/32\",\r\n \"\ + 40.82.186.182/32\",\r\n \"40.82.186.185/32\",\r\n \"40.82.186.214/32\"\ + ,\r\n \"40.82.186.231/32\",\r\n \"40.82.187.161/32\",\r\n\ + \ \"40.82.187.162/31\",\r\n \"40.82.187.164/32\",\r\n \ + \ \"40.82.187.177/32\",\r\n \"40.82.187.178/31\",\r\n \ + \ \"40.82.187.199/32\",\r\n \"40.82.187.200/32\",\r\n \ + \ \"40.82.187.202/32\",\r\n \"40.82.187.204/30\",\r\n \ + \ \"40.82.187.208/30\",\r\n \"40.82.187.212/31\",\r\n \"\ + 40.82.187.218/32\",\r\n \"40.82.187.223/32\",\r\n \"40.82.190.163/32\"\ + ,\r\n \"40.82.191.58/32\",\r\n \"40.84.2.83/32\",\r\n \ + \ \"40.84.4.93/32\",\r\n \"40.84.4.119/32\",\r\n \ + \ \"40.84.5.28/32\",\r\n \"40.84.49.16/32\",\r\n \"40.89.136.227/32\"\ + ,\r\n \"40.89.137.101/32\",\r\n \"40.89.142.184/32\",\r\n\ + \ \"40.89.143.43/32\",\r\n \"40.90.184.197/32\",\r\n \ + \ \"40.90.185.64/32\",\r\n \"40.90.191.153/32\",\r\n \ + \ \"40.90.218.196/31\",\r\n \"40.90.218.198/32\",\r\n \ + \ \"40.90.218.203/32\",\r\n \"40.90.219.121/32\",\r\n \"\ + 40.90.219.184/32\",\r\n \"40.90.220.37/32\",\r\n \"40.90.220.190/32\"\ + ,\r\n \"40.90.220.196/32\",\r\n \"40.90.222.64/32\",\r\n\ + \ \"40.91.74.37/32\",\r\n \"40.91.78.105/32\",\r\n \ + \ \"40.91.114.40/29\",\r\n \"40.91.114.48/31\",\r\n \ + \ \"40.91.122.25/32\",\r\n \"40.91.122.38/32\",\r\n \"40.91.126.157/32\"\ + ,\r\n \"40.91.127.44/32\",\r\n \"40.91.198.19/32\",\r\n\ + \ \"40.113.121.176/32\",\r\n \"40.114.112.147/32\",\r\n\ + \ \"40.114.217.8/32\",\r\n \"40.115.24.65/32\",\r\n \ + \ \"40.115.25.50/32\",\r\n \"40.115.71.111/32\",\r\n \ + \ \"40.118.63.137/32\",\r\n \"40.118.97.232/32\",\r\n \ + \ \"40.118.211.172/32\",\r\n \"40.119.145.130/32\",\r\n \ + \ \"40.119.147.102/32\",\r\n \"40.119.154.72/32\",\r\n \"\ + 40.119.203.98/31\",\r\n \"40.119.203.158/31\",\r\n \"40.119.203.208/31\"\ + ,\r\n \"40.119.207.131/32\",\r\n \"40.119.207.144/32\",\r\ + \n \"40.119.207.164/32\",\r\n \"40.119.207.166/32\",\r\n\ + \ \"40.119.207.174/32\",\r\n \"40.119.207.182/32\",\r\n\ + \ \"40.119.207.193/32\",\r\n \"40.119.207.200/32\",\r\n\ + \ \"40.119.215.167/32\",\r\n \"40.121.134.1/32\",\r\n \ + \ \"40.124.53.69/32\",\r\n \"51.11.26.92/32\",\r\n \ + \ \"51.11.26.95/32\",\r\n \"51.104.9.16/28\",\r\n \"51.105.37.244/32\"\ + ,\r\n \"51.105.67.224/28\",\r\n \"51.105.75.176/28\",\r\n\ + \ \"51.105.124.64/32\",\r\n \"51.105.124.80/32\",\r\n \ + \ \"51.105.161.5/32\",\r\n \"51.105.163.8/32\",\r\n \ + \ \"51.105.163.43/32\",\r\n \"51.105.164.8/32\",\r\n \ + \ \"51.105.164.234/32\",\r\n \"51.105.164.241/32\",\r\n \ + \ \"51.105.165.31/32\",\r\n \"51.105.165.37/32\",\r\n \"\ + 51.105.165.63/32\",\r\n \"51.105.165.116/32\",\r\n \"51.105.166.102/31\"\ + ,\r\n \"51.105.166.106/32\",\r\n \"51.105.179.157/32\",\r\ + \n \"51.137.136.13/32\",\r\n \"51.137.136.14/32\",\r\n \ + \ \"51.137.136.34/32\",\r\n \"51.137.137.69/32\",\r\n \ + \ \"51.137.137.118/32\",\r\n \"51.137.137.121/32\",\r\n \ + \ \"51.137.137.200/32\",\r\n \"51.137.137.237/32\",\r\n \ + \ \"51.140.1.10/32\",\r\n \"51.140.8.108/32\",\r\n \ + \ \"51.140.8.180/32\",\r\n \"51.140.35.95/32\",\r\n \"\ + 51.140.52.106/32\",\r\n \"51.140.78.213/32\",\r\n \"51.140.105.124/32\"\ + ,\r\n \"51.140.125.227/32\",\r\n \"51.140.164.179/32\",\r\ + \n \"51.140.191.146/32\",\r\n \"51.140.212.128/27\",\r\n\ + \ \"51.140.230.246/32\",\r\n \"51.140.231.138/32\",\r\n\ + \ \"51.141.2.189/32\",\r\n \"51.141.7.11/32\",\r\n \ + \ \"51.143.58.207/32\",\r\n \"51.143.111.58/32\",\r\n \ + \ \"51.143.120.236/32\",\r\n \"51.143.120.242/32\",\r\n \ + \ \"51.143.122.59/32\",\r\n \"51.143.122.60/32\",\r\n \ + \ \"51.144.56.60/32\",\r\n \"51.145.108.227/32\",\r\n \"\ + 51.145.108.250/32\",\r\n \"51.145.181.195/32\",\r\n \"51.145.181.214/32\"\ + ,\r\n \"52.137.56.200/32\",\r\n \"52.137.89.147/32\",\r\n\ + \ \"52.138.227.160/28\",\r\n \"52.139.1.70/32\",\r\n \ + \ \"52.139.1.156/32\",\r\n \"52.139.1.158/31\",\r\n \ + \ \"52.139.1.200/32\",\r\n \"52.139.1.218/32\",\r\n \"\ + 52.139.2.0/32\",\r\n \"52.139.16.105/32\",\r\n \"52.139.18.234/32\"\ + ,\r\n \"52.139.18.236/32\",\r\n \"52.139.19.71/32\",\r\n\ + \ \"52.139.19.187/32\",\r\n \"52.139.19.215/32\",\r\n \ + \ \"52.139.19.247/32\",\r\n \"52.139.20.31/32\",\r\n \ + \ \"52.139.20.118/32\",\r\n \"52.139.21.70/32\",\r\n \ + \ \"52.139.245.1/32\",\r\n \"52.139.245.21/32\",\r\n \"\ + 52.139.245.40/32\",\r\n \"52.139.245.48/32\",\r\n \"52.139.251.219/32\"\ + ,\r\n \"52.139.252.105/32\",\r\n \"52.142.112.145/32\",\r\ + \n \"52.142.112.146/32\",\r\n \"52.142.116.135/32\",\r\n\ + \ \"52.142.116.174/32\",\r\n \"52.142.116.250/32\",\r\n\ + \ \"52.142.117.183/32\",\r\n \"52.142.118.130/32\",\r\n\ + \ \"52.142.121.6/32\",\r\n \"52.142.121.75/32\",\r\n \ + \ \"52.142.124.23/32\",\r\n \"52.142.127.127/32\",\r\n \ + \ \"52.142.220.179/32\",\r\n \"52.142.232.120/32\",\r\n \ + \ \"52.143.73.88/32\",\r\n \"52.143.74.31/32\",\r\n \ + \ \"52.148.115.188/32\",\r\n \"52.148.115.194/32\",\r\n \ + \ \"52.148.115.238/32\",\r\n \"52.148.116.37/32\",\r\n \ + \ \"52.148.161.45/32\",\r\n \"52.148.161.53/32\",\r\n \"\ + 52.151.237.243/32\",\r\n \"52.151.238.5/32\",\r\n \"52.151.244.65/32\"\ + ,\r\n \"52.151.247.27/32\",\r\n \"52.153.240.107/32\",\r\ + \n \"52.155.161.88/32\",\r\n \"52.155.161.91/32\",\r\n \ + \ \"52.155.164.131/32\",\r\n \"52.155.166.50/32\",\r\n \ + \ \"52.155.167.231/32\",\r\n \"52.155.168.45/32\",\r\n \ + \ \"52.155.177.13/32\",\r\n \"52.155.178.247/32\",\r\n \ + \ \"52.155.179.84/32\",\r\n \"52.155.180.208/30\",\r\n \ + \ \"52.155.181.180/30\",\r\n \"52.155.182.48/31\",\r\n \ + \ \"52.155.182.50/32\",\r\n \"52.155.182.138/32\",\r\n \ + \ \"52.155.182.141/32\",\r\n \"52.156.197.208/32\",\r\n \ + \ \"52.156.197.254/32\",\r\n \"52.156.198.196/32\",\r\n \ + \ \"52.156.202.7/32\",\r\n \"52.156.203.22/32\",\r\n \"\ + 52.156.203.198/31\",\r\n \"52.156.204.24/32\",\r\n \"52.156.204.51/32\"\ + ,\r\n \"52.156.204.99/32\",\r\n \"52.156.204.139/32\",\r\ + \n \"52.156.205.137/32\",\r\n \"52.156.205.182/32\",\r\n\ + \ \"52.156.205.222/32\",\r\n \"52.156.205.226/32\",\r\n\ + \ \"52.156.206.43/32\",\r\n \"52.156.206.45/32\",\r\n \ + \ \"52.156.206.46/31\",\r\n \"52.157.19.228/32\",\r\n \ + \ \"52.157.20.142/32\",\r\n \"52.157.218.219/32\",\r\n \ + \ \"52.157.218.232/32\",\r\n \"52.157.232.110/32\",\r\n \ + \ \"52.157.232.147/32\",\r\n \"52.157.233.49/32\",\r\n \ + \ \"52.157.233.92/32\",\r\n \"52.157.233.133/32\",\r\n \ + \ \"52.157.233.205/32\",\r\n \"52.157.234.160/32\",\r\n \ + \ \"52.157.234.222/32\",\r\n \"52.157.235.27/32\",\r\n \ + \ \"52.157.235.144/32\",\r\n \"52.157.236.195/32\",\r\n \ + \ \"52.157.237.107/32\",\r\n \"52.157.237.213/32\",\r\n \ + \ \"52.157.237.255/32\",\r\n \"52.157.238.58/32\",\r\n \ + \ \"52.157.239.110/32\",\r\n \"52.157.239.132/32\",\r\n \ + \ \"52.158.28.235/32\",\r\n \"52.167.107.96/28\",\r\n \"\ + 52.169.192.237/32\",\r\n \"52.174.56.180/32\",\r\n \"52.177.85.43/32\"\ + ,\r\n \"52.178.44.248/32\",\r\n \"52.178.89.44/32\",\r\n\ + \ \"52.179.155.177/32\",\r\n \"52.179.194.73/32\",\r\n \ + \ \"52.179.198.41/32\",\r\n \"52.182.139.208/28\",\r\n \ + \ \"52.183.24.254/32\",\r\n \"52.183.30.204/32\",\r\n \ + \ \"52.183.75.62/32\",\r\n \"52.184.165.82/32\",\r\n \ + \ \"52.188.217.236/32\",\r\n \"52.189.208.36/32\",\r\n \ + \ \"52.189.213.36/32\",\r\n \"52.189.213.124/32\",\r\n \ + \ \"52.189.218.253/32\",\r\n \"52.190.26.220/32\",\r\n \"\ + 52.190.31.62/32\",\r\n \"52.191.129.65/32\",\r\n \"52.191.237.188/32\"\ + ,\r\n \"52.191.238.65/32\",\r\n \"52.224.188.157/32\",\r\ + \n \"52.224.188.168/32\",\r\n \"52.224.190.225/32\",\r\n\ + \ \"52.224.191.62/32\",\r\n \"52.224.201.216/32\",\r\n \ + \ \"52.224.201.223/32\",\r\n \"52.224.202.86/32\",\r\n \ + \ \"52.224.202.91/32\",\r\n \"52.225.225.218/32\",\r\n \ + \ \"52.225.231.232/32\",\r\n \"52.232.224.227/32\",\r\n \ + \ \"52.232.225.84/32\",\r\n \"52.232.228.217/32\",\r\n \ + \ \"52.232.245.96/32\",\r\n \"52.236.187.80/28\",\r\n \ + \ \"52.249.25.160/32\",\r\n \"52.249.25.165/32\",\r\n \ + \ \"65.52.138.123/32\",\r\n \"65.52.229.200/32\",\r\n \"\ + 104.40.28.202/32\",\r\n \"104.40.129.120/32\",\r\n \"104.42.15.41/32\"\ + ,\r\n \"104.42.34.58/32\",\r\n \"104.42.38.254/32\",\r\n\ + \ \"104.42.54.24/32\",\r\n \"104.42.75.120/32\",\r\n \ + \ \"104.42.211.215/32\",\r\n \"104.45.7.95/32\",\r\n \ + \ \"104.45.65.169/32\",\r\n \"104.45.168.103/32\",\r\n \ + \ \"104.45.168.104/32\",\r\n \"104.45.168.106/32\",\r\n \ + \ \"104.45.168.108/32\",\r\n \"104.45.168.111/32\",\r\n \ + \ \"104.45.168.114/32\",\r\n \"104.45.170.70/32\",\r\n \ + \ \"104.45.170.127/32\",\r\n \"104.45.170.161/32\",\r\n \ + \ \"104.45.170.173/32\",\r\n \"104.45.170.174/31\",\r\n \ + \ \"104.45.170.176/32\",\r\n \"104.45.170.178/32\",\r\n \ + \ \"104.45.170.180/32\",\r\n \"104.45.170.182/31\",\r\n \ + \ \"104.45.170.184/31\",\r\n \"104.45.170.186/32\",\r\n \ + \ \"104.45.170.188/32\",\r\n \"104.45.170.191/32\",\r\n \ + \ \"104.45.170.194/32\",\r\n \"104.45.170.196/32\",\r\n \ + \ \"104.46.116.211/32\",\r\n \"104.46.121.72/32\",\r\n \ + \ \"104.46.122.189/32\",\r\n \"104.208.216.221/32\",\r\n \ + \ \"104.209.35.177/32\",\r\n \"104.209.168.251/32\",\r\n \ + \ \"104.210.0.32/32\",\r\n \"104.211.9.226/32\",\r\n \"\ + 104.214.225.33/32\",\r\n \"137.116.52.31/32\",\r\n \"138.91.147.71/32\"\ + ,\r\n \"168.63.38.153/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"MicrosoftCloudAppSecurity.AustraliaEast\",\r\n\ + \ \"id\": \"MicrosoftCloudAppSecurity.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.70.74.160/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.AustraliaSoutheast\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.AustraliaSoutheast\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"MicrosoftCloudAppSecurity\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.77.53.96/27\",\r\n \"20.40.160.184/32\",\r\n\ + \ \"20.40.161.119/32\",\r\n \"20.40.161.131/32\",\r\n \ + \ \"20.40.161.132/32\",\r\n \"20.40.161.135/32\",\r\n \ + \ \"20.40.161.140/30\",\r\n \"20.40.161.160/31\",\r\n \ + \ \"20.40.162.86/32\",\r\n \"20.40.162.200/32\",\r\n \ + \ \"20.40.163.88/32\",\r\n \"20.40.163.96/31\",\r\n \"20.40.163.130/32\"\ + ,\r\n \"20.40.163.133/32\",\r\n \"20.40.163.178/31\",\r\n\ + \ \"40.81.56.80/32\",\r\n \"40.81.57.138/32\",\r\n \ + \ \"40.81.57.141/32\",\r\n \"40.81.57.144/32\",\r\n \ + \ \"40.81.57.157/32\",\r\n \"40.81.57.164/32\",\r\n \"40.81.57.169/32\"\ + ,\r\n \"40.81.58.180/32\",\r\n \"40.81.58.184/32\",\r\n\ + \ \"40.81.58.193/32\",\r\n \"40.81.59.4/32\",\r\n \ + \ \"40.81.59.90/32\",\r\n \"40.81.59.93/32\",\r\n \"\ + 40.81.62.162/32\",\r\n \"40.81.62.179/32\",\r\n \"40.81.62.193/32\"\ + ,\r\n \"40.81.62.199/32\",\r\n \"40.81.62.206/32\",\r\n\ + \ \"40.81.62.209/32\",\r\n \"40.81.62.212/32\",\r\n \ + \ \"40.81.62.220/30\",\r\n \"40.81.62.224/32\",\r\n \ + \ \"40.81.62.255/32\",\r\n \"40.81.63.1/32\",\r\n \"40.81.63.2/32\"\ + ,\r\n \"40.81.63.4/31\",\r\n \"40.81.63.7/32\",\r\n \ + \ \"40.81.63.8/32\",\r\n \"40.81.63.235/32\",\r\n \"\ + 40.81.63.245/32\",\r\n \"40.81.63.248/32\",\r\n \"40.115.71.111/32\"\ + ,\r\n \"52.189.208.36/32\",\r\n \"52.189.213.36/32\",\r\n\ + \ \"52.189.213.124/32\",\r\n \"52.189.218.253/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.CanadaCentral\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.CanadaCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"canadacentral\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.175.0/27\",\r\n \ + \ \"13.88.224.38/32\",\r\n \"13.88.224.211/32\",\r\n \ + \ \"13.88.224.222/32\",\r\n \"13.88.226.74/32\",\r\n \ + \ \"13.88.227.7/32\",\r\n \"40.82.184.80/32\",\r\n \"\ + 40.82.185.36/32\",\r\n \"40.82.185.117/32\",\r\n \"40.82.185.229/32\"\ + ,\r\n \"40.82.186.166/32\",\r\n \"40.82.186.168/31\",\r\n\ + \ \"40.82.186.176/31\",\r\n \"40.82.186.180/32\",\r\n \ + \ \"40.82.186.182/32\",\r\n \"40.82.186.185/32\",\r\n \ + \ \"40.82.186.214/32\",\r\n \"40.82.186.231/32\",\r\n \ + \ \"40.82.187.161/32\",\r\n \"40.82.187.162/31\",\r\n \ + \ \"40.82.187.164/32\",\r\n \"40.82.187.177/32\",\r\n \"\ + 40.82.187.178/31\",\r\n \"40.82.187.199/32\",\r\n \"40.82.187.200/32\"\ + ,\r\n \"40.82.187.202/32\",\r\n \"40.82.187.204/30\",\r\n\ + \ \"40.82.187.208/30\",\r\n \"40.82.187.212/31\",\r\n \ + \ \"40.82.187.218/32\",\r\n \"40.82.187.223/32\",\r\n \ + \ \"40.82.190.163/32\",\r\n \"40.82.191.58/32\",\r\n \ + \ \"52.139.1.70/32\",\r\n \"52.139.1.156/32\",\r\n \"\ + 52.139.1.158/31\",\r\n \"52.139.1.200/32\",\r\n \"52.139.1.218/32\"\ + ,\r\n \"52.139.2.0/32\",\r\n \"52.139.16.105/32\",\r\n \ + \ \"52.139.18.234/32\",\r\n \"52.139.18.236/32\",\r\n \ + \ \"52.139.19.71/32\",\r\n \"52.139.19.187/32\",\r\n \ + \ \"52.139.19.215/32\",\r\n \"52.139.19.247/32\",\r\n \ + \ \"52.139.20.31/32\",\r\n \"52.139.20.118/32\",\r\n \"\ + 52.139.21.70/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"MicrosoftCloudAppSecurity.CanadaEast\",\r\n \"id\": \"MicrosoftCloudAppSecurity.CanadaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftCloudAppSecurity\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.108.96/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftCloudAppSecurity.CentralUS\",\r\n \"id\"\ + : \"MicrosoftCloudAppSecurity.CentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.89.178.0/28\",\r\n \ + \ \"20.44.8.208/28\",\r\n \"52.182.139.208/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.EastAsia\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.75.39.128/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.EastUS\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.EastUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.42.29.162/32\",\r\n\ + \ \"20.42.31.48/32\",\r\n \"20.42.31.251/32\",\r\n \ + \ \"40.71.14.16/28\",\r\n \"40.76.78.217/32\",\r\n \"\ + 40.78.229.64/28\",\r\n \"40.79.156.112/28\",\r\n \"40.114.112.147/32\"\ + ,\r\n \"40.121.134.1/32\",\r\n \"52.151.237.243/32\",\r\n\ + \ \"52.151.238.5/32\",\r\n \"52.151.244.65/32\",\r\n \ + \ \"52.151.247.27/32\",\r\n \"52.188.217.236/32\",\r\n \ + \ \"52.190.26.220/32\",\r\n \"52.190.31.62/32\",\r\n \ + \ \"52.191.237.188/32\",\r\n \"52.191.238.65/32\",\r\n \ + \ \"52.224.188.157/32\",\r\n \"52.224.188.168/32\",\r\n \ + \ \"52.224.190.225/32\",\r\n \"52.224.191.62/32\",\r\n \ + \ \"52.224.201.216/32\",\r\n \"52.224.201.223/32\",\r\n \ + \ \"52.224.202.86/32\",\r\n \"52.224.202.91/32\",\r\n \"\ + 104.45.168.103/32\",\r\n \"104.45.168.104/32\",\r\n \"104.45.168.106/32\"\ + ,\r\n \"104.45.168.108/32\",\r\n \"104.45.168.111/32\",\r\ + \n \"104.45.168.114/32\",\r\n \"104.45.170.70/32\",\r\n\ + \ \"104.45.170.127/32\",\r\n \"104.45.170.161/32\",\r\n\ + \ \"104.45.170.173/32\",\r\n \"104.45.170.174/31\",\r\n\ + \ \"104.45.170.176/32\",\r\n \"104.45.170.178/32\",\r\n\ + \ \"104.45.170.180/32\",\r\n \"104.45.170.182/31\",\r\n\ + \ \"104.45.170.184/31\",\r\n \"104.45.170.186/32\",\r\n\ + \ \"104.45.170.188/32\",\r\n \"104.45.170.191/32\",\r\n\ + \ \"104.45.170.194/32\",\r\n \"104.45.170.196/32\",\r\n\ + \ \"104.211.9.226/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftCloudAppSecurity.EastUS2\",\r\n \"id\":\ + \ \"MicrosoftCloudAppSecurity.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.80.28/32\",\r\n \ + \ \"20.36.220.93/32\",\r\n \"20.36.222.59/32\",\r\n \ + \ \"20.36.222.60/32\",\r\n \"20.36.240.76/32\",\r\n \ + \ \"20.36.244.208/32\",\r\n \"20.36.245.0/32\",\r\n \"20.36.245.182/32\"\ + ,\r\n \"20.36.245.235/32\",\r\n \"20.36.246.188/32\",\r\n\ + \ \"20.36.248.40/32\",\r\n \"20.44.17.64/28\",\r\n \ + \ \"20.44.72.173/32\",\r\n \"20.44.72.217/32\",\r\n \ + \ \"20.44.73.253/32\",\r\n \"23.100.67.153/32\",\r\n \"\ + 40.65.233.253/32\",\r\n \"40.65.235.54/32\",\r\n \"40.67.152.91/32\"\ + ,\r\n \"40.67.152.227/32\",\r\n \"40.67.154.160/32\",\r\n\ + \ \"40.67.155.146/32\",\r\n \"40.67.159.55/32\",\r\n \ + \ \"40.70.0.255/32\",\r\n \"40.70.29.49/32\",\r\n \ + \ \"40.70.29.200/32\",\r\n \"40.70.148.112/28\",\r\n \"\ + 40.70.184.90/32\",\r\n \"40.84.2.83/32\",\r\n \"40.84.4.93/32\"\ + ,\r\n \"40.84.4.119/32\",\r\n \"40.84.5.28/32\",\r\n \ + \ \"40.84.49.16/32\",\r\n \"52.167.107.96/28\",\r\n \ + \ \"52.177.85.43/32\",\r\n \"52.179.155.177/32\",\r\n \ + \ \"52.179.194.73/32\",\r\n \"52.179.198.41/32\",\r\n \"\ + 52.184.165.82/32\",\r\n \"52.225.225.218/32\",\r\n \"52.225.231.232/32\"\ + ,\r\n \"52.232.224.227/32\",\r\n \"52.232.225.84/32\",\r\ + \n \"52.232.228.217/32\",\r\n \"52.232.245.96/32\",\r\n\ + \ \"104.46.116.211/32\",\r\n \"104.46.121.72/32\",\r\n \ + \ \"104.46.122.189/32\",\r\n \"104.208.216.221/32\",\r\n\ + \ \"104.209.168.251/32\",\r\n \"104.210.0.32/32\",\r\n \ + \ \"137.116.52.31/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftCloudAppSecurity.FranceCentral\",\r\n \"\ + id\": \"MicrosoftCloudAppSecurity.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.40.132.195/32\",\r\n\ + \ \"20.40.134.79/32\",\r\n \"20.40.134.94/32\",\r\n \ + \ \"40.66.56.158/32\",\r\n \"40.66.57.164/32\",\r\n \ + \ \"40.66.57.203/32\",\r\n \"40.66.59.41/32\",\r\n \"40.66.59.193/32\"\ + ,\r\n \"40.66.59.195/32\",\r\n \"40.66.59.196/32\",\r\n\ + \ \"40.66.59.246/32\",\r\n \"40.66.60.101/32\",\r\n \ + \ \"40.66.60.118/32\",\r\n \"40.66.60.180/32\",\r\n \ + \ \"40.66.60.185/32\",\r\n \"40.66.60.200/32\",\r\n \"\ + 40.66.60.206/31\",\r\n \"40.66.60.208/31\",\r\n \"40.66.60.210/32\"\ + ,\r\n \"40.66.60.215/32\",\r\n \"40.66.60.216/31\",\r\n\ + \ \"40.66.60.219/32\",\r\n \"40.66.60.220/31\",\r\n \ + \ \"40.66.60.222/32\",\r\n \"40.66.60.224/31\",\r\n \ + \ \"40.66.60.226/32\",\r\n \"40.66.60.232/32\",\r\n \"\ + 40.66.61.61/32\",\r\n \"40.66.61.158/32\",\r\n \"40.66.61.193/32\"\ + ,\r\n \"40.66.61.226/32\",\r\n \"40.66.62.7/32\",\r\n \ + \ \"40.66.62.9/32\",\r\n \"40.66.62.78/32\",\r\n \ + \ \"40.66.62.130/32\",\r\n \"40.66.62.154/32\",\r\n \"40.66.62.225/32\"\ + ,\r\n \"40.66.63.148/32\",\r\n \"40.66.63.255/32\",\r\n\ + \ \"40.79.132.96/28\",\r\n \"40.79.139.16/28\",\r\n \ + \ \"40.79.146.224/28\",\r\n \"40.89.136.227/32\",\r\n \ + \ \"40.89.137.101/32\",\r\n \"40.89.142.184/32\",\r\n \ + \ \"40.89.143.43/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftCloudAppSecurity.FranceSouth\",\r\n \"id\": \"\ + MicrosoftCloudAppSecurity.FranceSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.180.64/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.NorthEurope\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.NorthEurope\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"northeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.190.115/32\",\r\n\ + \ \"13.69.230.48/28\",\r\n \"13.74.108.176/28\",\r\n \ + \ \"13.74.168.152/32\",\r\n \"40.67.251.0/32\",\r\n \ + \ \"40.67.254.233/32\",\r\n \"52.138.227.160/28\",\r\n \ + \ \"52.142.112.145/32\",\r\n \"52.142.112.146/32\",\r\n \ + \ \"52.142.116.135/32\",\r\n \"52.142.116.174/32\",\r\n \ + \ \"52.142.116.250/32\",\r\n \"52.142.117.183/32\",\r\n \ + \ \"52.142.118.130/32\",\r\n \"52.142.121.6/32\",\r\n \"\ + 52.142.121.75/32\",\r\n \"52.142.124.23/32\",\r\n \"52.142.127.127/32\"\ + ,\r\n \"52.155.161.88/32\",\r\n \"52.155.161.91/32\",\r\n\ + \ \"52.155.164.131/32\",\r\n \"52.155.166.50/32\",\r\n \ + \ \"52.155.167.231/32\",\r\n \"52.155.168.45/32\",\r\n \ + \ \"52.155.177.13/32\",\r\n \"52.155.178.247/32\",\r\n \ + \ \"52.155.179.84/32\",\r\n \"52.155.180.208/30\",\r\n \ + \ \"52.155.181.180/30\",\r\n \"52.155.182.48/31\",\r\n \ + \ \"52.155.182.50/32\",\r\n \"52.155.182.138/32\",\r\n \ + \ \"52.155.182.141/32\",\r\n \"52.156.197.208/32\",\r\n \ + \ \"52.156.197.254/32\",\r\n \"52.156.198.196/32\",\r\n \ + \ \"52.156.202.7/32\",\r\n \"52.156.203.22/32\",\r\n \ + \ \"52.156.203.198/31\",\r\n \"52.156.204.24/32\",\r\n \"\ + 52.156.204.51/32\",\r\n \"52.156.204.99/32\",\r\n \"52.156.204.139/32\"\ + ,\r\n \"52.156.205.137/32\",\r\n \"52.156.205.182/32\",\r\ + \n \"52.156.205.222/32\",\r\n \"52.156.205.226/32\",\r\n\ + \ \"52.156.206.43/32\",\r\n \"52.156.206.45/32\",\r\n \ + \ \"52.156.206.46/31\",\r\n \"52.158.28.235/32\",\r\n \ + \ \"52.169.192.237/32\",\r\n \"65.52.229.200/32\",\r\n \ + \ \"168.63.38.153/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftCloudAppSecurity.SouthCentralUS\",\r\n \"\ + id\": \"MicrosoftCloudAppSecurity.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.242.224/27\",\r\n\ + \ \"20.45.3.127/32\",\r\n \"20.188.72.248/32\",\r\n \ + \ \"40.80.219.49/32\",\r\n \"40.80.220.215/32\",\r\n \ + \ \"40.80.220.246/32\",\r\n \"40.80.221.77/32\",\r\n \"\ + 40.80.222.91/32\",\r\n \"40.80.222.197/32\",\r\n \"40.124.53.69/32\"\ + ,\r\n \"52.153.240.107/32\",\r\n \"52.249.25.160/32\",\r\ + \n \"52.249.25.165/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftCloudAppSecurity.SoutheastAsia\",\r\n \ + \ \"id\": \"MicrosoftCloudAppSecurity.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.10.192/28\",\r\n\ + \ \"13.67.48.221/32\",\r\n \"13.76.43.73/32\",\r\n \ + \ \"13.76.129.255/32\",\r\n \"20.184.57.4/32\",\r\n \ + \ \"20.184.57.218/32\",\r\n \"20.184.58.46/32\",\r\n \"\ + 20.184.58.110/32\",\r\n \"20.184.60.77/32\",\r\n \"20.184.61.67/32\"\ + ,\r\n \"20.184.61.253/32\",\r\n \"20.184.63.158/32\",\r\n\ + \ \"20.184.63.216/32\",\r\n \"20.184.63.232/32\",\r\n \ + \ \"23.97.54.160/32\",\r\n \"23.97.55.165/32\",\r\n \ + \ \"23.98.83.96/28\",\r\n \"40.65.169.46/32\",\r\n \"\ + 40.65.169.97/32\",\r\n \"40.65.169.196/32\",\r\n \"40.65.169.236/32\"\ + ,\r\n \"40.65.170.17/32\",\r\n \"40.65.170.26/32\",\r\n\ + \ \"40.65.170.80/30\",\r\n \"40.65.170.112/31\",\r\n \ + \ \"40.65.170.123/32\",\r\n \"40.65.170.125/32\",\r\n \ + \ \"40.65.170.128/32\",\r\n \"40.65.170.133/32\",\r\n \ + \ \"40.65.170.137/32\",\r\n \"40.78.236.160/28\",\r\n \ + \ \"40.90.184.197/32\",\r\n \"40.90.185.64/32\",\r\n \"\ + 40.90.191.153/32\",\r\n \"40.119.203.98/31\",\r\n \"40.119.203.158/31\"\ + ,\r\n \"40.119.203.208/31\",\r\n \"40.119.207.131/32\",\r\ + \n \"40.119.207.144/32\",\r\n \"40.119.207.164/32\",\r\n\ + \ \"40.119.207.166/32\",\r\n \"40.119.207.174/32\",\r\n\ + \ \"40.119.207.182/32\",\r\n \"40.119.207.193/32\",\r\n\ + \ \"40.119.207.200/32\",\r\n \"40.119.215.167/32\",\r\n\ + \ \"52.139.245.1/32\",\r\n \"52.139.245.21/32\",\r\n \ + \ \"52.139.245.40/32\",\r\n \"52.139.245.48/32\",\r\n \ + \ \"52.139.251.219/32\",\r\n \"52.139.252.105/32\",\r\n \ + \ \"52.148.115.188/32\",\r\n \"52.148.115.194/32\",\r\n \ + \ \"52.148.115.238/32\",\r\n \"52.148.116.37/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.UKSouth\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.81.152.126/32\",\r\n\ + \ \"40.81.152.171/32\",\r\n \"40.81.152.172/32\",\r\n \ + \ \"40.81.156.153/32\",\r\n \"40.81.156.154/31\",\r\n \ + \ \"40.81.156.156/32\",\r\n \"40.81.159.35/32\",\r\n \ + \ \"40.81.159.77/32\",\r\n \"51.11.26.92/32\",\r\n \"\ + 51.11.26.95/32\",\r\n \"51.104.9.16/28\",\r\n \"51.105.37.244/32\"\ + ,\r\n \"51.105.67.224/28\",\r\n \"51.105.75.176/28\",\r\n\ + \ \"51.140.1.10/32\",\r\n \"51.140.8.108/32\",\r\n \ + \ \"51.140.8.180/32\",\r\n \"51.140.35.95/32\",\r\n \ + \ \"51.140.52.106/32\",\r\n \"51.140.78.213/32\",\r\n \"\ + 51.140.105.124/32\",\r\n \"51.140.125.227/32\",\r\n \"51.140.164.179/32\"\ + ,\r\n \"51.140.191.146/32\",\r\n \"51.145.108.227/32\",\r\ + \n \"51.145.108.250/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftCloudAppSecurity.UKWest\",\r\n \"\ + id\": \"MicrosoftCloudAppSecurity.UKWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.40.106.50/31\",\r\n\ + \ \"20.40.107.84/32\",\r\n \"40.81.120.13/32\",\r\n \ + \ \"40.81.120.24/31\",\r\n \"40.81.120.97/32\",\r\n \ + \ \"40.81.120.187/32\",\r\n \"40.81.120.191/32\",\r\n \"\ + 40.81.120.192/32\",\r\n \"40.81.121.66/32\",\r\n \"40.81.121.76/32\"\ + ,\r\n \"40.81.121.78/32\",\r\n \"40.81.121.107/32\",\r\n\ + \ \"40.81.121.108/32\",\r\n \"40.81.121.111/32\",\r\n \ + \ \"40.81.121.127/32\",\r\n \"40.81.121.135/32\",\r\n \ + \ \"40.81.121.140/32\",\r\n \"40.81.121.175/32\",\r\n \ + \ \"40.81.122.4/32\",\r\n \"40.81.122.62/31\",\r\n \"\ + 40.81.122.76/32\",\r\n \"40.81.122.203/32\",\r\n \"40.81.123.124/32\"\ + ,\r\n \"40.81.123.157/32\",\r\n \"40.81.124.185/32\",\r\n\ + \ \"40.81.124.219/32\",\r\n \"40.81.127.25/32\",\r\n \ + \ \"40.81.127.139/32\",\r\n \"40.81.127.140/31\",\r\n \ + \ \"40.81.127.229/32\",\r\n \"40.81.127.230/32\",\r\n \ + \ \"40.81.127.239/32\",\r\n \"51.137.136.13/32\",\r\n \ + \ \"51.137.136.14/32\",\r\n \"51.137.136.34/32\",\r\n \"\ + 51.137.137.69/32\",\r\n \"51.137.137.118/32\",\r\n \"51.137.137.121/32\"\ + ,\r\n \"51.137.137.200/32\",\r\n \"51.137.137.237/32\",\r\ + \n \"51.140.212.128/27\",\r\n \"51.140.230.246/32\",\r\n\ + \ \"51.140.231.138/32\",\r\n \"51.141.2.189/32\",\r\n \ + \ \"51.141.7.11/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftCloudAppSecurity.WestCentralUS\",\r\n \"\ + id\": \"MicrosoftCloudAppSecurity.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.196.192/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestEurope\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.67.96/28\",\r\n \ + \ \"13.69.107.96/28\",\r\n \"13.80.7.94/32\",\r\n \ + \ \"13.80.22.71/32\",\r\n \"13.80.125.22/32\",\r\n \"\ + 13.81.123.49/32\",\r\n \"13.81.204.189/32\",\r\n \"13.81.212.71/32\"\ + ,\r\n \"13.93.32.114/32\",\r\n \"13.93.113.192/32\",\r\n\ + \ \"13.95.1.33/32\",\r\n \"13.95.29.177/32\",\r\n \ + \ \"13.95.30.46/32\",\r\n \"40.67.216.253/32\",\r\n \"\ + 40.67.219.133/32\",\r\n \"40.68.245.184/32\",\r\n \"40.74.1.235/32\"\ + ,\r\n \"40.74.6.204/32\",\r\n \"40.91.198.19/32\",\r\n \ + \ \"40.113.121.176/32\",\r\n \"40.114.217.8/32\",\r\n \ + \ \"40.115.24.65/32\",\r\n \"40.115.25.50/32\",\r\n \ + \ \"40.118.63.137/32\",\r\n \"40.118.97.232/32\",\r\n \ + \ \"40.119.145.130/32\",\r\n \"40.119.147.102/32\",\r\n \ + \ \"40.119.154.72/32\",\r\n \"51.105.124.64/32\",\r\n \"\ + 51.105.124.80/32\",\r\n \"51.105.161.5/32\",\r\n \"51.105.163.8/32\"\ + ,\r\n \"51.105.163.43/32\",\r\n \"51.105.164.8/32\",\r\n\ + \ \"51.105.164.234/32\",\r\n \"51.105.164.241/32\",\r\n\ + \ \"51.105.165.31/32\",\r\n \"51.105.165.37/32\",\r\n \ + \ \"51.105.165.63/32\",\r\n \"51.105.165.116/32\",\r\n \ + \ \"51.105.166.102/31\",\r\n \"51.105.166.106/32\",\r\n \ + \ \"51.105.179.157/32\",\r\n \"51.144.56.60/32\",\r\n \ + \ \"51.145.181.195/32\",\r\n \"51.145.181.214/32\",\r\n \ + \ \"52.137.56.200/32\",\r\n \"52.142.220.179/32\",\r\n \ + \ \"52.142.232.120/32\",\r\n \"52.157.218.219/32\",\r\n \ + \ \"52.157.218.232/32\",\r\n \"52.157.232.110/32\",\r\n \ + \ \"52.157.232.147/32\",\r\n \"52.157.233.49/32\",\r\n \ + \ \"52.157.233.92/32\",\r\n \"52.157.233.133/32\",\r\n \ + \ \"52.157.233.205/32\",\r\n \"52.157.234.160/32\",\r\n \ + \ \"52.157.234.222/32\",\r\n \"52.157.235.27/32\",\r\n \ + \ \"52.157.235.144/32\",\r\n \"52.157.236.195/32\",\r\n \ + \ \"52.157.237.107/32\",\r\n \"52.157.237.213/32\",\r\n \ + \ \"52.157.237.255/32\",\r\n \"52.157.238.58/32\",\r\n \"\ + 52.157.239.110/32\",\r\n \"52.157.239.132/32\",\r\n \"52.174.56.180/32\"\ + ,\r\n \"52.178.44.248/32\",\r\n \"52.178.89.44/32\",\r\n\ + \ \"52.236.187.80/28\",\r\n \"65.52.138.123/32\",\r\n \ + \ \"104.40.129.120/32\",\r\n \"104.45.7.95/32\",\r\n \ + \ \"104.45.65.169/32\",\r\n \"104.214.225.33/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestUS\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.WestUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.64.26.88/32\",\r\n \ + \ \"13.64.28.87/32\",\r\n \"13.64.29.32/32\",\r\n \ + \ \"13.64.29.161/32\",\r\n \"13.64.30.76/32\",\r\n \"\ + 13.64.30.117/32\",\r\n \"13.64.30.118/32\",\r\n \"13.64.31.116/32\"\ + ,\r\n \"13.64.196.27/32\",\r\n \"13.64.198.19/32\",\r\n\ + \ \"13.64.198.97/32\",\r\n \"13.64.199.41/32\",\r\n \ + \ \"13.64.252.115/32\",\r\n \"13.86.176.189/32\",\r\n \ + \ \"13.86.176.211/32\",\r\n \"13.86.219.224/27\",\r\n \ + \ \"13.86.235.202/32\",\r\n \"13.86.239.236/32\",\r\n \"\ + 13.91.61.249/32\",\r\n \"13.91.91.243/32\",\r\n \"13.91.98.185/32\"\ + ,\r\n \"13.93.196.52/32\",\r\n \"13.93.216.68/32\",\r\n\ + \ \"13.93.233.42/32\",\r\n \"40.78.23.204/32\",\r\n \ + \ \"40.78.56.129/32\",\r\n \"40.118.211.172/32\",\r\n \ + \ \"52.157.19.228/32\",\r\n \"52.157.20.142/32\",\r\n \ + \ \"104.40.28.202/32\",\r\n \"104.42.15.41/32\",\r\n \"\ + 104.42.34.58/32\",\r\n \"104.42.38.254/32\",\r\n \"104.42.54.24/32\"\ + ,\r\n \"104.42.75.120/32\",\r\n \"104.42.211.215/32\",\r\ + \n \"104.209.35.177/32\",\r\n \"138.91.147.71/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftCloudAppSecurity.WestUS2\"\ + ,\r\n \"id\": \"MicrosoftCloudAppSecurity.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftCloudAppSecurity\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.134.18/32\",\r\n\ + \ \"13.66.142.80/28\",\r\n \"13.66.158.8/32\",\r\n \ + \ \"13.66.168.209/32\",\r\n \"13.66.173.192/32\",\r\n \ + \ \"13.66.210.205/32\",\r\n \"13.77.136.80/32\",\r\n \"\ + 13.77.148.229/32\",\r\n \"13.77.160.162/32\",\r\n \"13.77.163.148/32\"\ + ,\r\n \"13.77.165.61/32\",\r\n \"40.78.245.0/28\",\r\n \ + \ \"40.78.251.128/28\",\r\n \"40.90.218.196/31\",\r\n \ + \ \"40.90.218.198/32\",\r\n \"40.90.218.203/32\",\r\n \ + \ \"40.90.219.121/32\",\r\n \"40.90.219.184/32\",\r\n \ + \ \"40.90.220.37/32\",\r\n \"40.90.220.190/32\",\r\n \"\ + 40.90.220.196/32\",\r\n \"40.90.222.64/32\",\r\n \"40.91.74.37/32\"\ + ,\r\n \"40.91.78.105/32\",\r\n \"40.91.114.40/29\",\r\n\ + \ \"40.91.114.48/31\",\r\n \"40.91.122.25/32\",\r\n \ + \ \"40.91.122.38/32\",\r\n \"40.91.126.157/32\",\r\n \ + \ \"40.91.127.44/32\",\r\n \"51.143.58.207/32\",\r\n \"\ + 51.143.111.58/32\",\r\n \"51.143.120.236/32\",\r\n \"51.143.120.242/32\"\ + ,\r\n \"51.143.122.59/32\",\r\n \"51.143.122.60/32\",\r\n\ + \ \"52.137.89.147/32\",\r\n \"52.143.73.88/32\",\r\n \ + \ \"52.143.74.31/32\",\r\n \"52.148.161.45/32\",\r\n \ + \ \"52.148.161.53/32\",\r\n \"52.183.24.254/32\",\r\n \ + \ \"52.183.30.204/32\",\r\n \"52.183.75.62/32\",\r\n \"\ + 52.191.129.65/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"MicrosoftContainerRegistry\",\r\n \"id\": \"MicrosoftContainerRegistry\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"MicrosoftContainerRegistry\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.66.140.64/29\",\r\n \ + \ \"13.67.8.112/29\",\r\n \"13.69.64.80/29\",\r\n \"\ + 13.69.106.72/29\",\r\n \"13.69.227.80/29\",\r\n \"13.70.72.128/29\"\ + ,\r\n \"13.71.170.48/29\",\r\n \"13.71.194.120/29\",\r\n\ + \ \"13.74.107.72/29\",\r\n \"13.75.34.152/29\",\r\n \ + \ \"13.77.50.72/29\",\r\n \"13.78.106.192/29\",\r\n \ + \ \"13.87.56.88/29\",\r\n \"13.87.122.88/29\",\r\n \"13.89.170.208/29\"\ + ,\r\n \"20.37.74.64/29\",\r\n \"20.38.146.136/29\",\r\n\ + \ \"20.44.2.16/29\",\r\n \"20.44.26.136/29\",\r\n \ + \ \"20.45.122.136/29\",\r\n \"20.49.82.8/29\",\r\n \"\ + 20.49.90.8/29\",\r\n \"20.150.170.16/29\",\r\n \"20.150.178.136/29\"\ + ,\r\n \"20.150.186.136/29\",\r\n \"20.192.98.136/29\",\r\ + \n \"20.192.234.16/29\",\r\n \"20.193.202.8/29\",\r\n \ + \ \"20.194.66.8/29\",\r\n \"23.98.82.104/29\",\r\n \ + \ \"40.67.58.16/29\",\r\n \"40.69.106.72/29\",\r\n \"\ + 40.70.146.80/29\",\r\n \"40.71.10.208/29\",\r\n \"40.74.100.56/29\"\ + ,\r\n \"40.74.146.40/29\",\r\n \"40.75.34.24/29\",\r\n \ + \ \"40.78.194.72/29\",\r\n \"40.78.202.64/29\",\r\n \ + \ \"40.78.226.200/29\",\r\n \"40.78.234.40/29\",\r\n \ + \ \"40.78.242.152/29\",\r\n \"40.78.250.88/29\",\r\n \"\ + 40.79.130.48/29\",\r\n \"40.79.138.24/29\",\r\n \"40.79.146.24/29\"\ + ,\r\n \"40.79.154.96/29\",\r\n \"40.79.162.24/29\",\r\n\ + \ \"40.79.170.8/29\",\r\n \"40.79.178.72/29\",\r\n \ + \ \"40.79.186.0/29\",\r\n \"40.79.194.88/29\",\r\n \"\ + 40.80.50.136/29\",\r\n \"40.112.242.152/29\",\r\n \"40.120.74.8/29\"\ + ,\r\n \"51.12.98.16/29\",\r\n \"51.12.202.16/29\",\r\n \ + \ \"51.12.226.136/29\",\r\n \"51.12.234.136/29\",\r\n \ + \ \"51.105.66.136/29\",\r\n \"51.105.74.136/29\",\r\n \ + \ \"51.107.58.16/29\",\r\n \"51.107.154.16/29\",\r\n \ + \ \"51.116.58.16/29\",\r\n \"51.116.154.80/29\",\r\n \"\ + 51.116.242.136/29\",\r\n \"51.116.250.136/29\",\r\n \"51.120.98.24/29\"\ + ,\r\n \"51.120.106.136/29\",\r\n \"51.120.210.136/29\",\r\ + \n \"51.120.218.16/29\",\r\n \"51.140.146.192/29\",\r\n\ + \ \"51.140.210.88/29\",\r\n \"52.138.90.24/29\",\r\n \ + \ \"52.138.226.72/29\",\r\n \"52.162.106.152/29\",\r\n \ + \ \"52.167.106.72/29\",\r\n \"52.182.138.200/29\",\r\n \ + \ \"52.231.18.48/29\",\r\n \"52.231.146.88/29\",\r\n \ + \ \"52.236.186.72/29\",\r\n \"52.246.154.136/29\",\r\n \ + \ \"65.52.250.8/29\",\r\n \"102.133.26.16/29\",\r\n \"102.133.122.136/29\"\ + ,\r\n \"102.133.154.16/29\",\r\n \"102.133.250.136/29\"\ + ,\r\n \"104.208.16.72/29\",\r\n \"104.208.144.72/29\",\r\ + \n \"104.211.81.128/29\",\r\n \"104.211.146.72/29\",\r\n\ + \ \"104.214.18.176/29\",\r\n \"191.233.50.8/29\",\r\n \ + \ \"191.233.203.128/29\",\r\n \"191.234.146.136/29\",\r\n\ + \ \"191.234.154.136/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.AustraliaEast\",\r\n\ + \ \"id\": \"MicrosoftContainerRegistry.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.70.72.128/29\",\r\n \"40.79.162.24/29\",\r\n \ + \ \"40.79.170.8/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.AustraliaSoutheast\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.77.50.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.BrazilSouth\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.BrazilSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"191.233.203.128/29\",\r\n \"191.234.146.136/29\",\r\n\ + \ \"191.234.154.136/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.CanadaCentral\",\r\n\ + \ \"id\": \"MicrosoftContainerRegistry.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.170.48/29\",\r\n \"20.38.146.136/29\",\r\n \ + \ \"52.246.154.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.CanadaEast\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.CanadaEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.106.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.CentralIndia\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.192.98.136/29\",\r\n \"40.80.50.136/29\",\r\n \ + \ \"104.211.81.128/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.CentralUS\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.CentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.89.170.208/29\",\r\n \"52.182.138.200/29\",\r\n \ + \ \"104.208.16.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.CentralUSEUAP\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.78.202.64/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.EastAsia\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.EastAsia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.75.34.152/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.EastUS\",\r\n \"id\": \"\ + MicrosoftContainerRegistry.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.71.10.208/29\",\r\n\ + \ \"40.78.226.200/29\",\r\n \"40.79.154.96/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.EastUS2\"\ + ,\r\n \"id\": \"MicrosoftContainerRegistry.EastUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.70.146.80/29\",\r\n \"52.167.106.72/29\",\r\n \ + \ \"104.208.144.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.EastUS2EUAP\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.EastUS2EUAP\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.146.40/29\",\r\n \"40.75.34.24/29\",\r\n \ + \ \"52.138.90.24/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.FranceCentral\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.79.130.48/29\",\r\n \"40.79.138.24/29\",\r\n \ + \ \"40.79.146.24/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.FranceSouth\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.FranceSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.79.178.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.GermanyNorth\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.GermanyNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.116.58.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.GermanyWestCentral\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.GermanyWestCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.154.80/29\",\r\n \"51.116.242.136/29\"\ + ,\r\n \"51.116.250.136/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.JapanEast\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.78.106.192/29\",\r\n \"40.79.186.0/29\",\r\n \ + \ \"40.79.194.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.JapanWest\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.JapanWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.74.100.56/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.KoreaCentral\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.44.26.136/29\",\r\n \"20.194.66.8/29\",\r\n \ + \ \"52.231.18.48/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.KoreaSouth\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.KoreaSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.231.146.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.NorthCentralUS\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.162.106.152/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.NorthEurope\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.227.80/29\",\r\n \"13.74.107.72/29\",\r\n \ + \ \"52.138.226.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.NorwayEast\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.NorwayEast\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.98.24/29\",\r\n \"51.120.106.136/29\",\r\n \ + \ \"51.120.210.136/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.NorwayWest\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.NorwayWest\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.218.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.SouthAfricaNorth\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"102.133.122.136/29\",\r\n \"102.133.154.16/29\",\r\n \ + \ \"102.133.250.136/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.SouthAfricaWest\",\r\n\ + \ \"id\": \"MicrosoftContainerRegistry.SouthAfricaWest\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southafricawest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.26.16/29\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.SouthCentralUS\",\r\ + \n \"id\": \"MicrosoftContainerRegistry.SouthCentralUS\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.45.122.136/29\",\r\n \"20.49.90.8/29\",\r\n\ + \ \"104.214.18.176/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"MicrosoftContainerRegistry.SoutheastAsia\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.8.112/29\",\r\n \"23.98.82.104/29\",\r\n \ + \ \"40.78.234.40/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.SouthIndia\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.SouthIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.78.194.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.SwitzerlandNorth\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.58.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.SwitzerlandWest\",\r\n \ + \ \"id\": \"MicrosoftContainerRegistry.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.154.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.UAECentral\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.37.74.64/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.UAENorth\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.120.74.8/29\",\r\n \"65.52.250.8/29\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKNorth\"\ + ,\r\n \"id\": \"MicrosoftContainerRegistry.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.88/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKSouth\"\ + ,\r\n \"id\": \"MicrosoftContainerRegistry.UKSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.105.66.136/29\",\r\n \"51.105.74.136/29\",\r\n \ + \ \"51.140.146.192/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.UKSouth2\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.UKSouth2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"MicrosoftContainerRegistry\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.56.88/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"MicrosoftContainerRegistry.UKWest\"\ + ,\r\n \"id\": \"MicrosoftContainerRegistry.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.140.210.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.WestCentralUS\",\r\n \"\ + id\": \"MicrosoftContainerRegistry.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.194.120/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.WestEurope\",\r\n \"id\"\ + : \"MicrosoftContainerRegistry.WestEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.64.80/29\",\r\n \"13.69.106.72/29\",\r\n \ + \ \"52.236.186.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"MicrosoftContainerRegistry.WestIndia\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.WestIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"104.211.146.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"MicrosoftContainerRegistry.WestUS\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.112.242.152/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"MicrosoftContainerRegistry.WestUS2\",\r\n \"id\":\ + \ \"MicrosoftContainerRegistry.WestUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"MicrosoftContainerRegistry\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.140.64/29\",\r\n \"40.78.242.152/29\",\r\n \ + \ \"40.78.250.88/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"PowerQueryOnline\",\r\n \"id\": \"PowerQueryOnline\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"FW\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"\ + addressPrefixes\": [\r\n \"20.36.120.120/31\",\r\n \"20.37.64.120/31\"\ + ,\r\n \"20.37.152.70/31\",\r\n \"20.37.192.70/31\",\r\n\ + \ \"20.37.224.120/31\",\r\n \"20.38.80.70/31\",\r\n \ + \ \"20.38.136.68/31\",\r\n \"20.39.11.24/31\",\r\n \ + \ \"20.41.0.68/30\",\r\n \"20.41.64.70/31\",\r\n \"20.41.65.144/31\"\ + ,\r\n \"20.41.192.120/31\",\r\n \"20.42.4.200/30\",\r\n\ + \ \"20.42.128.70/31\",\r\n \"20.42.129.184/29\",\r\n \ + \ \"20.42.224.120/31\",\r\n \"20.43.40.70/31\",\r\n \ + \ \"20.43.64.70/31\",\r\n \"20.43.128.70/31\",\r\n \"\ + 20.45.112.120/31\",\r\n \"20.45.192.120/31\",\r\n \"20.150.160.108/31\"\ + ,\r\n \"20.189.104.68/31\",\r\n \"20.192.160.20/31\",\r\n\ + \ \"20.192.225.32/31\",\r\n \"40.67.48.120/31\",\r\n \ + \ \"40.74.30.104/30\",\r\n \"40.80.56.120/31\",\r\n \ + \ \"40.80.168.120/31\",\r\n \"40.80.184.68/31\",\r\n \"\ + 40.82.253.72/29\",\r\n \"40.89.16.120/31\",\r\n \"40.119.8.74/31\"\ + ,\r\n \"51.104.24.70/31\",\r\n \"51.105.80.120/31\",\r\n\ + \ \"51.105.88.120/31\",\r\n \"51.107.48.70/31\",\r\n \ + \ \"51.107.144.120/31\",\r\n \"51.116.48.70/31\",\r\n \ + \ \"51.116.144.70/31\",\r\n \"51.120.40.70/31\",\r\n \ + \ \"51.120.224.120/31\",\r\n \"51.137.160.68/31\",\r\n \ + \ \"51.143.192.120/31\",\r\n \"52.140.104.70/31\",\r\n \"\ + 52.150.139.72/30\",\r\n \"52.228.80.70/31\",\r\n \"102.133.56.96/31\"\ + ,\r\n \"102.133.216.70/31\",\r\n \"191.233.8.20/31\",\r\n\ + \ \"191.235.224.70/31\",\r\n \"2603:1000:104:1::200/123\"\ + ,\r\n \"2603:1010:6:1::200/123\",\r\n \"2603:1020:5:1::200/123\"\ + ,\r\n \"2603:1020:206:1::200/123\",\r\n \"2603:1020:705:1::200/123\"\ + ,\r\n \"2603:1020:805:1::200/123\",\r\n \"2603:1020:a04:1::200/123\"\ + ,\r\n \"2603:1020:c04:1::200/123\",\r\n \"2603:1020:e04:1::200/123\"\ + ,\r\n \"2603:1020:1004::200/123\",\r\n \"2603:1030:10:1::200/123\"\ + ,\r\n \"2603:1030:104:1::200/123\",\r\n \"2603:1030:210:1::200/123\"\ + ,\r\n \"2603:1030:40b:1::200/123\",\r\n \"2603:1030:40c:1::200/123\"\ + ,\r\n \"2603:1030:504:1::200/123\",\r\n \"2603:1030:807:1::200/123\"\ + ,\r\n \"2603:1030:c06:1::200/123\",\r\n \"2603:1030:f05:1::200/123\"\ + ,\r\n \"2603:1040:5:1::200/123\",\r\n \"2603:1040:407:1::200/123\"\ + ,\r\n \"2603:1040:904:1::200/123\",\r\n \"2603:1040:a06:1::200/123\"\ + ,\r\n \"2603:1040:d04::200/123\",\r\n \"2603:1040:f05:1::200/123\"\ + ,\r\n \"2603:1050:6:1::200/123\",\r\n \"2603:1050:403::200/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaCentral\"\ + ,\r\n \"id\": \"PowerQueryOnline.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.224.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.AustraliaCentral2\",\r\n \"id\": \"PowerQueryOnline.AustraliaCentral2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.36.120.120/31\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaEast\"\ + ,\r\n \"id\": \"PowerQueryOnline.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.192.70/31\",\r\n \"2603:1010:6:1::200/123\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.AustraliaSoutheast\"\ + ,\r\n \"id\": \"PowerQueryOnline.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.42.224.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.BrazilSouth\",\r\n \"id\": \"PowerQueryOnline.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"\ + addressPrefixes\": [\r\n \"191.235.224.70/31\",\r\n \"2603:1050:6:1::200/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CanadaCentral\"\ + ,\r\n \"id\": \"PowerQueryOnline.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 52.228.80.70/31\",\r\n \"2603:1030:f05:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CanadaEast\"\ + ,\r\n \"id\": \"PowerQueryOnline.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.89.16.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"PowerQueryOnline.CentralIndia\",\r\n \"id\": \"PowerQueryOnline.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.140.104.70/31\",\r\n \"\ + 2603:1040:a06:1::200/123\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"PowerQueryOnline.CentralUS\",\r\n \"id\": \"PowerQueryOnline.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.152.70/31\",\r\n \"2603:1030:10:1::200/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.CentralUSEUAP\"\ + ,\r\n \"id\": \"PowerQueryOnline.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.45.192.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.EastAsia\",\r\n \"id\": \"PowerQueryOnline.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.189.104.68/31\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"PowerQueryOnline.EastUS\",\r\n \"id\": \"\ + PowerQueryOnline.EastUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.42.4.200/30\",\r\n \ + \ \"2603:1030:210:1::200/123\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"PowerQueryOnline.EastUS2\",\r\n \"id\": \"PowerQueryOnline.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\ + \n \"20.41.0.68/30\",\r\n \"2603:1030:40c:1::200/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.EastUS2EUAP\"\ + ,\r\n \"id\": \"PowerQueryOnline.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.39.11.24/31\",\r\n \"2603:1030:40b:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.FranceCentral\"\ + ,\r\n \"id\": \"PowerQueryOnline.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.43.40.70/31\",\r\n \"2603:1020:805:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.FranceSouth\"\ + ,\r\n \"id\": \"PowerQueryOnline.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.105.88.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.GermanyNorth\",\r\n \"id\": \"PowerQueryOnline.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.48.70/31\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"PowerQueryOnline.GermanyWestCentral\",\r\n \ + \ \"id\": \"PowerQueryOnline.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.116.144.70/31\",\r\n \"2603:1020:c04:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.JapanEast\"\ + ,\r\n \"id\": \"PowerQueryOnline.JapanEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.43.64.70/31\",\r\n \"2603:1040:407:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.JapanWest\"\ + ,\r\n \"id\": \"PowerQueryOnline.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.56.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"PowerQueryOnline.KoreaCentral\",\r\n \"id\": \"PowerQueryOnline.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.41.64.70/31\",\r\n \"\ + 20.41.65.144/31\",\r\n \"2603:1040:f05:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.KoreaSouth\"\ + ,\r\n \"id\": \"PowerQueryOnline.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.168.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.NorthCentralUS\",\r\n \"id\": \"PowerQueryOnline.NorthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.80.184.68/31\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.NorthEurope\"\ + ,\r\n \"id\": \"PowerQueryOnline.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.38.80.70/31\",\r\n \"2603:1020:5:1::200/123\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.NorwayEast\"\ + ,\r\n \"id\": \"PowerQueryOnline.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.120.40.70/31\",\r\n \"2603:1020:e04:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.NorwayWest\"\ + ,\r\n \"id\": \"PowerQueryOnline.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.120.224.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.SouthAfricaNorth\",\r\n \"id\": \"PowerQueryOnline.SouthAfricaNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.133.216.70/31\",\r\n \ + \ \"2603:1000:104:1::200/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"PowerQueryOnline.SouthAfricaWest\",\r\n \"id\"\ + : \"PowerQueryOnline.SouthAfricaWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 102.133.56.96/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.SouthCentralUS\",\r\n \"id\": \"PowerQueryOnline.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.119.8.74/31\",\r\n \"\ + 2603:1030:807:1::200/123\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"PowerQueryOnline.SoutheastAsia\",\r\n \"id\": \"PowerQueryOnline.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.43.128.70/31\",\r\n \"\ + 2603:1040:5:1::200/123\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"PowerQueryOnline.SouthIndia\",\r\n \"id\": \"PowerQueryOnline.SouthIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.41.192.120/31\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"PowerQueryOnline.SwitzerlandNorth\",\r\n \ + \ \"id\": \"PowerQueryOnline.SwitzerlandNorth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.48.70/31\",\r\n \"2603:1020:a04:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.SwitzerlandWest\"\ + ,\r\n \"id\": \"PowerQueryOnline.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.144.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.UAECentral\",\r\n \"id\": \"PowerQueryOnline.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.37.64.120/31\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"PowerQueryOnline.UAENorth\",\r\n \"id\":\ + \ \"PowerQueryOnline.UAENorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.38.136.68/31\",\r\n\ + \ \"2603:1040:904:1::200/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"PowerQueryOnline.UKNorth\",\r\n \"id\":\ + \ \"PowerQueryOnline.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n\ + \ \"addressPrefixes\": [\r\n \"51.105.80.120/31\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UKSouth\"\ + ,\r\n \"id\": \"PowerQueryOnline.UKSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.104.24.70/31\",\r\n \"2603:1020:705:1::200/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.UKSouth2\"\ + ,\r\n \"id\": \"PowerQueryOnline.UKSouth2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.143.192.120/31\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.UKWest\",\r\n \"id\": \"PowerQueryOnline.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\ + \n \"51.137.160.68/31\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"PowerQueryOnline.WestCentralUS\",\r\n \"id\"\ + : \"PowerQueryOnline.WestCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 52.150.139.72/30\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"PowerQueryOnline.WestEurope\",\r\n \"id\": \"PowerQueryOnline.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.30.104/30\",\r\n \"2603:1020:206:1::200/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"PowerQueryOnline.WestUS\"\ + ,\r\n \"id\": \"PowerQueryOnline.WestUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.82.253.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"name\"\ + : \"PowerQueryOnline.WestUS2\",\r\n \"id\": \"PowerQueryOnline.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"PowerQueryOnline\",\r\n \"addressPrefixes\": [\r\ + \n \"20.42.128.70/31\",\r\n \"20.42.129.184/29\",\r\n \ + \ \"2603:1030:c06:1::200/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus\",\r\n \"id\": \"ServiceBus\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\",\r\n \"VSE\",\r\n\ + \ \"FW\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.138.80/29\",\r\n\ + \ \"13.67.8.96/29\",\r\n \"13.68.110.36/32\",\r\n \ + \ \"13.69.64.64/29\",\r\n \"13.69.106.64/29\",\r\n \"\ + 13.69.227.64/29\",\r\n \"13.70.72.16/29\",\r\n \"13.70.186.33/32\"\ + ,\r\n \"13.71.114.157/32\",\r\n \"13.71.170.32/29\",\r\n\ + \ \"13.71.194.96/28\",\r\n \"13.74.107.64/29\",\r\n \ + \ \"13.74.142.88/32\",\r\n \"13.75.34.128/28\",\r\n \ + \ \"13.76.141.36/32\",\r\n \"13.77.50.16/28\",\r\n \"13.78.94.187/32\"\ + ,\r\n \"13.78.106.80/29\",\r\n \"13.85.81.218/32\",\r\n\ + \ \"13.87.35.8/32\",\r\n \"13.87.56.64/28\",\r\n \ + \ \"13.87.122.64/28\",\r\n \"13.88.10.93/32\",\r\n \"\ + 13.89.170.192/29\",\r\n \"20.36.106.224/27\",\r\n \"20.36.114.128/27\"\ + ,\r\n \"20.37.74.32/27\",\r\n \"20.38.146.128/29\",\r\n\ + \ \"20.44.2.8/29\",\r\n \"20.44.26.128/29\",\r\n \ + \ \"20.45.122.128/29\",\r\n \"20.150.160.216/29\",\r\n \ + \ \"20.150.170.8/29\",\r\n \"20.150.178.128/29\",\r\n \"\ + 20.150.186.128/29\",\r\n \"20.192.98.128/29\",\r\n \"20.192.160.40/29\"\ + ,\r\n \"20.192.225.56/29\",\r\n \"20.192.234.8/29\",\r\n\ + \ \"23.98.82.96/29\",\r\n \"40.65.108.146/32\",\r\n \ + \ \"40.67.58.8/29\",\r\n \"40.68.127.68/32\",\r\n \"\ + 40.69.106.16/28\",\r\n \"40.70.146.64/29\",\r\n \"40.71.10.192/29\"\ + ,\r\n \"40.74.100.32/28\",\r\n \"40.74.122.78/32\",\r\n\ + \ \"40.74.146.32/29\",\r\n \"40.75.34.16/29\",\r\n \ + \ \"40.78.194.16/28\",\r\n \"40.78.202.16/28\",\r\n \ + \ \"40.78.226.192/29\",\r\n \"40.78.234.32/29\",\r\n \"\ + 40.78.242.144/29\",\r\n \"40.78.250.80/29\",\r\n \"40.79.130.32/29\"\ + ,\r\n \"40.79.138.16/29\",\r\n \"40.79.146.16/29\",\r\n\ + \ \"40.79.154.88/29\",\r\n \"40.79.162.16/29\",\r\n \ + \ \"40.79.170.16/29\",\r\n \"40.79.178.16/28\",\r\n \ + \ \"40.79.186.64/27\",\r\n \"40.79.194.80/29\",\r\n \"\ + 40.80.50.128/29\",\r\n \"40.86.91.130/32\",\r\n \"40.112.242.128/28\"\ + ,\r\n \"40.114.86.33/32\",\r\n \"40.120.74.24/29\",\r\n\ + \ \"51.12.98.8/29\",\r\n \"51.12.202.8/29\",\r\n \ + \ \"51.12.226.128/29\",\r\n \"51.12.234.128/29\",\r\n \ + \ \"51.105.66.128/29\",\r\n \"51.105.74.128/29\",\r\n \"\ + 51.107.58.8/29\",\r\n \"51.107.154.8/29\",\r\n \"51.116.58.8/29\"\ + ,\r\n \"51.116.154.72/29\",\r\n \"51.116.242.128/29\",\r\ + \n \"51.116.250.128/29\",\r\n \"51.120.98.16/29\",\r\n \ + \ \"51.120.106.128/29\",\r\n \"51.120.210.128/29\",\r\n \ + \ \"51.120.218.8/29\",\r\n \"51.140.43.12/32\",\r\n \ + \ \"51.140.146.48/29\",\r\n \"51.140.210.64/28\",\r\n \ + \ \"51.141.1.129/32\",\r\n \"51.142.210.16/32\",\r\n \"\ + 52.138.71.95/32\",\r\n \"52.138.90.16/29\",\r\n \"52.138.226.64/29\"\ + ,\r\n \"52.161.17.198/32\",\r\n \"52.162.106.128/28\",\r\ + \n \"52.167.106.64/29\",\r\n \"52.168.29.86/32\",\r\n \ + \ \"52.172.220.188/32\",\r\n \"52.180.178.204/32\",\r\n \ + \ \"52.182.138.192/29\",\r\n \"52.187.192.243/32\",\r\n \ + \ \"52.231.18.32/29\",\r\n \"52.231.146.64/28\",\r\n \ + \ \"52.232.119.191/32\",\r\n \"52.233.33.226/32\",\r\n \ + \ \"52.236.186.64/29\",\r\n \"52.242.36.0/32\",\r\n \"\ + 52.246.154.128/29\",\r\n \"65.52.219.186/32\",\r\n \"65.52.250.64/27\"\ + ,\r\n \"102.133.26.8/29\",\r\n \"102.133.122.128/29\",\r\ + \n \"102.133.154.8/29\",\r\n \"102.133.250.128/29\",\r\n\ + \ \"104.40.15.128/32\",\r\n \"104.45.239.115/32\",\r\n \ + \ \"104.208.16.64/29\",\r\n \"104.208.144.64/29\",\r\n \ + \ \"104.211.81.16/29\",\r\n \"104.211.146.16/28\",\r\n \ + \ \"104.211.190.88/32\",\r\n \"104.214.18.160/29\",\r\n \ + \ \"191.232.184.253/32\",\r\n \"191.233.8.40/29\",\r\n \ + \ \"191.233.203.16/29\",\r\n \"191.234.146.128/29\",\r\n \ + \ \"191.234.154.128/29\",\r\n \"191.235.170.182/32\",\r\n \ + \ \"207.46.138.15/32\",\r\n \"2603:1000:104:1::220/123\"\ + ,\r\n \"2603:1010:6:1::220/123\",\r\n \"2603:1020:5:1::220/123\"\ + ,\r\n \"2603:1020:206:1::220/123\",\r\n \"2603:1020:705:1::220/123\"\ + ,\r\n \"2603:1020:805:1::220/123\",\r\n \"2603:1020:a04:1::220/123\"\ + ,\r\n \"2603:1020:c04:1::220/123\",\r\n \"2603:1020:e04:1::220/123\"\ + ,\r\n \"2603:1020:1004::220/123\",\r\n \"2603:1030:10:1::220/123\"\ + ,\r\n \"2603:1030:104:1::220/123\",\r\n \"2603:1030:210:1::220/123\"\ + ,\r\n \"2603:1030:40b:1::220/123\",\r\n \"2603:1030:40c:1::220/123\"\ + ,\r\n \"2603:1030:504:1::220/123\",\r\n \"2603:1030:807:1::220/123\"\ + ,\r\n \"2603:1030:c06:1::220/123\",\r\n \"2603:1030:f05:1::220/123\"\ + ,\r\n \"2603:1040:5:1::220/123\",\r\n \"2603:1040:407:1::220/123\"\ + ,\r\n \"2603:1040:904:1::220/123\",\r\n \"2603:1040:a06:1::220/123\"\ + ,\r\n \"2603:1040:d04::220/123\",\r\n \"2603:1040:f05:1::220/123\"\ + ,\r\n \"2603:1050:6:1::220/123\",\r\n \"2603:1050:403::220/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaCentral\"\ + ,\r\n \"id\": \"ServiceBus.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"20.36.106.224/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaCentral2\"\ + ,\r\n \"id\": \"ServiceBus.AustraliaCentral2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"20.36.114.128/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaEast\"\ + ,\r\n \"id\": \"ServiceBus.AustraliaEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.70.72.16/29\"\ + ,\r\n \"40.79.162.16/29\",\r\n \"40.79.170.16/29\",\r\n\ + \ \"52.187.192.243/32\",\r\n \"2603:1010:6:1::220/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.AustraliaSoutheast\"\ + ,\r\n \"id\": \"ServiceBus.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.70.186.33/32\"\ + ,\r\n \"13.77.50.16/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.BrazilSouth\",\r\n \"id\": \"ServiceBus.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"\ + addressPrefixes\": [\r\n \"191.232.184.253/32\",\r\n \"\ + 191.233.203.16/29\",\r\n \"191.234.146.128/29\",\r\n \"\ + 191.234.154.128/29\",\r\n \"2603:1050:6:1::220/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.CanadaCentral\"\ + ,\r\n \"id\": \"ServiceBus.CanadaCentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.71.170.32/29\"\ + ,\r\n \"20.38.146.128/29\",\r\n \"52.233.33.226/32\",\r\n\ + \ \"52.246.154.128/29\",\r\n \"2603:1030:f05:1::220/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.CanadaEast\"\ + ,\r\n \"id\": \"ServiceBus.CanadaEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.69.106.16/28\"\ + ,\r\n \"52.242.36.0/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.CentralIndia\",\r\n \"id\": \"ServiceBus.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"\ + addressPrefixes\": [\r\n \"20.192.98.128/29\",\r\n \"40.80.50.128/29\"\ + ,\r\n \"52.172.220.188/32\",\r\n \"104.211.81.16/29\",\r\ + \n \"2603:1040:a06:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.CentralUS\",\r\n \"id\": \"ServiceBus.CentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralus\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.89.170.192/29\",\r\n \"40.86.91.130/32\",\r\ + \n \"52.182.138.192/29\",\r\n \"104.208.16.64/29\",\r\n\ + \ \"2603:1030:10:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.CentralUSEUAP\",\r\n \"id\":\ + \ \"ServiceBus.CentralUSEUAP\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centraluseuap\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.202.16/28\",\r\n\ + \ \"52.180.178.204/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.EastAsia\",\r\n \"id\": \"ServiceBus.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.75.34.128/28\",\r\n \"207.46.138.15/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.EastUS\"\ + ,\r\n \"id\": \"ServiceBus.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.71.10.192/29\"\ + ,\r\n \"40.78.226.192/29\",\r\n \"40.79.154.88/29\",\r\n\ + \ \"40.114.86.33/32\",\r\n \"52.168.29.86/32\",\r\n \ + \ \"2603:1030:210:1::220/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.EastUS2\",\r\n \"id\": \"ServiceBus.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.68.110.36/32\",\r\n \"40.70.146.64/29\",\r\n \ + \ \"52.167.106.64/29\",\r\n \"104.208.144.64/29\",\r\n \ + \ \"2603:1030:40c:1::220/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.EastUS2EUAP\",\r\n \"id\": \"ServiceBus.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"\ + addressPrefixes\": [\r\n \"40.74.146.32/29\",\r\n \"40.75.34.16/29\"\ + ,\r\n \"52.138.71.95/32\",\r\n \"52.138.90.16/29\",\r\n\ + \ \"2603:1030:40b:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.FranceCentral\",\r\n \"id\":\ + \ \"ServiceBus.FranceCentral\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"centralfrance\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.130.32/29\",\r\n\ + \ \"40.79.138.16/29\",\r\n \"40.79.146.16/29\",\r\n \ + \ \"2603:1020:805:1::220/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.FranceSouth\",\r\n \"id\": \"\ + ServiceBus.FranceSouth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southfrance\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.178.16/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.GermanyNorth\"\ + ,\r\n \"id\": \"ServiceBus.GermanyNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"germanyn\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.116.58.8/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.GermanyWestCentral\"\ + ,\r\n \"id\": \"ServiceBus.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"51.116.154.72/29\"\ + ,\r\n \"51.116.242.128/29\",\r\n \"51.116.250.128/29\",\r\ + \n \"2603:1020:c04:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.JapanEast\",\r\n \"id\": \"ServiceBus.JapanEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.78.94.187/32\",\r\n \"13.78.106.80/29\",\r\n\ + \ \"40.79.186.64/27\",\r\n \"40.79.194.80/29\",\r\n \ + \ \"2603:1040:407:1::220/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.JapanWest\",\r\n \"id\": \"ServiceBus.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.100.32/28\",\r\n \"40.74.122.78/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.KoreaCentral\"\ + ,\r\n \"id\": \"ServiceBus.KoreaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"20.44.26.128/29\"\ + ,\r\n \"52.231.18.32/29\",\r\n \"2603:1040:f05:1::220/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.KoreaSouth\"\ + ,\r\n \"id\": \"ServiceBus.KoreaSouth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"52.231.146.64/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.NorthCentralUS\"\ + ,\r\n \"id\": \"ServiceBus.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"52.162.106.128/28\"\ + ,\r\n \"65.52.219.186/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.NorthEurope\",\r\n \"id\": \"\ + ServiceBus.NorthEurope\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"northeurope\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.227.64/29\",\r\n\ + \ \"13.74.107.64/29\",\r\n \"13.74.142.88/32\",\r\n \ + \ \"52.138.226.64/29\",\r\n \"191.235.170.182/32\",\r\n \ + \ \"2603:1020:5:1::220/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.NorwayEast\",\r\n \"id\": \"ServiceBus.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.120.98.16/29\",\r\n \"51.120.106.128/29\",\r\n \ + \ \"51.120.210.128/29\",\r\n \"2603:1020:e04:1::220/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.NorwayWest\"\ + ,\r\n \"id\": \"ServiceBus.NorwayWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.218.8/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthAfricaNorth\"\ + ,\r\n \"id\": \"ServiceBus.SouthAfricaNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"102.133.122.128/29\"\ + ,\r\n \"102.133.154.8/29\",\r\n \"102.133.250.128/29\",\r\ + \n \"2603:1000:104:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.SouthAfricaWest\",\r\n \"id\"\ + : \"ServiceBus.SouthAfricaWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricawest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"102.133.26.8/29\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthCentralUS\"\ + ,\r\n \"id\": \"ServiceBus.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.85.81.218/32\"\ + ,\r\n \"20.45.122.128/29\",\r\n \"104.214.18.160/29\",\r\ + \n \"2603:1030:807:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.SoutheastAsia\",\r\n \"id\":\ + \ \"ServiceBus.SoutheastAsia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southeastasia\",\r\n \"state\": \"\ + GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.67.8.96/29\",\r\n \ + \ \"13.76.141.36/32\",\r\n \"23.98.82.96/29\",\r\n \ + \ \"40.78.234.32/29\",\r\n \"2603:1040:5:1::220/123\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.SouthIndia\"\ + ,\r\n \"id\": \"ServiceBus.SouthIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.71.114.157/32\"\ + ,\r\n \"40.78.194.16/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.SwitzerlandNorth\",\r\n \"id\"\ + : \"ServiceBus.SwitzerlandNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.58.8/29\",\r\n \ + \ \"2603:1020:a04:1::220/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"ServiceBus.SwitzerlandWest\",\r\n \"id\"\ + : \"ServiceBus.SwitzerlandWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.154.8/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UAECentral\"\ + ,\r\n \"id\": \"ServiceBus.UAECentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"20.37.74.32/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UAENorth\"\ + ,\r\n \"id\": \"ServiceBus.UAENorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.24/29\"\ + ,\r\n \"65.52.250.64/27\",\r\n \"2603:1040:904:1::220/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.UKNorth\"\ + ,\r\n \"id\": \"ServiceBus.UKNorth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureServiceBus\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.122.64/28\",\r\n\ + \ \"51.142.210.16/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceBus.UKSouth\",\r\n \"id\": \"ServiceBus.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.105.66.128/29\",\r\n \"51.105.74.128/29\",\r\n \ + \ \"51.140.43.12/32\",\r\n \"51.140.146.48/29\",\r\n \ + \ \"2603:1020:705:1::220/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.UKSouth2\",\r\n \"id\": \"ServiceBus.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.87.35.8/32\"\ + ,\r\n \"13.87.56.64/28\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceBus.UKWest\",\r\n \"id\": \"ServiceBus.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.140.210.64/28\",\r\n \"51.141.1.129/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestCentralUS\"\ + ,\r\n \"id\": \"ServiceBus.WestCentralUS\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.71.194.96/28\"\ + ,\r\n \"52.161.17.198/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.WestEurope\",\r\n \"id\": \"ServiceBus.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.64.64/29\",\r\n \"13.69.106.64/29\",\r\n\ + \ \"40.68.127.68/32\",\r\n \"52.232.119.191/32\",\r\n \ + \ \"52.236.186.64/29\",\r\n \"2603:1020:206:1::220/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestIndia\"\ + ,\r\n \"id\": \"ServiceBus.WestIndia\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"104.211.146.16/28\"\ + ,\r\n \"104.211.190.88/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceBus.WestUS\",\r\n \"id\": \"ServiceBus.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.88.10.93/32\",\r\n \"40.112.242.128/28\",\r\n \ + \ \"104.40.15.128/32\",\r\n \"104.45.239.115/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceBus.WestUS2\"\ + ,\r\n \"id\": \"ServiceBus.WestUS2\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureServiceBus\",\r\n \"addressPrefixes\": [\r\n \"13.66.138.80/29\"\ + ,\r\n \"40.65.108.146/32\",\r\n \"40.78.242.144/29\",\r\n\ + \ \"40.78.250.80/29\",\r\n \"2603:1030:c06:1::220/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric\"\ + ,\r\n \"id\": \"ServiceFabric\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.66.140.152/29\"\ + ,\r\n \"13.66.167.194/32\",\r\n \"13.66.226.151/32\",\r\n\ + \ \"13.67.9.136/29\",\r\n \"13.69.64.232/29\",\r\n \ + \ \"13.69.109.136/30\",\r\n \"13.69.227.232/29\",\r\n \ + \ \"13.70.72.216/29\",\r\n \"13.70.78.172/30\",\r\n \"\ + 13.71.170.224/29\",\r\n \"13.71.170.248/29\",\r\n \"13.71.195.48/29\"\ + ,\r\n \"13.74.80.74/32\",\r\n \"13.74.111.144/30\",\r\n\ + \ \"13.75.36.80/29\",\r\n \"13.75.41.166/32\",\r\n \ + \ \"13.75.42.35/32\",\r\n \"13.77.52.0/29\",\r\n \"\ + 13.78.108.24/29\",\r\n \"13.78.147.125/32\",\r\n \"13.80.117.236/32\"\ + ,\r\n \"13.87.32.204/32\",\r\n \"13.87.56.240/29\",\r\n\ + \ \"13.87.98.166/32\",\r\n \"13.87.122.240/29\",\r\n \ + \ \"13.89.171.104/29\",\r\n \"13.91.7.211/32\",\r\n \ + \ \"13.91.252.58/32\",\r\n \"13.92.124.124/32\",\r\n \"\ + 20.36.40.70/32\",\r\n \"20.36.72.79/32\",\r\n \"20.36.107.16/29\"\ + ,\r\n \"20.36.114.192/29\",\r\n \"20.37.74.80/29\",\r\n\ + \ \"20.38.149.192/30\",\r\n \"20.42.64.40/30\",\r\n \ + \ \"20.42.72.132/30\",\r\n \"20.44.3.24/29\",\r\n \"\ + 20.44.10.124/30\",\r\n \"20.44.19.0/30\",\r\n \"20.44.29.52/30\"\ + ,\r\n \"20.45.79.240/32\",\r\n \"20.45.123.244/30\",\r\n\ + \ \"20.49.82.4/30\",\r\n \"20.49.90.4/30\",\r\n \ + \ \"20.150.171.72/29\",\r\n \"20.150.181.160/30\",\r\n \ + \ \"20.150.189.28/30\",\r\n \"20.184.2.84/32\",\r\n \"20.192.101.28/30\"\ + ,\r\n \"20.192.235.0/29\",\r\n \"20.193.202.24/29\",\r\n\ + \ \"20.194.66.4/30\",\r\n \"23.96.200.228/32\",\r\n \ + \ \"23.96.210.6/32\",\r\n \"23.96.214.100/32\",\r\n \ + \ \"23.98.86.60/30\",\r\n \"23.99.11.219/32\",\r\n \"23.100.199.230/32\"\ + ,\r\n \"40.67.59.72/29\",\r\n \"40.69.107.0/29\",\r\n \ + \ \"40.69.166.6/32\",\r\n \"40.70.146.232/29\",\r\n \ + \ \"40.71.11.104/29\",\r\n \"40.74.100.240/29\",\r\n \ + \ \"40.74.146.56/29\",\r\n \"40.75.35.220/30\",\r\n \"40.76.203.148/32\"\ + ,\r\n \"40.76.205.181/32\",\r\n \"40.78.195.0/29\",\r\n\ + \ \"40.78.202.120/29\",\r\n \"40.78.238.60/30\",\r\n \ + \ \"40.78.245.192/30\",\r\n \"40.78.253.64/30\",\r\n \ + \ \"40.79.114.102/32\",\r\n \"40.79.130.232/29\",\r\n \ + \ \"40.79.139.192/30\",\r\n \"40.79.148.80/30\",\r\n \"\ + 40.79.165.80/29\",\r\n \"40.79.171.228/30\",\r\n \"40.79.173.0/30\"\ + ,\r\n \"40.79.179.0/29\",\r\n \"40.79.189.60/30\",\r\n \ + \ \"40.79.197.36/30\",\r\n \"40.80.53.4/30\",\r\n \ + \ \"40.84.62.189/32\",\r\n \"40.84.133.64/32\",\r\n \"\ + 40.85.224.118/32\",\r\n \"40.86.230.174/32\",\r\n \"40.89.168.15/32\"\ + ,\r\n \"40.112.243.176/29\",\r\n \"40.113.23.157/32\",\r\ + \n \"40.113.88.37/32\",\r\n \"40.115.64.123/32\",\r\n \ + \ \"40.115.113.228/32\",\r\n \"40.120.74.4/30\",\r\n \ + \ \"40.123.204.26/32\",\r\n \"51.12.99.64/29\",\r\n \ + \ \"51.12.203.64/29\",\r\n \"51.105.69.84/30\",\r\n \"51.105.77.52/30\"\ + ,\r\n \"51.107.59.40/29\",\r\n \"51.107.76.20/32\",\r\n\ + \ \"51.107.155.40/29\",\r\n \"51.107.239.250/32\",\r\n \ + \ \"51.116.59.40/29\",\r\n \"51.116.155.104/29\",\r\n \ + \ \"51.116.208.26/32\",\r\n \"51.116.232.27/32\",\r\n \ + \ \"51.116.245.160/30\",\r\n \"51.116.253.128/30\",\r\n \ + \ \"51.120.68.23/32\",\r\n \"51.120.98.240/29\",\r\n \ + \ \"51.120.164.23/32\",\r\n \"51.120.219.72/29\",\r\n \"\ + 51.140.148.24/29\",\r\n \"51.140.184.27/32\",\r\n \"51.140.211.16/29\"\ + ,\r\n \"51.141.8.30/32\",\r\n \"52.136.136.27/32\",\r\n\ + \ \"52.138.70.82/32\",\r\n \"52.138.92.168/30\",\r\n \ + \ \"52.138.143.55/32\",\r\n \"52.138.229.68/30\",\r\n \ + \ \"52.143.136.15/32\",\r\n \"52.143.184.15/32\",\r\n \ + \ \"52.151.38.144/32\",\r\n \"52.158.236.247/32\",\r\n \ + \ \"52.162.107.176/29\",\r\n \"52.163.90.165/32\",\r\n \ + \ \"52.163.94.113/32\",\r\n \"52.165.37.188/32\",\r\n \"\ + 52.167.0.27/32\",\r\n \"52.167.109.68/30\",\r\n \"52.167.227.220/32\"\ + ,\r\n \"52.174.163.204/32\",\r\n \"52.174.164.254/32\",\r\ + \n \"52.178.30.193/32\",\r\n \"52.180.176.84/32\",\r\n \ + \ \"52.182.141.56/30\",\r\n \"52.182.172.232/32\",\r\n \ + \ \"52.225.184.94/32\",\r\n \"52.225.185.159/32\",\r\n \ + \ \"52.230.8.61/32\",\r\n \"52.231.18.232/29\",\r\n \ + \ \"52.231.32.81/32\",\r\n \"52.231.147.16/29\",\r\n \"\ + 52.231.200.124/32\",\r\n \"52.236.161.75/32\",\r\n \"52.236.189.76/30\"\ + ,\r\n \"52.246.157.8/30\",\r\n \"65.52.250.224/29\",\r\n\ + \ \"102.37.48.12/32\",\r\n \"102.133.27.24/29\",\r\n \ + \ \"102.133.72.31/32\",\r\n \"102.133.155.24/29\",\r\n \ + \ \"102.133.160.28/32\",\r\n \"102.133.235.169/32\",\r\n \ + \ \"102.133.251.216/30\",\r\n \"104.41.9.53/32\",\r\n \ + \ \"104.41.187.29/32\",\r\n \"104.42.181.121/32\",\r\n \ + \ \"104.43.213.84/32\",\r\n \"104.45.19.250/32\",\r\n \ + \ \"104.46.225.57/32\",\r\n \"104.210.107.69/32\",\r\n \ + \ \"104.211.81.216/29\",\r\n \"104.211.103.201/32\",\r\n \ + \ \"104.211.146.240/29\",\r\n \"104.211.164.163/32\",\r\n \ + \ \"104.211.228.68/32\",\r\n \"104.214.19.72/29\",\r\n \ + \ \"104.215.78.146/32\",\r\n \"137.116.252.9/32\",\r\n \ + \ \"137.135.33.49/32\",\r\n \"191.233.50.24/29\",\r\n \"\ + 191.233.203.216/29\",\r\n \"191.234.149.32/30\",\r\n \"\ + 191.234.157.128/30\",\r\n \"207.46.234.62/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.AustraliaCentral\"\ + ,\r\n \"id\": \"ServiceFabric.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.36.40.70/32\",\r\n \ + \ \"20.36.107.16/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.AustraliaCentral2\",\r\n \"id\": \"\ + ServiceFabric.AustraliaCentral2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\ + \n \"addressPrefixes\": [\r\n \"20.36.72.79/32\",\r\n \ + \ \"20.36.114.192/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ServiceFabric.AustraliaEast\",\r\n \"id\": \"ServiceFabric.AustraliaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.70.72.216/29\",\r\n \"13.70.78.172/30\",\r\n \ + \ \"40.79.165.80/29\",\r\n \"40.79.171.228/30\",\r\n \ + \ \"40.79.173.0/30\",\r\n \"104.210.107.69/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.AustraliaSoutheast\"\ + ,\r\n \"id\": \"ServiceFabric.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.77.52.0/29\",\r\n \ + \ \"40.115.64.123/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.BrazilSouth\",\r\n \"id\": \"ServiceFabric.BrazilSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"brazilsouth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"104.41.9.53/32\",\r\n \"191.233.203.216/29\",\r\n \ + \ \"191.234.149.32/30\",\r\n \"191.234.157.128/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CanadaCentral\"\ + ,\r\n \"id\": \"ServiceFabric.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.71.170.224/29\",\r\n\ + \ \"13.71.170.248/29\",\r\n \"20.38.149.192/30\",\r\n \ + \ \"40.85.224.118/32\",\r\n \"52.246.157.8/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CanadaEast\"\ + ,\r\n \"id\": \"ServiceFabric.CanadaEast\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.69.107.0/29\",\r\n \ + \ \"40.86.230.174/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.CentralIndia\",\r\n \"id\": \"ServiceFabric.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"20.192.101.28/30\",\r\n \"40.80.53.4/30\",\r\n \ + \ \"104.211.81.216/29\",\r\n \"104.211.103.201/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CentralUS\"\ + ,\r\n \"id\": \"ServiceFabric.CentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.89.171.104/29\",\r\n\ + \ \"20.44.10.124/30\",\r\n \"40.69.166.6/32\",\r\n \ + \ \"52.165.37.188/32\",\r\n \"52.182.141.56/30\",\r\n \ + \ \"52.182.172.232/32\",\r\n \"104.43.213.84/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.CentralUSEUAP\"\ + ,\r\n \"id\": \"ServiceFabric.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.78.202.120/29\",\r\n\ + \ \"52.180.176.84/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.EastAsia\",\r\n \"id\": \"ServiceFabric.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.75.36.80/29\"\ + ,\r\n \"13.75.41.166/32\",\r\n \"13.75.42.35/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.EastUS\"\ + ,\r\n \"id\": \"ServiceFabric.EastUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\ + \n \"addressPrefixes\": [\r\n \"13.92.124.124/32\",\r\n \ + \ \"20.42.64.40/30\",\r\n \"20.42.72.132/30\",\r\n \ + \ \"40.71.11.104/29\",\r\n \"40.76.203.148/32\",\r\n \"\ + 40.76.205.181/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"ServiceFabric.EastUS2\",\r\n \"id\": \"ServiceFabric.EastUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.44.19.0/30\",\r\n \ + \ \"40.70.146.232/29\",\r\n \"40.84.62.189/32\",\r\n \ + \ \"52.167.0.27/32\",\r\n \"52.167.109.68/30\",\r\n \ + \ \"52.167.227.220/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"ServiceFabric.EastUS2EUAP\",\r\n \"id\": \"ServiceFabric.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.74.146.56/29\",\r\n \"40.75.35.220/30\",\r\n \ + \ \"40.79.114.102/32\",\r\n \"52.138.70.82/32\",\r\n \ + \ \"52.138.92.168/30\",\r\n \"52.225.184.94/32\",\r\n \ + \ \"52.225.185.159/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"ServiceFabric.FranceCentral\",\r\n \"id\": \"ServiceFabric.FranceCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"40.79.130.232/29\",\r\n \"40.79.139.192/30\",\r\n \ + \ \"40.79.148.80/30\",\r\n \"40.89.168.15/32\",\r\n \ + \ \"52.143.136.15/32\",\r\n \"52.143.184.15/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.FranceSouth\"\ + ,\r\n \"id\": \"ServiceFabric.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.179.0/29\",\r\n \ + \ \"52.136.136.27/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.GermanyNorth\",\r\n \"id\": \"ServiceFabric.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"51.116.59.40/29\"\ + ,\r\n \"51.116.208.26/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceFabric.GermanyWestCentral\",\r\n \"\ + id\": \"ServiceFabric.GermanyWestCentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\ + \n \"addressPrefixes\": [\r\n \"51.116.155.104/29\",\r\n \ + \ \"51.116.232.27/32\",\r\n \"51.116.245.160/30\",\r\n \ + \ \"51.116.253.128/30\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.JapanEast\",\r\n \"id\": \"ServiceFabric.JapanEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.78.108.24/29\"\ + ,\r\n \"40.79.189.60/30\",\r\n \"40.79.197.36/30\",\r\n\ + \ \"104.41.187.29/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.JapanWest\",\r\n \"id\": \"ServiceFabric.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"40.74.100.240/29\"\ + ,\r\n \"104.46.225.57/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceFabric.KoreaCentral\",\r\n \"id\"\ + : \"ServiceFabric.KoreaCentral\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + \r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.44.29.52/30\",\r\n \"\ + 20.194.66.4/30\",\r\n \"52.231.18.232/29\",\r\n \"52.231.32.81/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.KoreaSouth\"\ + ,\r\n \"id\": \"ServiceFabric.KoreaSouth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"52.231.147.16/29\",\r\n\ + \ \"52.231.200.124/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceFabric.NorthCentralUS\",\r\n \"id\":\ + \ \"ServiceFabric.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\ + \n \"addressPrefixes\": [\r\n \"23.96.200.228/32\",\r\n \ + \ \"23.96.210.6/32\",\r\n \"23.96.214.100/32\",\r\n \ + \ \"52.162.107.176/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ServiceFabric.NorthEurope\",\r\n \"id\": \"ServiceFabric.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.69.227.232/29\",\r\n \"13.74.80.74/32\",\r\n \ + \ \"13.74.111.144/30\",\r\n \"40.113.23.157/32\",\r\n \ + \ \"40.113.88.37/32\",\r\n \"40.115.113.228/32\",\r\n \ + \ \"52.138.143.55/32\",\r\n \"52.138.229.68/30\",\r\n \"\ + 137.116.252.9/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"ServiceFabric.NorwayEast\",\r\n \"id\": \"ServiceFabric.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.68.23/32\",\r\n\ + \ \"51.120.98.240/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.NorwayWest\",\r\n \"id\": \"ServiceFabric.NorwayWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.164.23/32\",\r\n\ + \ \"51.120.219.72/29\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.SouthAfricaNorth\",\r\n \"id\": \"\ + ServiceFabric.SouthAfricaNorth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.37.48.12/32\",\r\n \ + \ \"102.133.155.24/29\",\r\n \"102.133.160.28/32\",\r\n \ + \ \"102.133.235.169/32\",\r\n \"102.133.251.216/30\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SouthAfricaWest\"\ + ,\r\n \"id\": \"ServiceFabric.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"102.133.27.24/29\",\r\n\ + \ \"102.133.72.31/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.SouthCentralUS\",\r\n \"id\": \"ServiceFabric.SouthCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \ + \ \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\ + \n \"20.45.123.244/30\",\r\n \"20.49.90.4/30\",\r\n \ + \ \"40.84.133.64/32\",\r\n \"104.214.19.72/29\",\r\n \ + \ \"104.215.78.146/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"ServiceFabric.SoutheastAsia\",\r\n \"id\": \"ServiceFabric.SoutheastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southeastasia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.67.9.136/29\",\r\n \"20.184.2.84/32\",\r\n \ + \ \"23.98.86.60/30\",\r\n \"40.78.238.60/30\",\r\n \"\ + 52.163.90.165/32\",\r\n \"52.163.94.113/32\",\r\n \"52.230.8.61/32\"\ + ,\r\n \"207.46.234.62/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"ServiceFabric.SouthIndia\",\r\n \"id\": \"\ + ServiceFabric.SouthIndia\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"southindia\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n\ + \ \"systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.78.195.0/29\",\r\n \"104.211.228.68/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.SwitzerlandNorth\"\ + ,\r\n \"id\": \"ServiceFabric.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.107.59.40/29\",\r\n\ + \ \"51.107.76.20/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.SwitzerlandWest\",\r\n \"id\": \"ServiceFabric.SwitzerlandWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"51.107.155.40/29\",\r\n \"51.107.239.250/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UAECentral\"\ + ,\r\n \"id\": \"ServiceFabric.UAECentral\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.37.74.80/29\",\r\n \ + \ \"20.45.79.240/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.UAENorth\",\r\n \"id\": \"ServiceFabric.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"40.120.74.4/30\"\ + ,\r\n \"40.123.204.26/32\",\r\n \"65.52.250.224/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.UKNorth\"\ + ,\r\n \"id\": \"ServiceFabric.UKNorth\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\",\r\ + \n \"addressPrefixes\": [\r\n \"13.87.98.166/32\",\r\n \ + \ \"13.87.122.240/29\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ServiceFabric.UKSouth\",\r\n \"id\": \"ServiceFabric.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.105.69.84/30\",\r\n\ + \ \"51.105.77.52/30\",\r\n \"51.140.148.24/29\",\r\n \ + \ \"51.140.184.27/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ServiceFabric.UKSouth2\",\r\n \"id\": \"ServiceFabric.UKSouth2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n \"13.87.32.204/32\"\ + ,\r\n \"13.87.56.240/29\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceFabric.UKWest\",\r\n \"id\": \"ServiceFabric.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.140.211.16/29\",\r\n\ + \ \"51.141.8.30/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"ServiceFabric.WestCentralUS\",\r\n \"id\": \"ServiceFabric.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"ServiceFabric\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.71.195.48/29\",\r\n \"13.78.147.125/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestEurope\"\ + ,\r\n \"id\": \"ServiceFabric.WestEurope\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.69.64.232/29\",\r\n\ + \ \"13.69.109.136/30\",\r\n \"13.80.117.236/32\",\r\n \ + \ \"52.174.163.204/32\",\r\n \"52.174.164.254/32\",\r\n \ + \ \"52.178.30.193/32\",\r\n \"52.236.161.75/32\",\r\n \ + \ \"52.236.189.76/30\",\r\n \"104.45.19.250/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"ServiceFabric.WestIndia\"\ + ,\r\n \"id\": \"ServiceFabric.WestIndia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"104.211.146.240/29\",\r\ + \n \"104.211.164.163/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"ServiceFabric.WestUS\",\r\n \"id\": \"ServiceFabric.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.91.7.211/32\",\r\n \ + \ \"13.91.252.58/32\",\r\n \"23.99.11.219/32\",\r\n \ + \ \"40.112.243.176/29\",\r\n \"104.42.181.121/32\",\r\n \ + \ \"137.135.33.49/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"ServiceFabric.WestUS2\",\r\n \"id\": \"ServiceFabric.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"ServiceFabric\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.66.140.152/29\",\r\n\ + \ \"13.66.167.194/32\",\r\n \"13.66.226.151/32\",\r\n \ + \ \"40.78.245.192/30\",\r\n \"40.78.253.64/30\",\r\n \ + \ \"52.151.38.144/32\",\r\n \"52.158.236.247/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql\",\r\n \"\ + id\": \"Sql\",\r\n \"properties\": {\r\n \"changeNumber\": \"\ + 1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\n\ + \ \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.65.31.249/32\"\ + ,\r\n \"13.65.39.207/32\",\r\n \"13.65.85.183/32\",\r\n\ + \ \"13.65.200.105/32\",\r\n \"13.65.209.243/32\",\r\n \ + \ \"13.65.253.67/32\",\r\n \"13.66.60.72/32\",\r\n \ + \ \"13.66.60.111/32\",\r\n \"13.66.62.124/32\",\r\n \"\ + 13.66.136.0/26\",\r\n \"13.66.137.0/26\",\r\n \"13.66.226.202/32\"\ + ,\r\n \"13.66.229.222/32\",\r\n \"13.66.230.18/31\",\r\n\ + \ \"13.66.230.60/32\",\r\n \"13.66.230.64/32\",\r\n \ + \ \"13.66.230.103/32\",\r\n \"13.67.16.0/26\",\r\n \ + \ \"13.67.17.0/26\",\r\n \"13.67.48.255/32\",\r\n \"13.67.56.134/32\"\ + ,\r\n \"13.67.59.217/32\",\r\n \"13.67.215.62/32\",\r\n\ + \ \"13.68.22.44/32\",\r\n \"13.68.30.216/32\",\r\n \ + \ \"13.68.87.133/32\",\r\n \"13.69.104.0/26\",\r\n \"\ + 13.69.104.192/26\",\r\n \"13.69.105.0/26\",\r\n \"13.69.105.192/26\"\ + ,\r\n \"13.69.224.0/26\",\r\n \"13.69.224.192/26\",\r\n\ + \ \"13.69.225.0/26\",\r\n \"13.69.225.192/26\",\r\n \ + \ \"13.70.112.0/27\",\r\n \"13.70.113.0/27\",\r\n \"\ + 13.70.148.251/32\",\r\n \"13.70.155.163/32\",\r\n \"13.71.168.0/27\"\ + ,\r\n \"13.71.169.0/27\",\r\n \"13.71.192.0/27\",\r\n \ + \ \"13.71.193.0/27\",\r\n \"13.73.109.251/32\",\r\n \ + \ \"13.74.104.64/26\",\r\n \"13.74.104.128/26\",\r\n \ + \ \"13.74.105.0/26\",\r\n \"13.74.105.128/26\",\r\n \"13.75.32.0/26\"\ + ,\r\n \"13.75.33.0/26\",\r\n \"13.75.105.141/32\",\r\n \ + \ \"13.75.106.191/32\",\r\n \"13.75.108.188/32\",\r\n \ + \ \"13.75.149.87/32\",\r\n \"13.76.90.3/32\",\r\n \ + \ \"13.76.247.54/32\",\r\n \"13.77.7.78/32\",\r\n \"13.77.48.0/27\"\ + ,\r\n \"13.77.49.0/27\",\r\n \"13.78.61.196/32\",\r\n \ + \ \"13.78.104.0/27\",\r\n \"13.78.105.0/27\",\r\n \ + \ \"13.78.121.203/32\",\r\n \"13.78.144.57/32\",\r\n \"\ + 13.78.145.25/32\",\r\n \"13.78.148.71/32\",\r\n \"13.78.151.189/32\"\ + ,\r\n \"13.78.151.207/32\",\r\n \"13.78.178.116/32\",\r\n\ + \ \"13.78.178.151/32\",\r\n \"13.78.248.32/27\",\r\n \ + \ \"13.84.223.76/32\",\r\n \"13.85.65.48/32\",\r\n \ + \ \"13.85.68.115/32\",\r\n \"13.85.69.107/32\",\r\n \"\ + 13.86.216.0/25\",\r\n \"13.86.216.128/26\",\r\n \"13.86.216.192/27\"\ + ,\r\n \"13.86.217.0/25\",\r\n \"13.86.217.128/26\",\r\n\ + \ \"13.86.217.192/27\",\r\n \"13.87.16.64/27\",\r\n \ + \ \"13.87.17.0/27\",\r\n \"13.87.33.234/32\",\r\n \"\ + 13.87.34.7/32\",\r\n \"13.87.34.19/32\",\r\n \"13.87.38.138/32\"\ + ,\r\n \"13.87.97.210/32\",\r\n \"13.87.97.228/32\",\r\n\ + \ \"13.87.97.237/32\",\r\n \"13.87.120.0/27\",\r\n \ + \ \"13.87.121.0/27\",\r\n \"13.88.14.200/32\",\r\n \"\ + 13.88.29.70/32\",\r\n \"13.88.249.189/32\",\r\n \"13.88.254.42/32\"\ + ,\r\n \"13.89.36.110/32\",\r\n \"13.89.37.61/32\",\r\n \ + \ \"13.89.57.50/32\",\r\n \"13.89.57.115/32\",\r\n \ + \ \"13.89.168.0/26\",\r\n \"13.89.169.0/26\",\r\n \"\ + 13.91.4.219/32\",\r\n \"13.91.6.136/32\",\r\n \"13.91.41.153/32\"\ + ,\r\n \"13.91.44.56/32\",\r\n \"13.91.46.83/32\",\r\n \ + \ \"13.91.47.72/32\",\r\n \"13.93.165.251/32\",\r\n \ + \ \"13.93.237.158/32\",\r\n \"20.36.104.0/27\",\r\n \"\ + 20.36.105.0/27\",\r\n \"20.36.112.0/27\",\r\n \"20.36.113.0/27\"\ + ,\r\n \"20.37.72.64/27\",\r\n \"20.37.73.64/27\",\r\n \ + \ \"20.38.144.0/27\",\r\n \"20.38.145.0/27\",\r\n \ + \ \"20.44.0.0/27\",\r\n \"20.44.1.0/27\",\r\n \"20.44.24.0/27\"\ + ,\r\n \"20.44.25.0/27\",\r\n \"20.45.120.0/27\",\r\n \ + \ \"20.45.121.0/27\",\r\n \"20.49.80.0/27\",\r\n \"\ + 20.49.81.0/27\",\r\n \"20.49.88.0/27\",\r\n \"20.49.89.0/27\"\ + ,\r\n \"20.150.168.0/27\",\r\n \"20.150.169.0/27\",\r\n\ + \ \"20.150.176.0/27\",\r\n \"20.150.177.0/27\",\r\n \ + \ \"20.150.184.0/27\",\r\n \"20.150.185.0/27\",\r\n \ + \ \"20.192.96.0/27\",\r\n \"20.192.97.0/27\",\r\n \"20.192.232.0/27\"\ + ,\r\n \"20.192.233.0/27\",\r\n \"20.193.200.0/27\",\r\n\ + \ \"20.193.201.0/27\",\r\n \"20.194.64.0/27\",\r\n \ + \ \"20.194.65.0/27\",\r\n \"23.96.89.109/32\",\r\n \"\ + 23.96.106.191/32\",\r\n \"23.96.178.199/32\",\r\n \"23.96.202.229/32\"\ + ,\r\n \"23.96.204.249/32\",\r\n \"23.96.205.215/32\",\r\n\ + \ \"23.96.214.69/32\",\r\n \"23.96.243.243/32\",\r\n \ + \ \"23.96.247.75/32\",\r\n \"23.96.249.37/32\",\r\n \ + \ \"23.96.250.178/32\",\r\n \"23.97.68.51/32\",\r\n \"\ + 23.97.74.21/32\",\r\n \"23.97.78.163/32\",\r\n \"23.97.167.46/32\"\ + ,\r\n \"23.97.169.19/32\",\r\n \"23.97.219.82/32\",\r\n\ + \ \"23.97.221.176/32\",\r\n \"23.98.55.75/32\",\r\n \ + \ \"23.98.80.0/26\",\r\n \"23.98.81.0/26\",\r\n \"\ + 23.98.162.75/32\",\r\n \"23.98.162.76/31\",\r\n \"23.98.162.78/32\"\ + ,\r\n \"23.98.170.75/32\",\r\n \"23.98.170.76/31\",\r\n\ + \ \"23.99.4.210/32\",\r\n \"23.99.4.248/32\",\r\n \ + \ \"23.99.10.185/32\",\r\n \"23.99.34.75/32\",\r\n \"\ + 23.99.34.76/31\",\r\n \"23.99.34.78/32\",\r\n \"23.99.37.235/32\"\ + ,\r\n \"23.99.37.236/32\",\r\n \"23.99.57.14/32\",\r\n \ + \ \"23.99.80.243/32\",\r\n \"23.99.89.212/32\",\r\n \ + \ \"23.99.90.75/32\",\r\n \"23.99.91.130/32\",\r\n \"\ + 23.99.102.124/32\",\r\n \"23.99.118.196/32\",\r\n \"23.99.160.139/32\"\ + ,\r\n \"23.99.160.140/31\",\r\n \"23.99.160.142/32\",\r\n\ + \ \"23.99.205.183/32\",\r\n \"23.100.117.95/32\",\r\n \ + \ \"23.100.119.70/32\",\r\n \"23.101.18.228/32\",\r\n \ + \ \"23.101.64.10/32\",\r\n \"23.101.165.167/32\",\r\n \ + \ \"23.101.167.45/32\",\r\n \"23.101.170.98/32\",\r\n \ + \ \"23.102.16.130/32\",\r\n \"23.102.23.219/32\",\r\n \"\ + 23.102.25.199/32\",\r\n \"23.102.52.155/32\",\r\n \"23.102.57.142/32\"\ + ,\r\n \"23.102.62.171/32\",\r\n \"23.102.69.95/32\",\r\n\ + \ \"23.102.71.13/32\",\r\n \"23.102.74.190/32\",\r\n \ + \ \"23.102.172.251/32\",\r\n \"23.102.173.220/32\",\r\n \ + \ \"23.102.174.146/32\",\r\n \"23.102.179.187/32\",\r\n \ + \ \"23.102.206.35/32\",\r\n \"23.102.206.36/31\",\r\n \ + \ \"40.67.56.0/27\",\r\n \"40.67.57.0/27\",\r\n \"40.68.37.158/32\"\ + ,\r\n \"40.68.215.206/32\",\r\n \"40.68.220.16/32\",\r\n\ + \ \"40.69.104.0/27\",\r\n \"40.69.105.0/27\",\r\n \ + \ \"40.69.132.90/32\",\r\n \"40.69.143.202/32\",\r\n \ + \ \"40.69.169.120/32\",\r\n \"40.69.189.48/32\",\r\n \"\ + 40.70.144.0/26\",\r\n \"40.70.145.0/26\",\r\n \"40.71.8.0/26\"\ + ,\r\n \"40.71.8.192/26\",\r\n \"40.71.9.0/26\",\r\n \ + \ \"40.71.9.192/26\",\r\n \"40.71.196.33/32\",\r\n \ + \ \"40.71.211.227/32\",\r\n \"40.71.226.18/32\",\r\n \"\ + 40.74.51.145/32\",\r\n \"40.74.53.36/32\",\r\n \"40.74.60.91/32\"\ + ,\r\n \"40.74.96.0/27\",\r\n \"40.74.97.0/27\",\r\n \ + \ \"40.74.114.22/32\",\r\n \"40.74.115.153/32\",\r\n \ + \ \"40.74.135.185/32\",\r\n \"40.74.144.0/27\",\r\n \"\ + 40.74.145.0/27\",\r\n \"40.74.254.156/32\",\r\n \"40.75.32.0/27\"\ + ,\r\n \"40.75.33.0/27\",\r\n \"40.76.2.172/32\",\r\n \ + \ \"40.76.26.90/32\",\r\n \"40.76.42.44/32\",\r\n \ + \ \"40.76.65.222/32\",\r\n \"40.76.66.9/32\",\r\n \"40.76.193.221/32\"\ + ,\r\n \"40.76.209.171/32\",\r\n \"40.76.219.185/32\",\r\n\ + \ \"40.77.30.201/32\",\r\n \"40.78.16.122/32\",\r\n \ + \ \"40.78.23.252/32\",\r\n \"40.78.31.250/32\",\r\n \ + \ \"40.78.57.109/32\",\r\n \"40.78.101.91/32\",\r\n \"\ + 40.78.110.18/32\",\r\n \"40.78.111.189/32\",\r\n \"40.78.192.0/27\"\ + ,\r\n \"40.78.193.0/27\",\r\n \"40.78.224.0/26\",\r\n \ + \ \"40.78.224.128/26\",\r\n \"40.78.225.0/26\",\r\n \ + \ \"40.78.225.128/26\",\r\n \"40.78.232.0/26\",\r\n \"\ + 40.78.233.0/26\",\r\n \"40.78.240.0/26\",\r\n \"40.78.241.0/26\"\ + ,\r\n \"40.78.248.0/26\",\r\n \"40.78.249.0/26\",\r\n \ + \ \"40.79.84.180/32\",\r\n \"40.79.128.0/27\",\r\n \ + \ \"40.79.129.0/27\",\r\n \"40.79.136.0/27\",\r\n \"40.79.137.0/27\"\ + ,\r\n \"40.79.144.0/27\",\r\n \"40.79.145.0/27\",\r\n \ + \ \"40.79.152.0/26\",\r\n \"40.79.152.192/26\",\r\n \ + \ \"40.79.153.0/26\",\r\n \"40.79.153.192/26\",\r\n \"\ + 40.79.160.0/27\",\r\n \"40.79.161.0/27\",\r\n \"40.79.168.0/27\"\ + ,\r\n \"40.79.169.0/27\",\r\n \"40.79.176.0/27\",\r\n \ + \ \"40.79.177.0/27\",\r\n \"40.79.184.0/27\",\r\n \ + \ \"40.79.185.0/27\",\r\n \"40.79.192.0/27\",\r\n \"40.79.193.0/27\"\ + ,\r\n \"40.80.48.0/27\",\r\n \"40.80.49.0/27\",\r\n \ + \ \"40.83.178.165/32\",\r\n \"40.83.186.249/32\",\r\n \ + \ \"40.84.5.64/32\",\r\n \"40.84.54.249/32\",\r\n \"\ + 40.84.153.95/32\",\r\n \"40.84.155.210/32\",\r\n \"40.84.156.165/32\"\ + ,\r\n \"40.84.191.1/32\",\r\n \"40.84.193.16/32\",\r\n \ + \ \"40.84.195.189/32\",\r\n \"40.84.231.203/32\",\r\n \ + \ \"40.85.102.50/32\",\r\n \"40.85.224.249/32\",\r\n \ + \ \"40.85.225.5/32\",\r\n \"40.86.75.134/32\",\r\n \"\ + 40.86.226.166/32\",\r\n \"40.86.226.230/32\",\r\n \"40.112.139.250/32\"\ + ,\r\n \"40.112.240.0/27\",\r\n \"40.112.246.0/27\",\r\n\ + \ \"40.113.14.53/32\",\r\n \"40.113.16.190/32\",\r\n \ + \ \"40.113.17.148/32\",\r\n \"40.113.20.38/32\",\r\n \ + \ \"40.113.93.91/32\",\r\n \"40.113.200.119/32\",\r\n \ + \ \"40.114.40.118/32\",\r\n \"40.114.43.106/32\",\r\n \"\ + 40.114.45.195/32\",\r\n \"40.114.46.128/32\",\r\n \"40.114.46.212/32\"\ + ,\r\n \"40.114.81.142/32\",\r\n \"40.114.240.125/32\",\r\ + \n \"40.114.240.162/32\",\r\n \"40.115.37.61/32\",\r\n \ + \ \"40.115.51.118/32\",\r\n \"40.115.52.141/32\",\r\n \ + \ \"40.115.53.255/32\",\r\n \"40.115.61.208/32\",\r\n \ + \ \"40.117.42.73/32\",\r\n \"40.117.44.71/32\",\r\n \ + \ \"40.117.90.115/32\",\r\n \"40.117.97.189/32\",\r\n \"\ + 40.118.12.208/32\",\r\n \"40.118.129.167/32\",\r\n \"40.118.170.1/32\"\ + ,\r\n \"40.118.209.206/32\",\r\n \"40.118.244.227/32\",\r\ + \n \"40.118.249.123/32\",\r\n \"40.118.250.19/32\",\r\n\ + \ \"40.120.72.0/27\",\r\n \"40.120.73.0/27\",\r\n \ + \ \"40.121.143.204/32\",\r\n \"40.121.149.49/32\",\r\n \ + \ \"40.121.154.241/32\",\r\n \"40.121.158.30/32\",\r\n \ + \ \"40.122.205.105/32\",\r\n \"40.122.215.111/32\",\r\n \ + \ \"40.124.8.76/32\",\r\n \"40.126.228.153/32\",\r\n \"\ + 40.126.230.223/32\",\r\n \"40.126.232.113/32\",\r\n \"40.126.233.152/32\"\ + ,\r\n \"40.126.250.24/32\",\r\n \"40.127.82.69/32\",\r\n\ + \ \"40.127.83.164/32\",\r\n \"40.127.128.10/32\",\r\n \ + \ \"40.127.135.67/32\",\r\n \"40.127.137.209/32\",\r\n \ + \ \"40.127.141.194/32\",\r\n \"40.127.177.139/32\",\r\n \ + \ \"40.127.190.50/32\",\r\n \"51.12.96.0/27\",\r\n \ + \ \"51.12.97.0/27\",\r\n \"51.12.200.0/27\",\r\n \"51.12.201.0/27\"\ + ,\r\n \"51.12.224.0/27\",\r\n \"51.12.225.0/27\",\r\n \ + \ \"51.12.232.0/27\",\r\n \"51.12.233.0/27\",\r\n \ + \ \"51.105.64.0/27\",\r\n \"51.105.65.0/27\",\r\n \"51.105.72.0/27\"\ + ,\r\n \"51.105.73.0/27\",\r\n \"51.107.56.0/27\",\r\n \ + \ \"51.107.57.0/27\",\r\n \"51.107.152.0/27\",\r\n \ + \ \"51.107.153.0/27\",\r\n \"51.116.56.0/27\",\r\n \"\ + 51.116.57.0/27\",\r\n \"51.116.152.0/27\",\r\n \"51.116.153.0/27\"\ + ,\r\n \"51.116.240.0/27\",\r\n \"51.116.241.0/27\",\r\n\ + \ \"51.116.248.0/27\",\r\n \"51.116.249.0/27\",\r\n \ + \ \"51.120.96.0/27\",\r\n \"51.120.97.0/27\",\r\n \"\ + 51.120.104.0/27\",\r\n \"51.120.105.0/27\",\r\n \"51.120.208.0/27\"\ + ,\r\n \"51.120.209.0/27\",\r\n \"51.120.216.0/27\",\r\n\ + \ \"51.120.217.0/27\",\r\n \"51.140.77.9/32\",\r\n \ + \ \"51.140.114.26/32\",\r\n \"51.140.115.150/32\",\r\n \ + \ \"51.140.144.0/27\",\r\n \"51.140.145.0/27\",\r\n \"\ + 51.140.180.9/32\",\r\n \"51.140.183.238/32\",\r\n \"51.140.184.11/32\"\ + ,\r\n \"51.140.184.12/32\",\r\n \"51.140.208.64/27\",\r\n\ + \ \"51.140.209.0/27\",\r\n \"51.141.8.11/32\",\r\n \ + \ \"51.141.8.12/32\",\r\n \"51.141.15.53/32\",\r\n \"\ + 51.141.25.212/32\",\r\n \"51.142.211.129/32\",\r\n \"52.138.88.0/27\"\ + ,\r\n \"52.138.89.0/27\",\r\n \"52.138.224.0/26\",\r\n \ + \ \"52.138.224.128/26\",\r\n \"52.138.225.0/26\",\r\n \ + \ \"52.138.225.128/26\",\r\n \"52.161.15.204/32\",\r\n \ + \ \"52.161.100.158/32\",\r\n \"52.161.105.228/32\",\r\n \ + \ \"52.161.128.32/27\",\r\n \"52.162.104.0/26\",\r\n \ + \ \"52.162.105.0/26\",\r\n \"52.162.125.1/32\",\r\n \"\ + 52.162.241.250/32\",\r\n \"52.165.184.67/32\",\r\n \"52.166.76.0/32\"\ + ,\r\n \"52.166.131.195/32\",\r\n \"52.167.104.0/26\",\r\n\ + \ \"52.167.105.0/26\",\r\n \"52.167.117.226/32\",\r\n \ + \ \"52.168.166.153/32\",\r\n \"52.168.169.124/32\",\r\n \ + \ \"52.168.183.223/32\",\r\n \"52.170.41.199/32\",\r\n \ + \ \"52.170.97.16/32\",\r\n \"52.170.98.29/32\",\r\n \ + \ \"52.171.56.10/32\",\r\n \"52.172.24.47/32\",\r\n \"\ + 52.172.43.208/32\",\r\n \"52.172.217.233/32\",\r\n \"52.172.221.154/32\"\ + ,\r\n \"52.173.205.59/32\",\r\n \"52.175.33.150/32\",\r\n\ + \ \"52.176.43.167/32\",\r\n \"52.176.59.12/32\",\r\n \ + \ \"52.176.95.237/32\",\r\n \"52.176.100.98/32\",\r\n \ + \ \"52.177.185.181/32\",\r\n \"52.177.197.103/32\",\r\n \ + \ \"52.177.200.215/32\",\r\n \"52.179.16.95/32\",\r\n \ + \ \"52.179.157.248/32\",\r\n \"52.179.165.160/32\",\r\n \ + \ \"52.179.167.70/32\",\r\n \"52.179.178.184/32\",\r\n \ + \ \"52.180.176.154/31\",\r\n \"52.180.183.226/32\",\r\n \ + \ \"52.182.136.0/26\",\r\n \"52.182.137.0/26\",\r\n \"\ + 52.183.250.62/32\",\r\n \"52.184.192.175/32\",\r\n \"52.184.231.0/32\"\ + ,\r\n \"52.185.152.149/32\",\r\n \"52.187.15.214/32\",\r\ + \n \"52.187.76.130/32\",\r\n \"52.191.144.64/26\",\r\n \ + \ \"52.191.152.64/26\",\r\n \"52.191.172.187/32\",\r\n \ + \ \"52.191.174.114/32\",\r\n \"52.225.188.46/32\",\r\n \ + \ \"52.225.188.113/32\",\r\n \"52.225.222.124/32\",\r\n \ + \ \"52.228.24.103/32\",\r\n \"52.228.35.221/32\",\r\n \ + \ \"52.228.39.117/32\",\r\n \"52.229.17.93/32\",\r\n \ + \ \"52.229.122.195/32\",\r\n \"52.229.123.147/32\",\r\n \ + \ \"52.229.124.23/32\",\r\n \"52.231.16.0/27\",\r\n \"\ + 52.231.17.0/27\",\r\n \"52.231.32.42/31\",\r\n \"52.231.39.56/32\"\ + ,\r\n \"52.231.144.0/27\",\r\n \"52.231.145.0/27\",\r\n\ + \ \"52.231.200.86/31\",\r\n \"52.231.206.133/32\",\r\n \ + \ \"52.236.184.0/27\",\r\n \"52.236.184.128/25\",\r\n \ + \ \"52.236.185.0/27\",\r\n \"52.236.185.128/25\",\r\n \ + \ \"52.237.28.86/32\",\r\n \"52.237.219.227/32\",\r\n \ + \ \"52.242.26.53/32\",\r\n \"52.242.29.91/32\",\r\n \"\ + 52.242.30.154/32\",\r\n \"52.242.36.107/32\",\r\n \"52.243.32.19/32\"\ + ,\r\n \"52.243.43.186/32\",\r\n \"52.246.152.0/27\",\r\n\ + \ \"52.246.153.0/27\",\r\n \"52.246.251.248/32\",\r\n \ + \ \"52.255.48.161/32\",\r\n \"65.52.208.91/32\",\r\n \ + \ \"65.52.213.108/32\",\r\n \"65.52.214.127/32\",\r\n \ + \ \"65.52.218.82/32\",\r\n \"65.52.225.245/32\",\r\n \"\ + 65.52.226.209/32\",\r\n \"65.52.248.0/27\",\r\n \"65.52.249.0/27\"\ + ,\r\n \"102.133.24.0/27\",\r\n \"102.133.25.0/27\",\r\n\ + \ \"102.133.120.0/27\",\r\n \"102.133.121.0/27\",\r\n \ + \ \"102.133.152.0/27\",\r\n \"102.133.153.0/27\",\r\n \ + \ \"102.133.248.0/27\",\r\n \"102.133.249.0/27\",\r\n \ + \ \"104.40.28.188/32\",\r\n \"104.40.49.103/32\",\r\n \ + \ \"104.40.54.130/32\",\r\n \"104.40.82.151/32\",\r\n \"\ + 104.40.155.247/32\",\r\n \"104.40.168.64/26\",\r\n \"104.40.168.192/26\"\ + ,\r\n \"104.40.169.0/27\",\r\n \"104.40.169.128/25\",\r\n\ + \ \"104.40.180.164/32\",\r\n \"104.40.220.28/32\",\r\n \ + \ \"104.40.230.18/32\",\r\n \"104.40.232.54/32\",\r\n \ + \ \"104.40.237.111/32\",\r\n \"104.41.11.5/32\",\r\n \ + \ \"104.41.13.213/32\",\r\n \"104.41.13.233/32\",\r\n \ + \ \"104.41.36.39/32\",\r\n \"104.41.56.218/32\",\r\n \"\ + 104.41.57.82/32\",\r\n \"104.41.59.170/32\",\r\n \"104.41.150.1/32\"\ + ,\r\n \"104.41.152.74/32\",\r\n \"104.41.168.103/32\",\r\ + \n \"104.41.169.34/32\",\r\n \"104.41.202.30/32\",\r\n \ + \ \"104.41.205.195/32\",\r\n \"104.41.208.104/32\",\r\n \ + \ \"104.41.210.68/32\",\r\n \"104.41.211.98/32\",\r\n \ + \ \"104.42.120.235/32\",\r\n \"104.42.127.95/32\",\r\n \ + \ \"104.42.136.93/32\",\r\n \"104.42.188.130/32\",\r\n \ + \ \"104.42.192.190/32\",\r\n \"104.42.199.221/32\",\r\n \ + \ \"104.42.231.253/32\",\r\n \"104.42.237.198/32\",\r\n \ + \ \"104.42.238.205/32\",\r\n \"104.43.10.74/32\",\r\n \ + \ \"104.43.15.0/32\",\r\n \"104.43.164.21/32\",\r\n \"\ + 104.43.164.247/32\",\r\n \"104.43.203.72/32\",\r\n \"104.45.11.99/32\"\ + ,\r\n \"104.45.14.115/32\",\r\n \"104.45.158.30/32\",\r\n\ + \ \"104.46.38.143/32\",\r\n \"104.46.40.24/32\",\r\n \ + \ \"104.46.100.189/32\",\r\n \"104.46.108.148/32\",\r\n \ + \ \"104.47.157.97/32\",\r\n \"104.208.21.0/26\",\r\n \ + \ \"104.208.22.0/26\",\r\n \"104.208.28.16/32\",\r\n \ + \ \"104.208.28.53/32\",\r\n \"104.208.149.0/26\",\r\n \"\ + 104.208.150.0/26\",\r\n \"104.208.161.78/32\",\r\n \"104.208.163.201/32\"\ + ,\r\n \"104.208.233.240/32\",\r\n \"104.208.238.55/32\"\ + ,\r\n \"104.208.241.224/32\",\r\n \"104.209.186.94/32\"\ + ,\r\n \"104.210.32.128/32\",\r\n \"104.210.105.215/32\"\ + ,\r\n \"104.211.85.0/27\",\r\n \"104.211.86.0/27\",\r\n\ + \ \"104.211.96.159/32\",\r\n \"104.211.96.160/32\",\r\n\ + \ \"104.211.144.0/27\",\r\n \"104.211.145.0/27\",\r\n \ + \ \"104.211.160.80/31\",\r\n \"104.211.185.58/32\",\r\n \ + \ \"104.211.190.46/32\",\r\n \"104.211.224.146/31\",\r\n \ + \ \"104.214.16.0/26\",\r\n \"104.214.16.192/26\",\r\n \ + \ \"104.214.17.0/26\",\r\n \"104.214.17.192/26\",\r\n \ + \ \"104.214.67.25/32\",\r\n \"104.214.73.137/32\",\r\n \ + \ \"104.214.78.242/32\",\r\n \"104.214.148.156/32\",\r\n \ + \ \"104.214.150.17/32\",\r\n \"104.215.195.14/32\",\r\n \ + \ \"104.215.196.52/32\",\r\n \"111.221.106.161/32\",\r\n \ + \ \"137.116.31.224/27\",\r\n \"137.116.129.110/32\",\r\n \ + \ \"137.116.203.91/32\",\r\n \"137.135.51.212/32\",\r\n \ + \ \"137.135.109.63/32\",\r\n \"137.135.186.126/32\",\r\n \ + \ \"137.135.189.158/32\",\r\n \"137.135.205.85/32\",\r\n \ + \ \"137.135.213.9/32\",\r\n \"138.91.48.99/32\",\r\n \ + \ \"138.91.58.227/32\",\r\n \"138.91.145.12/32\",\r\n \ + \ \"138.91.160.189/32\",\r\n \"138.91.240.14/32\",\r\n \ + \ \"138.91.246.31/32\",\r\n \"138.91.247.51/32\",\r\n \ + \ \"138.91.251.139/32\",\r\n \"157.55.208.150/32\",\r\n \ + \ \"168.61.136.0/27\",\r\n \"168.61.137.0/27\",\r\n \"168.62.115.112/28\"\ + ,\r\n \"168.62.232.188/32\",\r\n \"168.62.235.49/32\",\r\ + \n \"168.62.235.241/32\",\r\n \"168.62.239.29/32\",\r\n\ + \ \"168.63.13.214/32\",\r\n \"168.63.98.91/32\",\r\n \ + \ \"168.63.175.68/32\",\r\n \"191.233.48.0/27\",\r\n \ + \ \"191.233.49.0/27\",\r\n \"191.233.69.227/32\",\r\n \ + \ \"191.233.90.117/32\",\r\n \"191.233.200.0/27\",\r\n \ + \ \"191.233.201.0/27\",\r\n \"191.234.2.139/32\",\r\n \"\ + 191.234.2.140/31\",\r\n \"191.234.2.142/32\",\r\n \"191.234.144.0/27\"\ + ,\r\n \"191.234.145.0/27\",\r\n \"191.234.152.0/27\",\r\n\ + \ \"191.234.153.0/27\",\r\n \"191.235.170.58/32\",\r\n \ + \ \"191.235.193.75/32\",\r\n \"191.235.193.76/31\",\r\n \ + \ \"191.235.193.78/32\",\r\n \"191.235.193.139/32\",\r\n\ + \ \"191.235.193.140/31\",\r\n \"191.235.209.79/32\",\r\n\ + \ \"191.236.119.31/32\",\r\n \"191.236.148.44/32\",\r\n\ + \ \"191.236.153.120/32\",\r\n \"191.237.20.112/32\",\r\n\ + \ \"191.237.82.74/32\",\r\n \"191.237.219.202/32\",\r\n\ + \ \"191.237.232.75/32\",\r\n \"191.237.232.76/31\",\r\n\ + \ \"191.237.232.78/32\",\r\n \"191.237.232.235/32\",\r\n\ + \ \"191.237.232.236/31\",\r\n \"191.237.240.43/32\",\r\n\ + \ \"191.237.240.44/32\",\r\n \"191.237.240.46/32\",\r\n\ + \ \"191.238.6.43/32\",\r\n \"191.238.6.44/31\",\r\n \ + \ \"191.238.6.46/32\",\r\n \"191.238.68.11/32\",\r\n \ + \ \"191.238.68.12/31\",\r\n \"191.238.68.14/32\",\r\n \ + \ \"191.238.224.203/32\",\r\n \"191.238.230.40/32\",\r\n \ + \ \"191.239.12.154/32\",\r\n \"191.239.189.48/32\",\r\n \ + \ \"191.239.192.109/32\",\r\n \"191.239.224.107/32\",\r\n \ + \ \"191.239.224.108/31\",\r\n \"191.239.224.110/32\",\r\n \ + \ \"207.46.139.82/32\",\r\n \"207.46.140.180/32\",\r\n \ + \ \"207.46.153.182/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.AustraliaCentral\",\r\n \"id\": \"Sql.AustraliaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.36.104.0/27\",\r\n \"20.36.105.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.AustraliaCentral2\"\ + ,\r\n \"id\": \"Sql.AustraliaCentral2\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\ + \n \"addressPrefixes\": [\r\n \"20.36.112.0/27\",\r\n \ + \ \"20.36.113.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Sql.AustraliaEast\",\r\n \"id\": \"Sql.AustraliaEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiaeast\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.70.112.0/27\",\r\n \"13.70.113.0/27\",\r\n\ + \ \"13.75.149.87/32\",\r\n \"40.79.160.0/27\",\r\n \ + \ \"40.79.161.0/27\",\r\n \"40.79.168.0/27\",\r\n \"\ + 40.79.169.0/27\",\r\n \"40.126.228.153/32\",\r\n \"40.126.230.223/32\"\ + ,\r\n \"40.126.232.113/32\",\r\n \"40.126.233.152/32\",\r\ + \n \"40.126.250.24/32\",\r\n \"52.237.219.227/32\",\r\n\ + \ \"104.210.105.215/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.AustraliaSoutheast\",\r\n \"id\": \"Sql.AustraliaSoutheast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n\ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \ + \ \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\ + \n \"13.70.148.251/32\",\r\n \"13.70.155.163/32\",\r\n \ + \ \"13.73.109.251/32\",\r\n \"13.77.7.78/32\",\r\n \ + \ \"13.77.48.0/27\",\r\n \"13.77.49.0/27\",\r\n \"40.127.82.69/32\"\ + ,\r\n \"40.127.83.164/32\",\r\n \"52.255.48.161/32\",\r\n\ + \ \"191.239.189.48/32\",\r\n \"191.239.192.109/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.BrazilSouth\"\ + ,\r\n \"id\": \"Sql.BrazilSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n \ + \ \"addressPrefixes\": [\r\n \"104.41.11.5/32\",\r\n \ + \ \"104.41.13.213/32\",\r\n \"104.41.13.233/32\",\r\n \ + \ \"104.41.36.39/32\",\r\n \"104.41.56.218/32\",\r\n \"\ + 104.41.57.82/32\",\r\n \"104.41.59.170/32\",\r\n \"191.233.200.0/27\"\ + ,\r\n \"191.233.201.0/27\",\r\n \"191.234.144.0/27\",\r\n\ + \ \"191.234.145.0/27\",\r\n \"191.234.152.0/27\",\r\n \ + \ \"191.234.153.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Sql.CanadaCentral\",\r\n \"id\": \"Sql.CanadaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.71.168.0/27\",\r\n \"13.71.169.0/27\",\r\n\ + \ \"13.88.249.189/32\",\r\n \"13.88.254.42/32\",\r\n \ + \ \"20.38.144.0/27\",\r\n \"20.38.145.0/27\",\r\n \ + \ \"40.85.224.249/32\",\r\n \"40.85.225.5/32\",\r\n \"52.228.24.103/32\"\ + ,\r\n \"52.228.35.221/32\",\r\n \"52.228.39.117/32\",\r\n\ + \ \"52.237.28.86/32\",\r\n \"52.246.152.0/27\",\r\n \ + \ \"52.246.153.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.CanadaEast\",\r\n \"id\": \"Sql.CanadaEast\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"canadaeast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.104.0/27\",\r\n \"40.69.105.0/27\",\r\n \"\ + 40.86.226.166/32\",\r\n \"40.86.226.230/32\",\r\n \"52.229.122.195/32\"\ + ,\r\n \"52.229.123.147/32\",\r\n \"52.229.124.23/32\",\r\ + \n \"52.242.26.53/32\",\r\n \"52.242.29.91/32\",\r\n \ + \ \"52.242.30.154/32\",\r\n \"52.242.36.107/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.CentralIndia\"\ + ,\r\n \"id\": \"Sql.CentralIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"20.192.96.0/27\"\ + ,\r\n \"20.192.97.0/27\",\r\n \"40.80.48.0/27\",\r\n \ + \ \"40.80.49.0/27\",\r\n \"52.172.217.233/32\",\r\n \ + \ \"52.172.221.154/32\",\r\n \"104.211.85.0/27\",\r\n \ + \ \"104.211.86.0/27\",\r\n \"104.211.96.159/32\",\r\n \"\ + 104.211.96.160/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"Sql.CentralUS\",\r\n \"id\": \"Sql.CentralUS\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"centralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.215.62/32\",\r\n \"13.89.36.110/32\",\r\n \ + \ \"13.89.37.61/32\",\r\n \"13.89.57.50/32\",\r\n \"13.89.57.115/32\"\ + ,\r\n \"13.89.168.0/26\",\r\n \"13.89.169.0/26\",\r\n \ + \ \"23.99.160.139/32\",\r\n \"23.99.160.140/31\",\r\n \ + \ \"23.99.160.142/32\",\r\n \"23.99.205.183/32\",\r\n \ + \ \"40.69.132.90/32\",\r\n \"40.69.143.202/32\",\r\n \ + \ \"40.69.169.120/32\",\r\n \"40.69.189.48/32\",\r\n \"\ + 40.77.30.201/32\",\r\n \"40.86.75.134/32\",\r\n \"40.113.200.119/32\"\ + ,\r\n \"40.122.205.105/32\",\r\n \"40.122.215.111/32\",\r\ + \n \"52.165.184.67/32\",\r\n \"52.173.205.59/32\",\r\n \ + \ \"52.176.43.167/32\",\r\n \"52.176.59.12/32\",\r\n \ + \ \"52.176.95.237/32\",\r\n \"52.176.100.98/32\",\r\n \ + \ \"52.182.136.0/26\",\r\n \"52.182.137.0/26\",\r\n \"\ + 104.43.164.21/32\",\r\n \"104.43.164.247/32\",\r\n \"104.43.203.72/32\"\ + ,\r\n \"104.208.21.0/26\",\r\n \"104.208.22.0/26\",\r\n\ + \ \"104.208.28.16/32\",\r\n \"104.208.28.53/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.CentralUSEUAP\"\ + ,\r\n \"id\": \"Sql.CentralUSEUAP\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"52.180.176.154/31\"\ + ,\r\n \"52.180.183.226/32\",\r\n \"168.61.136.0/27\",\r\n\ + \ \"168.61.137.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Sql.EastAsia\",\r\n \"id\": \"Sql.EastAsia\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.75.32.0/26\",\r\n \"13.75.33.0/26\",\r\n \"13.75.105.141/32\"\ + ,\r\n \"13.75.106.191/32\",\r\n \"13.75.108.188/32\",\r\n\ + \ \"23.97.68.51/32\",\r\n \"23.97.74.21/32\",\r\n \ + \ \"23.97.78.163/32\",\r\n \"23.99.102.124/32\",\r\n \ + \ \"23.99.118.196/32\",\r\n \"52.175.33.150/32\",\r\n \"\ + 191.234.2.139/32\",\r\n \"191.234.2.140/31\",\r\n \"191.234.2.142/32\"\ + ,\r\n \"207.46.139.82/32\",\r\n \"207.46.140.180/32\",\r\ + \n \"207.46.153.182/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.EastUS\",\r\n \"id\": \"Sql.EastUS\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"eastus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.96.89.109/32\",\r\n \"23.96.106.191/32\",\r\n \ + \ \"40.71.8.0/26\",\r\n \"40.71.8.192/26\",\r\n \"40.71.9.0/26\"\ + ,\r\n \"40.71.9.192/26\",\r\n \"40.71.196.33/32\",\r\n \ + \ \"40.71.211.227/32\",\r\n \"40.71.226.18/32\",\r\n \ + \ \"40.76.2.172/32\",\r\n \"40.76.26.90/32\",\r\n \"\ + 40.76.42.44/32\",\r\n \"40.76.65.222/32\",\r\n \"40.76.66.9/32\"\ + ,\r\n \"40.76.193.221/32\",\r\n \"40.76.209.171/32\",\r\n\ + \ \"40.76.219.185/32\",\r\n \"40.78.224.0/26\",\r\n \ + \ \"40.78.224.128/26\",\r\n \"40.78.225.0/26\",\r\n \ + \ \"40.78.225.128/26\",\r\n \"40.79.152.0/26\",\r\n \"\ + 40.79.152.192/26\",\r\n \"40.79.153.0/26\",\r\n \"40.79.153.192/26\"\ + ,\r\n \"40.114.40.118/32\",\r\n \"40.114.43.106/32\",\r\n\ + \ \"40.114.45.195/32\",\r\n \"40.114.46.128/32\",\r\n \ + \ \"40.114.46.212/32\",\r\n \"40.114.81.142/32\",\r\n \ + \ \"40.117.42.73/32\",\r\n \"40.117.44.71/32\",\r\n \ + \ \"40.117.90.115/32\",\r\n \"40.117.97.189/32\",\r\n \"\ + 40.121.143.204/32\",\r\n \"40.121.149.49/32\",\r\n \"40.121.154.241/32\"\ + ,\r\n \"40.121.158.30/32\",\r\n \"52.168.166.153/32\",\r\ + \n \"52.168.169.124/32\",\r\n \"52.168.183.223/32\",\r\n\ + \ \"52.170.41.199/32\",\r\n \"52.170.97.16/32\",\r\n \ + \ \"52.170.98.29/32\",\r\n \"52.179.16.95/32\",\r\n \ + \ \"104.41.150.1/32\",\r\n \"104.41.152.74/32\",\r\n \"\ + 104.45.158.30/32\",\r\n \"137.135.109.63/32\",\r\n \"191.237.20.112/32\"\ + ,\r\n \"191.237.82.74/32\",\r\n \"191.238.6.43/32\",\r\n\ + \ \"191.238.6.44/31\",\r\n \"191.238.6.46/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.EastUS2\",\r\n\ + \ \"id\": \"Sql.EastUS2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"eastus2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.68.22.44/32\",\r\n \"\ + 13.68.30.216/32\",\r\n \"13.68.87.133/32\",\r\n \"23.102.206.35/32\"\ + ,\r\n \"23.102.206.36/31\",\r\n \"40.70.144.0/26\",\r\n\ + \ \"40.70.145.0/26\",\r\n \"40.79.84.180/32\",\r\n \ + \ \"40.84.5.64/32\",\r\n \"40.84.54.249/32\",\r\n \"\ + 52.167.104.0/26\",\r\n \"52.167.105.0/26\",\r\n \"52.167.117.226/32\"\ + ,\r\n \"52.177.185.181/32\",\r\n \"52.177.197.103/32\",\r\ + \n \"52.177.200.215/32\",\r\n \"52.179.157.248/32\",\r\n\ + \ \"52.179.165.160/32\",\r\n \"52.179.167.70/32\",\r\n \ + \ \"52.179.178.184/32\",\r\n \"52.184.192.175/32\",\r\n \ + \ \"52.184.231.0/32\",\r\n \"52.225.222.124/32\",\r\n \ + \ \"104.46.100.189/32\",\r\n \"104.46.108.148/32\",\r\n \ + \ \"104.208.149.0/26\",\r\n \"104.208.150.0/26\",\r\n \ + \ \"104.208.161.78/32\",\r\n \"104.208.163.201/32\",\r\n \ + \ \"104.208.233.240/32\",\r\n \"104.208.238.55/32\",\r\n \ + \ \"104.208.241.224/32\",\r\n \"104.209.186.94/32\",\r\n \ + \ \"191.239.224.107/32\",\r\n \"191.239.224.108/31\",\r\n\ + \ \"191.239.224.110/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.EastUS2EUAP\",\r\n \"id\": \"Sql.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.74.144.0/27\",\r\n \"40.74.145.0/27\",\r\n\ + \ \"40.75.32.0/27\",\r\n \"40.75.33.0/27\",\r\n \ + \ \"52.138.88.0/27\",\r\n \"52.138.89.0/27\",\r\n \"52.225.188.46/32\"\ + ,\r\n \"52.225.188.113/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"Sql.EastUS2Stage\",\r\n \"id\": \"Sql.EastUS2Stage\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"137.116.31.224/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.FranceCentral\",\r\n \"id\": \"Sql.FranceCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.79.128.0/27\",\r\n \"40.79.129.0/27\",\r\n\ + \ \"40.79.136.0/27\",\r\n \"40.79.137.0/27\",\r\n \ + \ \"40.79.144.0/27\",\r\n \"40.79.145.0/27\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"Sql.FranceSouth\",\r\n \ + \ \"id\": \"Sql.FranceSouth\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"southfrance\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\"\ + ,\r\n \"addressPrefixes\": [\r\n \"40.79.176.0/27\",\r\n \ + \ \"40.79.177.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.GermanyNorth\",\r\n \"id\": \"Sql.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.56.0/27\",\r\n \"51.116.57.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.GermanyWestCentral\"\ + ,\r\n \"id\": \"Sql.GermanyWestCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.116.152.0/27\"\ + ,\r\n \"51.116.153.0/27\",\r\n \"51.116.240.0/27\",\r\n\ + \ \"51.116.241.0/27\",\r\n \"51.116.248.0/27\",\r\n \ + \ \"51.116.249.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.JapanEast\",\r\n \"id\": \"Sql.JapanEast\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.78.61.196/32\",\r\n \"13.78.104.0/27\",\r\n \"\ + 13.78.105.0/27\",\r\n \"13.78.121.203/32\",\r\n \"23.102.69.95/32\"\ + ,\r\n \"23.102.71.13/32\",\r\n \"23.102.74.190/32\",\r\n\ + \ \"40.79.184.0/27\",\r\n \"40.79.185.0/27\",\r\n \ + \ \"40.79.192.0/27\",\r\n \"40.79.193.0/27\",\r\n \"\ + 52.185.152.149/32\",\r\n \"52.243.32.19/32\",\r\n \"52.243.43.186/32\"\ + ,\r\n \"104.41.168.103/32\",\r\n \"104.41.169.34/32\",\r\ + \n \"191.237.240.43/32\",\r\n \"191.237.240.44/32\",\r\n\ + \ \"191.237.240.46/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.JapanWest\",\r\n \"id\": \"Sql.JapanWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japanwest\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"40.74.96.0/27\"\ + ,\r\n \"40.74.97.0/27\",\r\n \"40.74.114.22/32\",\r\n \ + \ \"40.74.115.153/32\",\r\n \"40.74.135.185/32\",\r\n \ + \ \"104.214.148.156/32\",\r\n \"104.214.150.17/32\",\r\n \ + \ \"191.238.68.11/32\",\r\n \"191.238.68.12/31\",\r\n \ + \ \"191.238.68.14/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.KoreaCentral\",\r\n \"id\": \"Sql.KoreaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"koreacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.44.24.0/27\",\r\n \"20.44.25.0/27\",\r\n \"20.194.64.0/27\"\ + ,\r\n \"20.194.65.0/27\",\r\n \"52.231.16.0/27\",\r\n \ + \ \"52.231.17.0/27\",\r\n \"52.231.32.42/31\",\r\n \ + \ \"52.231.39.56/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Sql.KoreaSouth\",\r\n \"id\": \"Sql.KoreaSouth\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.231.144.0/27\",\r\n \"52.231.145.0/27\",\r\n \ + \ \"52.231.200.86/31\",\r\n \"52.231.206.133/32\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"Sql.NorthCentralUS\",\r\n\ + \ \"id\": \"Sql.NorthCentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"23.96.178.199/32\"\ + ,\r\n \"23.96.202.229/32\",\r\n \"23.96.204.249/32\",\r\n\ + \ \"23.96.205.215/32\",\r\n \"23.96.214.69/32\",\r\n \ + \ \"23.96.243.243/32\",\r\n \"23.96.247.75/32\",\r\n \ + \ \"23.96.249.37/32\",\r\n \"23.96.250.178/32\",\r\n \ + \ \"23.98.55.75/32\",\r\n \"23.101.165.167/32\",\r\n \"\ + 23.101.167.45/32\",\r\n \"23.101.170.98/32\",\r\n \"52.162.104.0/26\"\ + ,\r\n \"52.162.105.0/26\",\r\n \"52.162.125.1/32\",\r\n\ + \ \"52.162.241.250/32\",\r\n \"65.52.208.91/32\",\r\n \ + \ \"65.52.213.108/32\",\r\n \"65.52.214.127/32\",\r\n \ + \ \"65.52.218.82/32\",\r\n \"157.55.208.150/32\",\r\n \ + \ \"168.62.232.188/32\",\r\n \"168.62.235.49/32\",\r\n \ + \ \"168.62.235.241/32\",\r\n \"168.62.239.29/32\",\r\n \ + \ \"191.236.148.44/32\",\r\n \"191.236.153.120/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"Sql.NorthCentralUSStage\"\ + ,\r\n \"id\": \"Sql.NorthCentralUSStage\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"168.62.115.112/28\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.NorthEurope\"\ + ,\r\n \"id\": \"Sql.NorthEurope\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.69.224.0/26\"\ + ,\r\n \"13.69.224.192/26\",\r\n \"13.69.225.0/26\",\r\n\ + \ \"13.69.225.192/26\",\r\n \"13.74.104.64/26\",\r\n \ + \ \"13.74.104.128/26\",\r\n \"13.74.105.0/26\",\r\n \ + \ \"13.74.105.128/26\",\r\n \"23.102.16.130/32\",\r\n \ + \ \"23.102.23.219/32\",\r\n \"23.102.25.199/32\",\r\n \"\ + 23.102.52.155/32\",\r\n \"23.102.57.142/32\",\r\n \"23.102.62.171/32\"\ + ,\r\n \"40.85.102.50/32\",\r\n \"40.113.14.53/32\",\r\n\ + \ \"40.113.16.190/32\",\r\n \"40.113.17.148/32\",\r\n \ + \ \"40.113.20.38/32\",\r\n \"40.113.93.91/32\",\r\n \ + \ \"40.127.128.10/32\",\r\n \"40.127.135.67/32\",\r\n \ + \ \"40.127.137.209/32\",\r\n \"40.127.141.194/32\",\r\n \ + \ \"40.127.177.139/32\",\r\n \"40.127.190.50/32\",\r\n \ + \ \"52.138.224.0/26\",\r\n \"52.138.224.128/26\",\r\n \"\ + 52.138.225.0/26\",\r\n \"52.138.225.128/26\",\r\n \"65.52.225.245/32\"\ + ,\r\n \"65.52.226.209/32\",\r\n \"104.41.202.30/32\",\r\n\ + \ \"104.41.205.195/32\",\r\n \"104.41.208.104/32\",\r\n\ + \ \"104.41.210.68/32\",\r\n \"104.41.211.98/32\",\r\n \ + \ \"137.135.186.126/32\",\r\n \"137.135.189.158/32\",\r\n\ + \ \"137.135.205.85/32\",\r\n \"137.135.213.9/32\",\r\n \ + \ \"138.91.48.99/32\",\r\n \"138.91.58.227/32\",\r\n \ + \ \"191.235.170.58/32\",\r\n \"191.235.193.75/32\",\r\n \ + \ \"191.235.193.76/31\",\r\n \"191.235.193.78/32\",\r\n \ + \ \"191.235.193.139/32\",\r\n \"191.235.193.140/31\",\r\n \ + \ \"191.235.209.79/32\",\r\n \"191.237.219.202/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.NorwayEast\"\ + ,\r\n \"id\": \"Sql.NorwayEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.120.96.0/27\"\ + ,\r\n \"51.120.97.0/27\",\r\n \"51.120.104.0/27\",\r\n \ + \ \"51.120.105.0/27\",\r\n \"51.120.208.0/27\",\r\n \ + \ \"51.120.209.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Sql.NorwayWest\",\r\n \"id\": \"Sql.NorwayWest\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"norwayw\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.120.216.0/27\",\r\n \"51.120.217.0/27\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"Sql.SouthAfricaNorth\",\r\ + \n \"id\": \"Sql.SouthAfricaNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southafricanorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"102.133.120.0/27\"\ + ,\r\n \"102.133.121.0/27\",\r\n \"102.133.152.0/27\",\r\n\ + \ \"102.133.153.0/27\",\r\n \"102.133.248.0/27\",\r\n \ + \ \"102.133.249.0/27\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Sql.SouthAfricaWest\",\r\n \"id\": \"Sql.SouthAfricaWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricawest\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"102.133.24.0/27\",\r\n \"102.133.25.0/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.SouthCentralUS\"\ + ,\r\n \"id\": \"Sql.SouthCentralUS\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.65.31.249/32\"\ + ,\r\n \"13.65.39.207/32\",\r\n \"13.65.85.183/32\",\r\n\ + \ \"13.65.200.105/32\",\r\n \"13.65.209.243/32\",\r\n \ + \ \"13.65.253.67/32\",\r\n \"13.66.60.72/32\",\r\n \ + \ \"13.66.60.111/32\",\r\n \"13.66.62.124/32\",\r\n \"\ + 13.84.223.76/32\",\r\n \"13.85.65.48/32\",\r\n \"13.85.68.115/32\"\ + ,\r\n \"13.85.69.107/32\",\r\n \"20.45.120.0/27\",\r\n \ + \ \"20.45.121.0/27\",\r\n \"20.49.88.0/27\",\r\n \ + \ \"20.49.89.0/27\",\r\n \"23.98.162.75/32\",\r\n \"23.98.162.76/31\"\ + ,\r\n \"23.98.162.78/32\",\r\n \"23.98.170.75/32\",\r\n\ + \ \"23.98.170.76/31\",\r\n \"23.102.172.251/32\",\r\n \ + \ \"23.102.173.220/32\",\r\n \"23.102.174.146/32\",\r\n \ + \ \"23.102.179.187/32\",\r\n \"40.74.254.156/32\",\r\n \ + \ \"40.84.153.95/32\",\r\n \"40.84.155.210/32\",\r\n \ + \ \"40.84.156.165/32\",\r\n \"40.84.191.1/32\",\r\n \"\ + 40.84.193.16/32\",\r\n \"40.84.195.189/32\",\r\n \"40.84.231.203/32\"\ + ,\r\n \"40.124.8.76/32\",\r\n \"52.171.56.10/32\",\r\n \ + \ \"52.183.250.62/32\",\r\n \"104.214.16.0/26\",\r\n \ + \ \"104.214.16.192/26\",\r\n \"104.214.17.0/26\",\r\n \ + \ \"104.214.17.192/26\",\r\n \"104.214.67.25/32\",\r\n \ + \ \"104.214.73.137/32\",\r\n \"104.214.78.242/32\",\r\n \ + \ \"191.238.224.203/32\",\r\n \"191.238.230.40/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.SoutheastAsia\"\ + ,\r\n \"id\": \"Sql.SoutheastAsia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"13.67.16.0/26\"\ + ,\r\n \"13.67.17.0/26\",\r\n \"13.67.48.255/32\",\r\n \ + \ \"13.67.56.134/32\",\r\n \"13.67.59.217/32\",\r\n \ + \ \"13.76.90.3/32\",\r\n \"13.76.247.54/32\",\r\n \"\ + 23.98.80.0/26\",\r\n \"23.98.81.0/26\",\r\n \"23.100.117.95/32\"\ + ,\r\n \"23.100.119.70/32\",\r\n \"23.101.18.228/32\",\r\n\ + \ \"40.78.232.0/26\",\r\n \"40.78.233.0/26\",\r\n \ + \ \"52.187.15.214/32\",\r\n \"52.187.76.130/32\",\r\n \ + \ \"104.43.10.74/32\",\r\n \"104.43.15.0/32\",\r\n \"104.215.195.14/32\"\ + ,\r\n \"104.215.196.52/32\",\r\n \"111.221.106.161/32\"\ + ,\r\n \"137.116.129.110/32\",\r\n \"168.63.175.68/32\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.SouthIndia\"\ + ,\r\n \"id\": \"Sql.SouthIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n \ + \ \"addressPrefixes\": [\r\n \"40.78.192.0/27\",\r\n \ + \ \"40.78.193.0/27\",\r\n \"52.172.24.47/32\",\r\n \"\ + 52.172.43.208/32\",\r\n \"104.211.224.146/31\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"Sql.SwitzerlandNorth\",\r\n\ + \ \"id\": \"Sql.SwitzerlandNorth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"51.107.56.0/27\"\ + ,\r\n \"51.107.57.0/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.SwitzerlandWest\",\r\n \"id\": \"Sql.SwitzerlandWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.107.152.0/27\",\r\n \"51.107.153.0/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.UAECentral\"\ + ,\r\n \"id\": \"Sql.UAECentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"20.37.72.64/27\"\ + ,\r\n \"20.37.73.64/27\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Sql.UAENorth\",\r\n \"id\": \"Sql.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.120.72.0/27\",\r\n \"40.120.73.0/27\",\r\n\ + \ \"65.52.248.0/27\",\r\n \"65.52.249.0/27\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.UKNorth\",\r\n\ + \ \"id\": \"Sql.UKNorth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uknorth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n\ + \ \"systemService\": \"AzureSQL\",\r\n \"addressPrefixes\":\ + \ [\r\n \"13.87.97.210/32\",\r\n \"13.87.97.228/32\",\r\n\ + \ \"13.87.97.237/32\",\r\n \"13.87.120.0/27\",\r\n \ + \ \"13.87.121.0/27\",\r\n \"51.142.211.129/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"Sql.UKSouth\",\r\n \ + \ \"id\": \"Sql.UKSouth\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"uksouth\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n \ + \ \"addressPrefixes\": [\r\n \"51.105.64.0/27\",\r\n \"\ + 51.105.65.0/27\",\r\n \"51.105.72.0/27\",\r\n \"51.105.73.0/27\"\ + ,\r\n \"51.140.77.9/32\",\r\n \"51.140.114.26/32\",\r\n\ + \ \"51.140.115.150/32\",\r\n \"51.140.144.0/27\",\r\n \ + \ \"51.140.145.0/27\",\r\n \"51.140.180.9/32\",\r\n \ + \ \"51.140.183.238/32\",\r\n \"51.140.184.11/32\",\r\n \ + \ \"51.140.184.12/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Sql.UKSouth2\",\r\n \"id\": \"Sql.UKSouth2\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"uksouth2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureSQL\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.16.64/27\",\r\n \ + \ \"13.87.17.0/27\",\r\n \"13.87.33.234/32\",\r\n \ + \ \"13.87.34.7/32\",\r\n \"13.87.34.19/32\",\r\n \"13.87.38.138/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.UKWest\"\ + ,\r\n \"id\": \"Sql.UKWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\ + \n \"addressPrefixes\": [\r\n \"51.140.208.64/27\",\r\n \ + \ \"51.140.209.0/27\",\r\n \"51.141.8.11/32\",\r\n \ + \ \"51.141.8.12/32\",\r\n \"51.141.15.53/32\",\r\n \"\ + 51.141.25.212/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"Sql.WestCentralUS\",\r\n \"id\": \"Sql.WestCentralUS\",\r\n\ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.192.0/27\",\r\n \"13.71.193.0/27\",\r\n \"\ + 13.78.144.57/32\",\r\n \"13.78.145.25/32\",\r\n \"13.78.148.71/32\"\ + ,\r\n \"13.78.151.189/32\",\r\n \"13.78.151.207/32\",\r\n\ + \ \"13.78.178.116/32\",\r\n \"13.78.178.151/32\",\r\n \ + \ \"13.78.248.32/27\",\r\n \"52.161.15.204/32\",\r\n \ + \ \"52.161.100.158/32\",\r\n \"52.161.105.228/32\",\r\n \ + \ \"52.161.128.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Sql.WestEurope\",\r\n \"id\": \"Sql.WestEurope\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureSQL\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.69.104.0/26\",\r\n \"13.69.104.192/26\",\r\n \ + \ \"13.69.105.0/26\",\r\n \"13.69.105.192/26\",\r\n \"23.97.167.46/32\"\ + ,\r\n \"23.97.169.19/32\",\r\n \"23.97.219.82/32\",\r\n\ + \ \"23.97.221.176/32\",\r\n \"23.101.64.10/32\",\r\n \ + \ \"40.68.37.158/32\",\r\n \"40.68.215.206/32\",\r\n \ + \ \"40.68.220.16/32\",\r\n \"40.74.51.145/32\",\r\n \"\ + 40.74.53.36/32\",\r\n \"40.74.60.91/32\",\r\n \"40.114.240.125/32\"\ + ,\r\n \"40.114.240.162/32\",\r\n \"40.115.37.61/32\",\r\n\ + \ \"40.115.51.118/32\",\r\n \"40.115.52.141/32\",\r\n \ + \ \"40.115.53.255/32\",\r\n \"40.115.61.208/32\",\r\n \ + \ \"40.118.12.208/32\",\r\n \"52.166.76.0/32\",\r\n \ + \ \"52.166.131.195/32\",\r\n \"52.236.184.0/27\",\r\n \"\ + 52.236.184.128/25\",\r\n \"52.236.185.0/27\",\r\n \"52.236.185.128/25\"\ + ,\r\n \"104.40.155.247/32\",\r\n \"104.40.168.64/26\",\r\ + \n \"104.40.168.192/26\",\r\n \"104.40.169.0/27\",\r\n \ + \ \"104.40.169.128/25\",\r\n \"104.40.180.164/32\",\r\n \ + \ \"104.40.220.28/32\",\r\n \"104.40.230.18/32\",\r\n \ + \ \"104.40.232.54/32\",\r\n \"104.40.237.111/32\",\r\n \ + \ \"104.45.11.99/32\",\r\n \"104.45.14.115/32\",\r\n \ + \ \"104.46.38.143/32\",\r\n \"104.46.40.24/32\",\r\n \"\ + 104.47.157.97/32\",\r\n \"137.116.203.91/32\",\r\n \"168.63.13.214/32\"\ + ,\r\n \"168.63.98.91/32\",\r\n \"191.233.69.227/32\",\r\n\ + \ \"191.233.90.117/32\",\r\n \"191.237.232.75/32\",\r\n\ + \ \"191.237.232.76/31\",\r\n \"191.237.232.78/32\",\r\n\ + \ \"191.237.232.235/32\",\r\n \"191.237.232.236/31\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.WestIndia\"\ + ,\r\n \"id\": \"Sql.WestIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureSQL\",\r\n \"addressPrefixes\": [\r\n \"104.211.144.0/27\"\ + ,\r\n \"104.211.145.0/27\",\r\n \"104.211.160.80/31\",\r\ + \n \"104.211.185.58/32\",\r\n \"104.211.190.46/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.WestUS\"\ + ,\r\n \"id\": \"Sql.WestUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\ + \n \"addressPrefixes\": [\r\n \"13.86.216.0/25\",\r\n \ + \ \"13.86.216.128/26\",\r\n \"13.86.216.192/27\",\r\n \ + \ \"13.86.217.0/25\",\r\n \"13.86.217.128/26\",\r\n \"\ + 13.86.217.192/27\",\r\n \"13.88.14.200/32\",\r\n \"13.88.29.70/32\"\ + ,\r\n \"13.91.4.219/32\",\r\n \"13.91.6.136/32\",\r\n \ + \ \"13.91.41.153/32\",\r\n \"13.91.44.56/32\",\r\n \ + \ \"13.91.46.83/32\",\r\n \"13.91.47.72/32\",\r\n \"13.93.165.251/32\"\ + ,\r\n \"13.93.237.158/32\",\r\n \"23.99.4.210/32\",\r\n\ + \ \"23.99.4.248/32\",\r\n \"23.99.10.185/32\",\r\n \ + \ \"23.99.34.75/32\",\r\n \"23.99.34.76/31\",\r\n \"\ + 23.99.34.78/32\",\r\n \"23.99.37.235/32\",\r\n \"23.99.37.236/32\"\ + ,\r\n \"23.99.57.14/32\",\r\n \"23.99.80.243/32\",\r\n \ + \ \"23.99.89.212/32\",\r\n \"23.99.90.75/32\",\r\n \ + \ \"23.99.91.130/32\",\r\n \"40.78.16.122/32\",\r\n \"\ + 40.78.23.252/32\",\r\n \"40.78.31.250/32\",\r\n \"40.78.57.109/32\"\ + ,\r\n \"40.78.101.91/32\",\r\n \"40.78.110.18/32\",\r\n\ + \ \"40.78.111.189/32\",\r\n \"40.83.178.165/32\",\r\n \ + \ \"40.83.186.249/32\",\r\n \"40.112.139.250/32\",\r\n \ + \ \"40.112.240.0/27\",\r\n \"40.112.246.0/27\",\r\n \ + \ \"40.118.129.167/32\",\r\n \"40.118.170.1/32\",\r\n \ + \ \"40.118.209.206/32\",\r\n \"40.118.244.227/32\",\r\n \ + \ \"40.118.249.123/32\",\r\n \"40.118.250.19/32\",\r\n \"\ + 104.40.28.188/32\",\r\n \"104.40.49.103/32\",\r\n \"104.40.54.130/32\"\ + ,\r\n \"104.40.82.151/32\",\r\n \"104.42.120.235/32\",\r\ + \n \"104.42.127.95/32\",\r\n \"104.42.136.93/32\",\r\n \ + \ \"104.42.188.130/32\",\r\n \"104.42.192.190/32\",\r\n \ + \ \"104.42.199.221/32\",\r\n \"104.42.231.253/32\",\r\n \ + \ \"104.42.237.198/32\",\r\n \"104.42.238.205/32\",\r\n \ + \ \"104.210.32.128/32\",\r\n \"137.135.51.212/32\",\r\n \ + \ \"138.91.145.12/32\",\r\n \"138.91.160.189/32\",\r\n \ + \ \"138.91.240.14/32\",\r\n \"138.91.246.31/32\",\r\n \ + \ \"138.91.247.51/32\",\r\n \"138.91.251.139/32\",\r\n \ + \ \"191.236.119.31/32\",\r\n \"191.239.12.154/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Sql.WestUS2\",\r\n\ + \ \"id\": \"Sql.WestUS2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"westus2\",\r\n \"state\": \"GA\"\ + ,\r\n \"networkFeatures\": [\r\n \"API\",\r\n \"\ + NSG\"\r\n ],\r\n \"systemService\": \"AzureSQL\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.66.136.0/26\",\r\n \"\ + 13.66.137.0/26\",\r\n \"13.66.226.202/32\",\r\n \"13.66.229.222/32\"\ + ,\r\n \"13.66.230.18/31\",\r\n \"13.66.230.60/32\",\r\n\ + \ \"13.66.230.64/32\",\r\n \"13.66.230.103/32\",\r\n \ + \ \"40.78.240.0/26\",\r\n \"40.78.241.0/26\",\r\n \ + \ \"40.78.248.0/26\",\r\n \"40.78.249.0/26\",\r\n \"52.191.144.64/26\"\ + ,\r\n \"52.191.152.64/26\",\r\n \"52.191.172.187/32\",\r\ + \n \"52.191.174.114/32\",\r\n \"52.229.17.93/32\",\r\n \ + \ \"52.246.251.248/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"SqlManagement\",\r\n \"id\": \"SqlManagement\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"SqlManagement\",\r\n \"addressPrefixes\": [\r\n\ + \ \"13.64.155.40/32\",\r\n \"13.66.140.96/27\",\r\n \ + \ \"13.66.141.192/27\",\r\n \"13.67.8.192/27\",\r\n \ + \ \"13.67.10.32/27\",\r\n \"13.69.64.96/27\",\r\n \"13.69.67.0/27\"\ + ,\r\n \"13.69.106.96/27\",\r\n \"13.69.107.32/27\",\r\n\ + \ \"13.69.227.96/27\",\r\n \"13.69.229.192/27\",\r\n \ + \ \"13.70.72.160/27\",\r\n \"13.70.73.224/27\",\r\n \ + \ \"13.71.119.167/32\",\r\n \"13.71.123.234/32\",\r\n \ + \ \"13.71.170.160/27\",\r\n \"13.71.173.96/27\",\r\n \"\ + 13.71.195.0/27\",\r\n \"13.71.196.96/27\",\r\n \"13.73.240.192/27\"\ + ,\r\n \"13.73.242.0/27\",\r\n \"13.73.249.176/28\",\r\n\ + \ \"13.74.107.96/27\",\r\n \"13.74.107.224/27\",\r\n \ + \ \"13.75.36.32/27\",\r\n \"13.75.39.32/27\",\r\n \ + \ \"13.77.50.192/27\",\r\n \"13.77.53.0/27\",\r\n \"13.78.106.224/27\"\ + ,\r\n \"13.78.109.64/27\",\r\n \"13.78.181.246/32\",\r\n\ + \ \"13.78.182.82/32\",\r\n \"13.84.52.76/32\",\r\n \ + \ \"13.86.219.96/27\",\r\n \"13.87.39.133/32\",\r\n \ + \ \"13.87.39.173/32\",\r\n \"13.87.56.192/27\",\r\n \"13.87.58.0/27\"\ + ,\r\n \"13.87.122.192/27\",\r\n \"13.87.124.0/27\",\r\n\ + \ \"13.89.170.224/27\",\r\n \"13.89.174.96/27\",\r\n \ + \ \"13.92.242.41/32\",\r\n \"13.94.47.38/32\",\r\n \ + \ \"13.104.248.32/27\",\r\n \"13.104.248.96/27\",\r\n \"\ + 20.36.46.202/32\",\r\n \"20.36.46.220/32\",\r\n \"20.36.75.75/32\"\ + ,\r\n \"20.36.75.114/32\",\r\n \"20.36.108.0/27\",\r\n \ + \ \"20.36.108.64/27\",\r\n \"20.36.115.160/27\",\r\n \ + \ \"20.36.115.192/27\",\r\n \"20.36.123.0/28\",\r\n \ + \ \"20.37.67.64/28\",\r\n \"20.37.76.0/27\",\r\n \"20.37.76.64/27\"\ + ,\r\n \"20.37.198.96/28\",\r\n \"20.37.227.0/28\",\r\n \ + \ \"20.38.87.208/28\",\r\n \"20.38.128.0/27\",\r\n \ + \ \"20.38.139.64/28\",\r\n \"20.38.146.192/27\",\r\n \ + \ \"20.38.147.32/27\",\r\n \"20.39.12.240/28\",\r\n \"20.40.200.176/28\"\ + ,\r\n \"20.41.67.96/28\",\r\n \"20.41.197.32/28\",\r\n \ + \ \"20.42.131.34/31\",\r\n \"20.42.230.96/28\",\r\n \ + \ \"20.43.43.176/28\",\r\n \"20.43.70.80/28\",\r\n \"\ + 20.43.120.192/27\",\r\n \"20.44.4.0/26\",\r\n \"20.44.8.128/27\"\ + ,\r\n \"20.44.16.160/27\",\r\n \"20.44.26.192/27\",\r\n\ + \ \"20.44.27.160/27\",\r\n \"20.45.75.228/32\",\r\n \ + \ \"20.45.75.230/32\",\r\n \"20.45.114.208/28\",\r\n \ + \ \"20.45.122.192/27\",\r\n \"20.45.126.32/27\",\r\n \"\ + 20.45.197.240/28\",\r\n \"20.49.83.160/27\",\r\n \"20.49.83.192/27\"\ + ,\r\n \"20.49.91.160/27\",\r\n \"20.49.99.48/28\",\r\n \ + \ \"20.49.109.64/28\",\r\n \"20.49.113.16/28\",\r\n \ + \ \"20.49.120.48/28\",\r\n \"20.50.1.224/28\",\r\n \"\ + 20.150.165.160/28\",\r\n \"20.150.170.32/27\",\r\n \"20.150.170.128/27\"\ + ,\r\n \"20.150.172.96/27\",\r\n \"20.150.178.192/26\",\r\ + \n \"20.150.186.192/26\",\r\n \"20.187.194.208/28\",\r\n\ + \ \"20.192.98.192/26\",\r\n \"20.192.165.192/28\",\r\n \ + \ \"20.192.230.16/28\",\r\n \"20.192.238.32/27\",\r\n \ + \ \"20.192.238.64/27\",\r\n \"20.194.67.128/26\",\r\n \ + \ \"23.96.185.63/32\",\r\n \"23.96.243.93/32\",\r\n \ + \ \"23.97.120.24/32\",\r\n \"23.98.82.128/27\",\r\n \"23.98.83.32/27\"\ + ,\r\n \"23.98.104.144/28\",\r\n \"23.99.97.255/32\",\r\n\ + \ \"40.64.132.112/28\",\r\n \"40.65.124.161/32\",\r\n \ + \ \"40.67.50.224/28\",\r\n \"40.67.58.32/27\",\r\n \ + \ \"40.67.60.32/27\",\r\n \"40.69.106.192/27\",\r\n \"\ + 40.69.108.0/27\",\r\n \"40.69.161.215/32\",\r\n \"40.70.72.228/32\"\ + ,\r\n \"40.70.146.96/27\",\r\n \"40.70.148.64/27\",\r\n\ + \ \"40.71.10.224/27\",\r\n \"40.71.13.192/27\",\r\n \ + \ \"40.71.215.148/32\",\r\n \"40.74.100.192/27\",\r\n \ + \ \"40.74.101.224/27\",\r\n \"40.74.147.0/27\",\r\n \"\ + 40.74.147.96/27\",\r\n \"40.74.147.128/27\",\r\n \"40.74.254.227/32\"\ + ,\r\n \"40.75.34.64/27\",\r\n \"40.75.35.0/27\",\r\n \ + \ \"40.78.194.192/27\",\r\n \"40.78.196.0/27\",\r\n \ + \ \"40.78.203.128/27\",\r\n \"40.78.203.192/27\",\r\n \ + \ \"40.78.226.224/27\",\r\n \"40.78.229.0/27\",\r\n \"40.78.234.64/27\"\ + ,\r\n \"40.78.234.224/27\",\r\n \"40.78.242.192/27\",\r\n\ + \ \"40.78.243.128/27\",\r\n \"40.78.250.128/27\",\r\n \ + \ \"40.78.251.64/27\",\r\n \"40.79.32.162/32\",\r\n \ + \ \"40.79.130.160/27\",\r\n \"40.79.132.0/27\",\r\n \"\ + 40.79.138.64/27\",\r\n \"40.79.138.160/27\",\r\n \"40.79.146.64/27\"\ + ,\r\n \"40.79.146.160/27\",\r\n \"40.79.154.0/27\",\r\n\ + \ \"40.79.154.224/27\",\r\n \"40.79.156.0/27\",\r\n \ + \ \"40.79.162.64/27\",\r\n \"40.79.162.160/27\",\r\n \ + \ \"40.79.170.160/27\",\r\n \"40.79.171.0/27\",\r\n \"\ + 40.79.178.192/27\",\r\n \"40.79.179.224/27\",\r\n \"40.79.186.96/27\"\ + ,\r\n \"40.79.187.128/27\",\r\n \"40.79.194.0/27\",\r\n\ + \ \"40.79.195.128/27\",\r\n \"40.80.50.192/27\",\r\n \ + \ \"40.80.51.32/27\",\r\n \"40.80.62.0/28\",\r\n \"\ + 40.80.172.32/28\",\r\n \"40.89.20.144/28\",\r\n \"40.112.243.128/27\"\ + ,\r\n \"40.120.75.192/26\",\r\n \"40.123.207.224/32\",\r\ + \n \"40.123.219.239/32\",\r\n \"40.126.238.47/32\",\r\n\ + \ \"40.127.3.232/32\",\r\n \"51.12.42.0/28\",\r\n \ + \ \"51.12.98.32/27\",\r\n \"51.12.98.128/27\",\r\n \"\ + 51.12.194.0/28\",\r\n \"51.12.202.32/27\",\r\n \"51.12.202.128/27\"\ + ,\r\n \"51.12.226.192/26\",\r\n \"51.12.234.192/26\",\r\n\ + \ \"51.104.8.192/27\",\r\n \"51.104.28.240/28\",\r\n \ + \ \"51.105.66.192/27\",\r\n \"51.105.67.128/27\",\r\n \ + \ \"51.105.74.192/27\",\r\n \"51.105.75.32/27\",\r\n \ + \ \"51.105.83.0/28\",\r\n \"51.105.90.160/28\",\r\n \"\ + 51.107.51.0/28\",\r\n \"51.107.58.32/27\",\r\n \"51.107.60.0/27\"\ + ,\r\n \"51.107.147.0/28\",\r\n \"51.107.154.32/27\",\r\n\ + \ \"51.107.156.0/27\",\r\n \"51.116.49.144/28\",\r\n \ + \ \"51.116.58.32/27\",\r\n \"51.116.60.0/27\",\r\n \ + \ \"51.116.145.144/28\",\r\n \"51.116.154.96/27\",\r\n \ + \ \"51.116.156.0/27\",\r\n \"51.116.242.192/26\",\r\n \"\ + 51.116.243.32/27\",\r\n \"51.116.250.192/27\",\r\n \"51.116.253.96/27\"\ + ,\r\n \"51.120.43.64/28\",\r\n \"51.120.98.32/27\",\r\n\ + \ \"51.120.100.0/27\",\r\n \"51.120.106.192/26\",\r\n \ + \ \"51.120.210.192/26\",\r\n \"51.120.218.32/27\",\r\n \ + \ \"51.120.218.128/27\",\r\n \"51.120.227.64/28\",\r\n \ + \ \"51.137.164.96/28\",\r\n \"51.140.121.92/32\",\r\n \ + \ \"51.140.127.51/32\",\r\n \"51.140.146.224/27\",\r\n \ + \ \"51.140.210.224/27\",\r\n \"51.140.212.32/27\",\r\n \ + \ \"51.141.38.88/32\",\r\n \"51.141.39.175/32\",\r\n \"\ + 51.142.213.97/32\",\r\n \"51.142.215.251/32\",\r\n \"51.143.195.0/28\"\ + ,\r\n \"52.136.51.80/28\",\r\n \"52.136.139.224/32\",\r\n\ + \ \"52.136.140.157/32\",\r\n \"52.138.90.96/27\",\r\n \ + \ \"52.138.226.96/27\",\r\n \"52.138.226.224/27\",\r\n \ + \ \"52.140.108.80/28\",\r\n \"52.143.136.162/32\",\r\n \ + \ \"52.143.139.82/32\",\r\n \"52.150.139.78/31\",\r\n \ + \ \"52.150.152.32/28\",\r\n \"52.162.107.128/27\",\r\n \ + \ \"52.162.110.192/27\",\r\n \"52.164.200.174/32\",\r\n \ + \ \"52.165.237.178/32\",\r\n \"52.166.50.138/32\",\r\n \ + \ \"52.167.106.96/27\",\r\n \"52.167.106.224/27\",\r\n \ + \ \"52.169.6.70/32\",\r\n \"52.172.193.99/32\",\r\n \"52.172.204.185/32\"\ + ,\r\n \"52.173.243.204/32\",\r\n \"52.175.156.251/32\",\r\ + \n \"52.182.138.224/27\",\r\n \"52.182.139.96/27\",\r\n\ + \ \"52.183.64.43/32\",\r\n \"52.185.145.40/32\",\r\n \ + \ \"52.185.154.136/32\",\r\n \"52.187.185.17/32\",\r\n \ + \ \"52.225.130.171/32\",\r\n \"52.228.84.112/28\",\r\n \ + \ \"52.230.122.197/32\",\r\n \"52.231.18.160/27\",\r\n \ + \ \"52.231.19.224/27\",\r\n \"52.231.30.200/32\",\r\n \ + \ \"52.231.34.21/32\",\r\n \"52.231.146.224/27\",\r\n \"\ + 52.231.148.32/27\",\r\n \"52.231.202.76/32\",\r\n \"52.231.206.187/32\"\ + ,\r\n \"52.233.30.2/32\",\r\n \"52.233.38.82/32\",\r\n \ + \ \"52.233.130.100/32\",\r\n \"52.235.36.131/32\",\r\n \ + \ \"52.236.186.96/27\",\r\n \"52.236.187.32/27\",\r\n \ + \ \"52.237.244.169/32\",\r\n \"52.242.36.170/32\",\r\n \ + \ \"52.243.87.200/32\",\r\n \"52.246.154.192/27\",\r\n \ + \ \"52.246.155.32/27\",\r\n \"52.255.51.21/32\",\r\n \ + \ \"65.52.252.0/27\",\r\n \"65.52.252.64/27\",\r\n \"102.133.27.224/27\"\ + ,\r\n \"102.133.28.32/27\",\r\n \"102.133.58.208/28\",\r\ + \n \"102.133.72.35/32\",\r\n \"102.133.72.42/32\",\r\n \ + \ \"102.133.122.192/27\",\r\n \"102.133.123.192/27\",\r\n\ + \ \"102.133.155.224/27\",\r\n \"102.133.156.32/27\",\r\n\ + \ \"102.133.160.35/32\",\r\n \"102.133.218.128/28\",\r\n\ + \ \"102.133.250.192/27\",\r\n \"102.133.251.32/27\",\r\n\ + \ \"104.42.96.175/32\",\r\n \"104.208.16.96/27\",\r\n \ + \ \"104.208.144.96/27\",\r\n \"104.211.81.160/27\",\r\n \ + \ \"104.211.146.192/27\",\r\n \"104.211.187.232/32\",\r\n\ + \ \"104.214.19.0/27\",\r\n \"104.214.108.80/32\",\r\n \ + \ \"104.215.17.87/32\",\r\n \"191.232.163.58/32\",\r\n \ + \ \"191.233.11.128/28\",\r\n \"191.233.54.32/27\",\r\n \ + \ \"191.233.54.192/27\",\r\n \"191.233.203.160/27\",\r\n \ + \ \"191.233.205.32/27\",\r\n \"191.234.136.64/28\",\r\n \ + \ \"191.234.146.192/26\",\r\n \"191.234.154.192/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage\",\r\n\ + \ \"id\": \"Storage\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\",\r\ + \n \"VSE\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.65.107.32/28\"\ + ,\r\n \"13.65.160.16/28\",\r\n \"13.65.160.48/28\",\r\n\ + \ \"13.65.160.64/28\",\r\n \"13.66.176.16/28\",\r\n \ + \ \"13.66.176.48/28\",\r\n \"13.66.232.64/28\",\r\n \ + \ \"13.66.232.208/28\",\r\n \"13.66.232.224/28\",\r\n \"\ + 13.66.234.0/27\",\r\n \"13.67.155.16/28\",\r\n \"13.68.120.64/28\"\ + ,\r\n \"13.68.163.32/28\",\r\n \"13.68.165.64/28\",\r\n\ + \ \"13.68.167.240/28\",\r\n \"13.69.40.16/28\",\r\n \ + \ \"13.70.99.16/28\",\r\n \"13.70.99.48/28\",\r\n \"\ + 13.70.99.64/28\",\r\n \"13.70.208.16/28\",\r\n \"13.71.200.64/28\"\ + ,\r\n \"13.71.200.96/28\",\r\n \"13.71.200.240/28\",\r\n\ + \ \"13.71.202.16/28\",\r\n \"13.71.202.32/28\",\r\n \ + \ \"13.71.202.64/27\",\r\n \"13.72.235.64/28\",\r\n \ + \ \"13.72.235.96/27\",\r\n \"13.72.235.144/28\",\r\n \"\ + 13.72.237.48/28\",\r\n \"13.72.237.64/28\",\r\n \"13.73.8.16/28\"\ + ,\r\n \"13.73.8.32/28\",\r\n \"13.74.208.64/28\",\r\n \ + \ \"13.74.208.112/28\",\r\n \"13.74.208.144/28\",\r\n \ + \ \"13.75.240.16/28\",\r\n \"13.75.240.32/28\",\r\n \ + \ \"13.75.240.64/27\",\r\n \"13.76.104.16/28\",\r\n \"\ + 13.77.8.16/28\",\r\n \"13.77.8.32/28\",\r\n \"13.77.8.64/28\"\ + ,\r\n \"13.77.8.96/28\",\r\n \"13.77.8.128/27\",\r\n \ + \ \"13.77.8.160/28\",\r\n \"13.77.8.192/27\",\r\n \ + \ \"13.77.112.16/28\",\r\n \"13.77.112.32/28\",\r\n \"13.77.112.112/28\"\ + ,\r\n \"13.77.112.128/28\",\r\n \"13.77.115.16/28\",\r\n\ + \ \"13.77.115.32/28\",\r\n \"13.77.184.64/28\",\r\n \ + \ \"13.78.152.64/28\",\r\n \"13.78.240.16/28\",\r\n \ + \ \"13.79.176.16/28\",\r\n \"13.79.176.48/28\",\r\n \"\ + 13.79.176.80/28\",\r\n \"13.82.33.32/28\",\r\n \"13.82.152.16/28\"\ + ,\r\n \"13.82.152.48/28\",\r\n \"13.82.152.80/28\",\r\n\ + \ \"13.83.72.16/28\",\r\n \"13.84.56.16/28\",\r\n \ + \ \"13.85.88.16/28\",\r\n \"13.85.200.128/28\",\r\n \"\ + 13.87.40.64/28\",\r\n \"13.87.40.96/28\",\r\n \"13.87.104.64/28\"\ + ,\r\n \"13.87.104.96/28\",\r\n \"13.88.144.112/28\",\r\n\ + \ \"13.88.144.240/28\",\r\n \"13.88.145.64/28\",\r\n \ + \ \"13.88.145.96/28\",\r\n \"13.88.145.128/28\",\r\n \ + \ \"13.93.168.80/28\",\r\n \"13.93.168.112/28\",\r\n \ + \ \"13.93.168.144/28\",\r\n \"13.95.96.176/28\",\r\n \"\ + 13.95.240.16/28\",\r\n \"13.95.240.32/28\",\r\n \"13.95.240.64/27\"\ + ,\r\n \"20.38.96.0/19\",\r\n \"20.47.0.0/18\",\r\n \ + \ \"20.60.0.0/23\",\r\n \"20.60.2.0/24\",\r\n \"20.60.4.0/22\"\ + ,\r\n \"20.60.8.0/21\",\r\n \"20.60.16.0/22\",\r\n \ + \ \"20.60.20.0/24\",\r\n \"20.150.0.0/17\",\r\n \"20.157.32.0/19\"\ + ,\r\n \"23.96.64.64/26\",\r\n \"23.97.112.64/26\",\r\n \ + \ \"23.98.49.0/26\",\r\n \"23.98.49.192/26\",\r\n \ + \ \"23.98.55.0/26\",\r\n \"23.98.55.112/28\",\r\n \"23.98.55.144/28\"\ + ,\r\n \"23.98.56.0/26\",\r\n \"23.98.57.64/26\",\r\n \ + \ \"23.98.160.64/26\",\r\n \"23.98.162.192/26\",\r\n \ + \ \"23.98.168.0/24\",\r\n \"23.98.192.64/26\",\r\n \"\ + 23.98.255.64/26\",\r\n \"23.99.32.64/26\",\r\n \"23.99.34.224/28\"\ + ,\r\n \"23.99.37.96/28\",\r\n \"23.99.47.32/28\",\r\n \ + \ \"23.99.160.64/26\",\r\n \"23.99.160.192/28\",\r\n \ + \ \"23.102.206.0/28\",\r\n \"23.102.206.128/28\",\r\n \ + \ \"23.102.206.192/28\",\r\n \"40.68.176.16/28\",\r\n \ + \ \"40.68.176.48/28\",\r\n \"40.68.232.16/28\",\r\n \"40.68.232.48/28\"\ + ,\r\n \"40.69.176.16/28\",\r\n \"40.70.88.0/28\",\r\n \ + \ \"40.71.104.16/28\",\r\n \"40.71.104.32/28\",\r\n \ + \ \"40.71.240.16/28\",\r\n \"40.78.72.16/28\",\r\n \"\ + 40.78.112.64/28\",\r\n \"40.79.8.16/28\",\r\n \"40.79.48.16/28\"\ + ,\r\n \"40.79.88.16/28\",\r\n \"40.83.24.16/28\",\r\n \ + \ \"40.83.24.80/28\",\r\n \"40.83.24.96/27\",\r\n \ + \ \"40.83.104.176/28\",\r\n \"40.83.104.208/28\",\r\n \"\ + 40.83.225.32/28\",\r\n \"40.83.227.16/28\",\r\n \"40.84.8.32/28\"\ + ,\r\n \"40.84.11.80/28\",\r\n \"40.85.105.32/28\",\r\n \ + \ \"40.85.232.64/28\",\r\n \"40.85.232.96/28\",\r\n \ + \ \"40.85.232.144/28\",\r\n \"40.85.235.32/27\",\r\n \ + \ \"40.85.235.80/28\",\r\n \"40.85.235.96/28\",\r\n \"\ + 40.86.232.64/28\",\r\n \"40.86.232.96/28\",\r\n \"40.86.232.128/28\"\ + ,\r\n \"40.86.232.176/28\",\r\n \"40.86.232.192/28\",\r\n\ + \ \"40.112.152.16/28\",\r\n \"40.112.224.16/28\",\r\n \ + \ \"40.112.224.48/28\",\r\n \"40.113.27.176/28\",\r\n \ + \ \"40.114.152.16/28\",\r\n \"40.114.152.48/28\",\r\n \ + \ \"40.115.169.32/28\",\r\n \"40.115.175.16/28\",\r\n \ + \ \"40.115.175.32/28\",\r\n \"40.115.227.80/28\",\r\n \"\ + 40.115.229.16/28\",\r\n \"40.115.229.32/28\",\r\n \"40.115.231.64/27\"\ + ,\r\n \"40.115.231.112/28\",\r\n \"40.115.231.128/28\",\r\ + \n \"40.116.120.16/28\",\r\n \"40.116.232.16/28\",\r\n \ + \ \"40.116.232.48/28\",\r\n \"40.116.232.96/28\",\r\n \ + \ \"40.117.48.80/28\",\r\n \"40.117.48.112/28\",\r\n \ + \ \"40.117.104.16/28\",\r\n \"40.118.72.176/28\",\r\n \ + \ \"40.118.73.48/28\",\r\n \"40.118.73.176/28\",\r\n \"\ + 40.118.73.208/28\",\r\n \"40.122.96.16/28\",\r\n \"40.122.216.16/28\"\ + ,\r\n \"40.123.16.16/28\",\r\n \"51.140.16.16/28\",\r\n\ + \ \"51.140.16.32/28\",\r\n \"51.140.168.64/27\",\r\n \ + \ \"51.140.168.112/28\",\r\n \"51.140.168.128/28\",\r\n \ + \ \"51.140.232.64/27\",\r\n \"51.140.232.112/28\",\r\n \ + \ \"51.140.232.128/28\",\r\n \"51.140.232.160/27\",\r\n \ + \ \"51.141.128.0/23\",\r\n \"51.141.130.0/25\",\r\n \ + \ \"52.161.112.16/28\",\r\n \"52.161.112.32/28\",\r\n \"\ + 52.161.168.16/28\",\r\n \"52.161.168.32/28\",\r\n \"52.162.56.16/28\"\ + ,\r\n \"52.162.56.32/28\",\r\n \"52.162.56.64/27\",\r\n\ + \ \"52.162.56.112/28\",\r\n \"52.162.56.128/28\",\r\n \ + \ \"52.163.176.16/28\",\r\n \"52.163.232.16/28\",\r\n \ + \ \"52.164.112.16/28\",\r\n \"52.164.232.16/28\",\r\n \ + \ \"52.164.232.32/28\",\r\n \"52.164.232.64/28\",\r\n \ + \ \"52.165.104.16/28\",\r\n \"52.165.104.32/28\",\r\n \"\ + 52.165.104.64/27\",\r\n \"52.165.104.112/28\",\r\n \"52.165.104.144/28\"\ + ,\r\n \"52.165.104.160/28\",\r\n \"52.165.136.32/28\",\r\ + \n \"52.165.240.64/28\",\r\n \"52.166.80.32/27\",\r\n \ + \ \"52.166.80.80/28\",\r\n \"52.166.80.96/28\",\r\n \ + \ \"52.167.88.80/28\",\r\n \"52.167.88.112/28\",\r\n \ + \ \"52.167.240.16/28\",\r\n \"52.169.168.32/27\",\r\n \"\ + 52.169.240.16/28\",\r\n \"52.169.240.32/28\",\r\n \"52.169.240.64/28\"\ + ,\r\n \"52.171.144.32/27\",\r\n \"52.171.144.80/28\",\r\n\ + \ \"52.171.144.96/28\",\r\n \"52.171.144.128/28\",\r\n \ + \ \"52.172.16.16/28\",\r\n \"52.172.16.80/28\",\r\n \ + \ \"52.172.16.96/28\",\r\n \"52.172.16.128/27\",\r\n \ + \ \"52.173.152.64/28\",\r\n \"52.173.152.96/28\",\r\n \"\ + 52.174.8.32/28\",\r\n \"52.174.224.16/28\",\r\n \"52.174.224.32/28\"\ + ,\r\n \"52.174.224.64/27\",\r\n \"52.174.224.112/28\",\r\ + \n \"52.174.224.128/28\",\r\n \"52.175.40.128/28\",\r\n\ + \ \"52.175.112.16/28\",\r\n \"52.176.224.64/28\",\r\n \ + \ \"52.176.224.96/28\",\r\n \"52.177.208.80/28\",\r\n \ + \ \"52.178.168.32/27\",\r\n \"52.178.168.80/28\",\r\n \ + \ \"52.178.168.96/28\",\r\n \"52.178.168.128/27\",\r\n \ + \ \"52.179.24.16/28\",\r\n \"52.179.144.32/28\",\r\n \"\ + 52.179.144.64/28\",\r\n \"52.179.240.16/28\",\r\n \"52.179.240.48/28\"\ + ,\r\n \"52.179.240.64/28\",\r\n \"52.179.240.96/27\",\r\n\ + \ \"52.179.240.144/28\",\r\n \"52.179.240.160/28\",\r\n\ + \ \"52.179.240.192/27\",\r\n \"52.179.240.240/28\",\r\n\ + \ \"52.179.241.0/28\",\r\n \"52.179.241.32/27\",\r\n \ + \ \"52.180.40.16/28\",\r\n \"52.180.40.32/28\",\r\n \ + \ \"52.180.184.16/28\",\r\n \"52.182.176.16/28\",\r\n \ + \ \"52.182.176.32/28\",\r\n \"52.182.176.64/27\",\r\n \"\ + 52.183.48.16/28\",\r\n \"52.183.104.16/28\",\r\n \"52.183.104.32/28\"\ + ,\r\n \"52.184.40.16/28\",\r\n \"52.184.40.32/28\",\r\n\ + \ \"52.184.168.32/28\",\r\n \"52.184.168.96/27\",\r\n \ + \ \"52.185.56.80/28\",\r\n \"52.185.56.96/28\",\r\n \ + \ \"52.185.56.144/28\",\r\n \"52.185.56.160/28\",\r\n \ + \ \"52.185.112.16/28\",\r\n \"52.185.112.48/28\",\r\n \"\ + 52.185.112.80/28\",\r\n \"52.185.112.112/28\",\r\n \"52.185.233.0/24\"\ + ,\r\n \"52.186.112.32/27\",\r\n \"52.187.141.32/27\",\r\n\ + \ \"52.189.177.0/24\",\r\n \"52.190.240.16/28\",\r\n \ + \ \"52.190.240.32/28\",\r\n \"52.190.240.64/27\",\r\n \ + \ \"52.190.240.112/28\",\r\n \"52.190.240.128/28\",\r\n \ + \ \"52.191.176.16/28\",\r\n \"52.191.176.32/28\",\r\n \ + \ \"52.225.40.32/27\",\r\n \"52.225.136.16/28\",\r\n \"\ + 52.225.136.32/28\",\r\n \"52.225.240.0/28\",\r\n \"52.226.8.32/27\"\ + ,\r\n \"52.226.8.80/28\",\r\n \"52.226.8.96/28\",\r\n \ + \ \"52.226.8.128/27\",\r\n \"52.228.232.0/28\",\r\n \ + \ \"52.229.80.64/27\",\r\n \"52.230.240.16/28\",\r\n \ + \ \"52.230.240.32/28\",\r\n \"52.230.240.64/27\",\r\n \"\ + 52.230.240.112/28\",\r\n \"52.230.240.128/28\",\r\n \"52.230.240.160/27\"\ + ,\r\n \"52.231.80.64/27\",\r\n \"52.231.80.112/28\",\r\n\ + \ \"52.231.80.128/28\",\r\n \"52.231.80.160/27\",\r\n \ + \ \"52.231.168.64/27\",\r\n \"52.231.168.112/28\",\r\n \ + \ \"52.231.168.128/28\",\r\n \"52.231.208.16/28\",\r\n \ + \ \"52.231.208.32/28\",\r\n \"52.232.232.16/28\",\r\n \ + \ \"52.232.232.32/28\",\r\n \"52.232.232.80/28\",\r\n \ + \ \"52.232.232.96/28\",\r\n \"52.232.232.128/27\",\r\n \ + \ \"52.232.232.176/28\",\r\n \"52.232.232.192/28\",\r\n \ + \ \"52.234.176.48/28\",\r\n \"52.234.176.64/28\",\r\n \"\ + 52.234.176.96/27\",\r\n \"52.236.40.16/28\",\r\n \"52.236.40.32/28\"\ + ,\r\n \"52.236.240.48/28\",\r\n \"52.236.240.64/28\",\r\n\ + \ \"52.237.104.16/28\",\r\n \"52.237.104.32/28\",\r\n \ + \ \"52.238.56.16/28\",\r\n \"52.238.56.32/28\",\r\n \ + \ \"52.238.56.64/27\",\r\n \"52.238.56.112/28\",\r\n \ + \ \"52.238.56.128/28\",\r\n \"52.238.56.160/27\",\r\n \"\ + 52.238.200.32/27\",\r\n \"52.239.104.16/28\",\r\n \"52.239.104.32/28\"\ + ,\r\n \"52.239.128.0/20\",\r\n \"52.239.144.0/22\",\r\n\ + \ \"52.239.148.0/27\",\r\n \"52.239.148.64/26\",\r\n \ + \ \"52.239.148.128/25\",\r\n \"52.239.149.0/24\",\r\n \ + \ \"52.239.150.0/23\",\r\n \"52.239.152.0/21\",\r\n \ + \ \"52.239.160.0/22\",\r\n \"52.239.164.0/24\",\r\n \"52.239.165.0/26\"\ + ,\r\n \"52.239.165.160/27\",\r\n \"52.239.165.192/26\",\r\ + \n \"52.239.167.0/24\",\r\n \"52.239.168.0/21\",\r\n \ + \ \"52.239.176.128/25\",\r\n \"52.239.177.0/24\",\r\n \ + \ \"52.239.178.0/23\",\r\n \"52.239.180.0/22\",\r\n \ + \ \"52.239.184.0/22\",\r\n \"52.239.188.0/23\",\r\n \"52.239.190.0/24\"\ + ,\r\n \"52.239.191.0/28\",\r\n \"52.239.192.0/18\",\r\n\ + \ \"52.240.48.16/28\",\r\n \"52.240.48.32/28\",\r\n \ + \ \"52.240.60.16/28\",\r\n \"52.240.60.32/28\",\r\n \ + \ \"52.240.60.64/27\",\r\n \"52.241.88.16/28\",\r\n \"\ + 52.241.88.32/28\",\r\n \"52.241.88.64/27\",\r\n \"52.245.40.0/24\"\ + ,\r\n \"104.41.232.16/28\",\r\n \"104.42.200.16/28\",\r\n\ + \ \"104.43.80.16/28\",\r\n \"104.46.31.16/28\",\r\n \ + \ \"104.208.0.16/28\",\r\n \"104.208.0.48/28\",\r\n \ + \ \"104.208.128.16/28\",\r\n \"104.208.248.16/28\",\r\n \ + \ \"104.211.104.64/28\",\r\n \"104.211.104.96/28\",\r\n \ + \ \"104.211.104.128/28\",\r\n \"104.211.109.0/28\",\r\n \ + \ \"104.211.109.32/27\",\r\n \"104.211.109.80/28\",\r\n \ + \ \"104.211.109.96/28\",\r\n \"104.211.168.16/28\",\r\n \ + \ \"104.211.232.16/28\",\r\n \"104.211.232.48/28\",\r\n \ + \ \"104.211.232.80/28\",\r\n \"104.211.232.176/28\",\r\n \ + \ \"104.214.40.16/28\",\r\n \"104.214.80.16/28\",\r\n \ + \ \"104.214.80.48/28\",\r\n \"104.214.152.16/28\",\r\n \"\ + 104.214.152.176/28\",\r\n \"104.214.243.32/28\",\r\n \"\ + 104.215.32.16/28\",\r\n \"104.215.32.32/28\",\r\n \"104.215.32.64/27\"\ + ,\r\n \"104.215.35.32/27\",\r\n \"104.215.104.64/28\",\r\ + \n \"104.215.240.64/28\",\r\n \"104.215.240.96/28\",\r\n\ + \ \"137.116.1.0/25\",\r\n \"137.116.2.0/25\",\r\n \ + \ \"137.116.3.0/25\",\r\n \"137.116.3.128/26\",\r\n \"\ + 137.116.96.0/25\",\r\n \"137.116.96.128/26\",\r\n \"137.135.192.64/26\"\ + ,\r\n \"137.135.192.192/26\",\r\n \"137.135.193.192/26\"\ + ,\r\n \"137.135.194.0/25\",\r\n \"137.135.194.192/26\",\r\ + \n \"138.91.96.64/26\",\r\n \"138.91.96.128/26\",\r\n \ + \ \"138.91.128.128/26\",\r\n \"138.91.129.0/26\",\r\n \ + \ \"157.56.216.0/26\",\r\n \"168.61.57.64/26\",\r\n \ + \ \"168.61.57.128/25\",\r\n \"168.61.58.0/26\",\r\n \"\ + 168.61.58.128/26\",\r\n \"168.61.59.64/26\",\r\n \"168.61.61.0/26\"\ + ,\r\n \"168.61.61.192/26\",\r\n \"168.61.120.32/27\",\r\n\ + \ \"168.61.120.64/27\",\r\n \"168.61.121.0/26\",\r\n \ + \ \"168.61.128.192/26\",\r\n \"168.61.129.0/25\",\r\n \ + \ \"168.61.130.64/26\",\r\n \"168.61.130.128/25\",\r\n \ + \ \"168.61.131.0/26\",\r\n \"168.61.131.128/25\",\r\n \ + \ \"168.61.132.0/26\",\r\n \"168.62.0.0/26\",\r\n \"168.62.1.128/26\"\ + ,\r\n \"168.62.32.0/26\",\r\n \"168.62.32.192/26\",\r\n\ + \ \"168.62.33.128/26\",\r\n \"168.62.96.128/25\",\r\n \ + \ \"168.62.128.128/26\",\r\n \"168.63.0.0/26\",\r\n \ + \ \"168.63.2.64/26\",\r\n \"168.63.3.32/27\",\r\n \"\ + 168.63.3.64/27\",\r\n \"168.63.32.0/26\",\r\n \"168.63.33.192/26\"\ + ,\r\n \"168.63.89.64/26\",\r\n \"168.63.89.128/26\",\r\n\ + \ \"168.63.113.32/27\",\r\n \"168.63.113.64/27\",\r\n \ + \ \"168.63.128.0/26\",\r\n \"168.63.128.128/25\",\r\n \ + \ \"168.63.129.128/25\",\r\n \"168.63.130.0/26\",\r\n \ + \ \"168.63.130.128/26\",\r\n \"168.63.131.0/26\",\r\n \ + \ \"168.63.156.64/26\",\r\n \"168.63.156.192/26\",\r\n \ + \ \"168.63.160.0/26\",\r\n \"168.63.160.192/26\",\r\n \"\ + 168.63.161.64/26\",\r\n \"168.63.161.160/27\",\r\n \"168.63.161.192/26\"\ + ,\r\n \"168.63.162.32/27\",\r\n \"168.63.162.64/26\",\r\n\ + \ \"168.63.162.144/28\",\r\n \"168.63.162.192/26\",\r\n\ + \ \"168.63.163.128/26\",\r\n \"168.63.180.64/26\",\r\n \ + \ \"191.232.216.32/27\",\r\n \"191.232.221.16/28\",\r\n \ + \ \"191.232.221.32/28\",\r\n \"191.233.128.0/24\",\r\n \ + \ \"191.235.192.192/26\",\r\n \"191.235.193.32/28\",\r\n \ + \ \"191.235.248.0/23\",\r\n \"191.235.250.0/25\",\r\n \ + \ \"191.235.255.192/26\",\r\n \"191.237.32.128/28\",\r\n \ + \ \"191.237.32.208/28\",\r\n \"191.237.32.240/28\",\r\n \ + \ \"191.237.160.64/26\",\r\n \"191.237.160.224/28\",\r\n \ + \ \"191.237.232.32/28\",\r\n \"191.237.232.128/28\",\r\n\ + \ \"191.237.238.32/28\",\r\n \"191.238.0.0/26\",\r\n \ + \ \"191.238.0.224/28\",\r\n \"191.238.64.64/26\",\r\n \ + \ \"191.238.64.192/28\",\r\n \"191.238.66.0/26\",\r\n \ + \ \"191.239.192.0/26\",\r\n \"191.239.203.0/28\",\r\n \ + \ \"191.239.224.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.AustraliaCentral\",\r\n \"id\": \"Storage.AustraliaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"AzureStorage\",\r\n \"\ + addressPrefixes\": [\r\n \"20.47.35.0/24\",\r\n \"20.150.124.0/24\"\ + ,\r\n \"52.239.216.0/23\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Storage.AustraliaCentral2\",\r\n \"id\": \"\ + Storage.AustraliaCentral2\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"australiacentral2\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.47.36.0/24\",\r\n \ + \ \"20.150.103.0/24\",\r\n \"52.239.218.0/23\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.AustraliaEast\"\ + ,\r\n \"id\": \"Storage.AustraliaEast\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.70.99.16/28\"\ + ,\r\n \"13.70.99.48/28\",\r\n \"13.70.99.64/28\",\r\n \ + \ \"13.72.235.64/28\",\r\n \"13.72.235.96/27\",\r\n \ + \ \"13.72.235.144/28\",\r\n \"13.72.237.48/28\",\r\n \ + \ \"13.72.237.64/28\",\r\n \"13.75.240.16/28\",\r\n \"13.75.240.32/28\"\ + ,\r\n \"13.75.240.64/27\",\r\n \"20.38.112.0/23\",\r\n \ + \ \"20.47.37.0/24\",\r\n \"20.150.66.0/24\",\r\n \ + \ \"20.150.92.0/24\",\r\n \"20.150.117.0/24\",\r\n \"52.239.130.0/23\"\ + ,\r\n \"52.239.226.0/24\",\r\n \"104.46.31.16/28\",\r\n\ + \ \"191.238.66.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.AustraliaSoutheast\",\r\n \"id\": \"Storage.AustraliaSoutheast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n\ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.77.8.16/28\",\r\n \"13.77.8.32/28\"\ + ,\r\n \"13.77.8.64/28\",\r\n \"13.77.8.96/28\",\r\n \ + \ \"13.77.8.128/27\",\r\n \"13.77.8.160/28\",\r\n \"\ + 13.77.8.192/27\",\r\n \"20.47.38.0/24\",\r\n \"20.150.12.0/23\"\ + ,\r\n \"20.150.119.0/24\",\r\n \"52.239.132.0/23\",\r\n\ + \ \"52.239.225.0/24\",\r\n \"191.239.192.0/26\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.BrazilSouth\"\ + ,\r\n \"id\": \"Storage.BrazilSouth\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.39.0/24\"\ + ,\r\n \"20.150.111.0/24\",\r\n \"23.97.112.64/26\",\r\n\ + \ \"191.232.216.32/27\",\r\n \"191.232.221.16/28\",\r\n\ + \ \"191.232.221.32/28\",\r\n \"191.233.128.0/24\",\r\n \ + \ \"191.235.248.0/23\",\r\n \"191.235.250.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.CanadaCentral\"\ + ,\r\n \"id\": \"Storage.CanadaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.38.114.0/25\",\r\n \ + \ \"20.47.40.0/24\",\r\n \"20.150.16.0/24\",\r\n \ + \ \"20.150.31.0/24\",\r\n \"20.150.71.0/24\",\r\n \"20.150.100.0/24\"\ + ,\r\n \"40.85.232.64/28\",\r\n \"40.85.232.96/28\",\r\n\ + \ \"40.85.232.144/28\",\r\n \"40.85.235.32/27\",\r\n \ + \ \"40.85.235.80/28\",\r\n \"40.85.235.96/28\",\r\n \ + \ \"52.239.148.64/26\",\r\n \"52.239.189.0/24\"\r\n ]\r\n\ + \ }\r\n },\r\n {\r\n \"name\": \"Storage.CanadaEast\",\r\n\ + \ \"id\": \"Storage.CanadaEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.121.128/25\"\ + ,\r\n \"20.47.41.0/24\",\r\n \"20.150.1.0/25\",\r\n \ + \ \"20.150.40.128/25\",\r\n \"20.150.113.0/24\",\r\n \ + \ \"40.86.232.64/28\",\r\n \"40.86.232.96/28\",\r\n \"\ + 40.86.232.128/28\",\r\n \"40.86.232.176/28\",\r\n \"40.86.232.192/28\"\ + ,\r\n \"52.229.80.64/27\",\r\n \"52.239.164.128/26\",\r\n\ + \ \"52.239.190.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.CentralIndia\",\r\n \"id\": \"Storage.CentralIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centralindia\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.126.0/23\",\r\n \"20.47.42.0/24\",\r\n \ + \ \"20.150.114.0/24\",\r\n \"52.239.135.64/26\",\r\n \ + \ \"52.239.202.0/24\",\r\n \"104.211.104.64/28\",\r\n \ + \ \"104.211.104.96/28\",\r\n \"104.211.104.128/28\",\r\n \ + \ \"104.211.109.0/28\",\r\n \"104.211.109.32/27\",\r\n \ + \ \"104.211.109.80/28\",\r\n \"104.211.109.96/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.CentralUS\"\ + ,\r\n \"id\": \"Storage.CentralUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.67.155.16/28\"\ + ,\r\n \"20.38.96.0/23\",\r\n \"20.38.122.0/23\",\r\n \ + \ \"20.47.58.0/23\",\r\n \"20.60.18.0/24\",\r\n \"\ + 20.150.43.128/25\",\r\n \"20.150.58.0/24\",\r\n \"20.150.63.0/24\"\ + ,\r\n \"20.150.77.0/24\",\r\n \"20.150.89.0/24\",\r\n \ + \ \"20.150.95.0/24\",\r\n \"23.99.160.64/26\",\r\n \ + \ \"23.99.160.192/28\",\r\n \"40.69.176.16/28\",\r\n \"\ + 40.83.24.16/28\",\r\n \"40.83.24.80/28\",\r\n \"40.122.96.16/28\"\ + ,\r\n \"40.122.216.16/28\",\r\n \"52.165.104.16/28\",\r\n\ + \ \"52.165.104.32/28\",\r\n \"52.165.104.64/27\",\r\n \ + \ \"52.165.104.112/28\",\r\n \"52.165.136.32/28\",\r\n \ + \ \"52.165.240.64/28\",\r\n \"52.173.152.64/28\",\r\n \ + \ \"52.173.152.96/28\",\r\n \"52.176.224.64/28\",\r\n \ + \ \"52.176.224.96/28\",\r\n \"52.180.184.16/28\",\r\n \ + \ \"52.182.176.16/28\",\r\n \"52.182.176.32/28\",\r\n \"\ + 52.182.176.64/27\",\r\n \"52.185.56.80/28\",\r\n \"52.185.56.96/28\"\ + ,\r\n \"52.185.56.144/28\",\r\n \"52.185.56.160/28\",\r\n\ + \ \"52.185.112.16/28\",\r\n \"52.185.112.48/28\",\r\n \ + \ \"52.185.112.112/28\",\r\n \"52.228.232.0/28\",\r\n \ + \ \"52.230.240.16/28\",\r\n \"52.230.240.32/28\",\r\n \ + \ \"52.230.240.64/27\",\r\n \"52.230.240.112/28\",\r\n \ + \ \"52.230.240.128/28\",\r\n \"52.230.240.160/27\",\r\n \ + \ \"52.238.200.32/27\",\r\n \"52.239.150.0/23\",\r\n \"\ + 52.239.177.32/27\",\r\n \"52.239.177.64/26\",\r\n \"52.239.177.128/25\"\ + ,\r\n \"52.239.195.0/24\",\r\n \"52.239.234.0/23\",\r\n\ + \ \"104.208.0.16/28\",\r\n \"104.208.0.48/28\",\r\n \ + \ \"168.61.128.192/26\",\r\n \"168.61.129.0/25\",\r\n \ + \ \"168.61.130.64/26\",\r\n \"168.61.130.128/25\",\r\n \ + \ \"168.61.131.0/26\",\r\n \"168.61.131.128/25\",\r\n \ + \ \"168.61.132.0/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.CentralUSEUAP\",\r\n \"id\": \"Storage.CentralUSEUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"centraluseuap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"\ + addressPrefixes\": [\r\n \"20.47.5.0/24\",\r\n \"20.150.23.0/24\"\ + ,\r\n \"20.150.47.0/25\",\r\n \"40.83.24.96/27\",\r\n \ + \ \"52.165.104.144/28\",\r\n \"52.165.104.160/28\",\r\n \ + \ \"52.185.112.80/28\",\r\n \"52.239.177.0/27\",\r\n \ + \ \"52.239.238.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.EastAsia\",\r\n \"id\": \"Storage.EastAsia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastasia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.47.43.0/24\",\r\n \"20.150.1.128/25\",\r\n\ + \ \"20.150.22.0/24\",\r\n \"20.150.96.0/24\",\r\n \ + \ \"40.83.104.176/28\",\r\n \"40.83.104.208/28\",\r\n \ + \ \"52.175.40.128/28\",\r\n \"52.175.112.16/28\",\r\n \"\ + 52.184.40.16/28\",\r\n \"52.184.40.32/28\",\r\n \"52.239.128.0/24\"\ + ,\r\n \"52.239.224.0/24\",\r\n \"168.63.128.0/26\",\r\n\ + \ \"168.63.128.128/25\",\r\n \"168.63.129.128/25\",\r\n\ + \ \"168.63.130.0/26\",\r\n \"168.63.130.128/26\",\r\n \ + \ \"168.63.131.0/26\",\r\n \"168.63.156.64/26\",\r\n \ + \ \"168.63.156.192/26\",\r\n \"191.237.238.32/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS\",\r\ + \n \"id\": \"Storage.EastUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.68.163.32/28\",\r\n\ + \ \"13.68.165.64/28\",\r\n \"13.68.167.240/28\",\r\n \ + \ \"13.82.33.32/28\",\r\n \"13.82.152.16/28\",\r\n \ + \ \"13.82.152.48/28\",\r\n \"13.82.152.80/28\",\r\n \"\ + 20.38.98.0/24\",\r\n \"20.47.1.0/24\",\r\n \"20.47.16.0/23\"\ + ,\r\n \"20.47.31.0/24\",\r\n \"20.60.6.0/23\",\r\n \ + \ \"20.150.32.0/23\",\r\n \"20.150.90.0/24\",\r\n \"\ + 23.96.64.64/26\",\r\n \"40.71.104.16/28\",\r\n \"40.71.104.32/28\"\ + ,\r\n \"40.71.240.16/28\",\r\n \"40.117.48.80/28\",\r\n\ + \ \"40.117.48.112/28\",\r\n \"40.117.104.16/28\",\r\n \ + \ \"52.179.24.16/28\",\r\n \"52.186.112.32/27\",\r\n \ + \ \"52.226.8.32/27\",\r\n \"52.226.8.80/28\",\r\n \"\ + 52.226.8.96/28\",\r\n \"52.226.8.128/27\",\r\n \"52.234.176.48/28\"\ + ,\r\n \"52.234.176.64/28\",\r\n \"52.234.176.96/27\",\r\n\ + \ \"52.239.152.0/22\",\r\n \"52.239.168.0/22\",\r\n \ + \ \"52.239.207.192/26\",\r\n \"52.239.214.0/23\",\r\n \ + \ \"52.239.220.0/23\",\r\n \"52.239.246.0/23\",\r\n \"\ + 52.239.252.0/24\",\r\n \"52.240.48.16/28\",\r\n \"52.240.48.32/28\"\ + ,\r\n \"52.240.60.16/28\",\r\n \"52.240.60.32/28\",\r\n\ + \ \"52.240.60.64/27\",\r\n \"138.91.96.64/26\",\r\n \ + \ \"138.91.96.128/26\",\r\n \"168.62.32.0/26\",\r\n \ + \ \"168.62.32.192/26\",\r\n \"168.62.33.128/26\",\r\n \"\ + 191.237.32.128/28\",\r\n \"191.237.32.208/28\",\r\n \"191.237.32.240/28\"\ + ,\r\n \"191.238.0.0/26\",\r\n \"191.238.0.224/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS2\"\ + ,\r\n \"id\": \"Storage.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.68.120.64/28\"\ + ,\r\n \"13.77.112.16/28\",\r\n \"13.77.112.32/28\",\r\n\ + \ \"13.77.112.112/28\",\r\n \"13.77.112.128/28\",\r\n \ + \ \"13.77.115.16/28\",\r\n \"13.77.115.32/28\",\r\n \ + \ \"20.38.100.0/23\",\r\n \"20.47.60.0/23\",\r\n \"20.150.29.0/24\"\ + ,\r\n \"20.150.36.0/24\",\r\n \"20.150.50.0/23\",\r\n \ + \ \"20.150.72.0/24\",\r\n \"20.150.82.0/24\",\r\n \ + \ \"20.150.88.0/24\",\r\n \"23.102.206.0/28\",\r\n \"23.102.206.128/28\"\ + ,\r\n \"23.102.206.192/28\",\r\n \"40.79.8.16/28\",\r\n\ + \ \"40.79.48.16/28\",\r\n \"40.84.8.32/28\",\r\n \ + \ \"40.84.11.80/28\",\r\n \"40.123.16.16/28\",\r\n \"\ + 52.167.88.80/28\",\r\n \"52.167.88.112/28\",\r\n \"52.167.240.16/28\"\ + ,\r\n \"52.177.208.80/28\",\r\n \"52.179.144.32/28\",\r\n\ + \ \"52.179.144.64/28\",\r\n \"52.179.240.16/28\",\r\n \ + \ \"52.179.240.48/28\",\r\n \"52.179.240.64/28\",\r\n \ + \ \"52.179.240.96/27\",\r\n \"52.179.240.144/28\",\r\n \ + \ \"52.179.240.160/28\",\r\n \"52.179.240.192/27\",\r\n \ + \ \"52.179.240.240/28\",\r\n \"52.179.241.0/28\",\r\n \ + \ \"52.179.241.32/27\",\r\n \"52.184.168.96/27\",\r\n \ + \ \"52.225.136.16/28\",\r\n \"52.225.136.32/28\",\r\n \"\ + 52.225.240.0/28\",\r\n \"52.232.232.16/28\",\r\n \"52.232.232.32/28\"\ + ,\r\n \"52.232.232.80/28\",\r\n \"52.232.232.96/28\",\r\n\ + \ \"52.232.232.128/27\",\r\n \"52.232.232.176/28\",\r\n\ + \ \"52.232.232.192/28\",\r\n \"52.239.156.0/24\",\r\n \ + \ \"52.239.157.0/25\",\r\n \"52.239.157.128/26\",\r\n \ + \ \"52.239.157.192/27\",\r\n \"52.239.172.0/22\",\r\n \ + \ \"52.239.184.0/25\",\r\n \"52.239.184.160/28\",\r\n \ + \ \"52.239.184.192/27\",\r\n \"52.239.185.32/27\",\r\n \ + \ \"52.239.185.64/27\",\r\n \"52.239.192.0/25\",\r\n \"\ + 52.239.192.160/27\",\r\n \"52.239.192.192/26\",\r\n \"52.239.198.0/25\"\ + ,\r\n \"52.239.198.160/27\",\r\n \"52.239.198.192/26\",\r\ + \n \"52.239.206.0/24\",\r\n \"52.239.207.0/27\",\r\n \ + \ \"52.239.207.32/28\",\r\n \"52.239.207.64/26\",\r\n \ + \ \"52.239.207.128/26\",\r\n \"52.239.222.0/23\",\r\n \ + \ \"104.208.128.16/28\",\r\n \"104.208.248.16/28\",\r\n \ + \ \"137.116.1.0/25\",\r\n \"137.116.2.0/26\",\r\n \"137.116.2.96/29\"\ + ,\r\n \"137.116.2.104/30\",\r\n \"137.116.2.108/32\",\r\n\ + \ \"137.116.2.110/31\",\r\n \"137.116.2.112/32\",\r\n \ + \ \"137.116.2.114/32\",\r\n \"137.116.2.116/30\",\r\n \ + \ \"137.116.2.120/29\",\r\n \"137.116.3.0/25\",\r\n \ + \ \"137.116.3.128/26\",\r\n \"137.116.96.0/25\",\r\n \"\ + 137.116.96.128/26\",\r\n \"191.237.160.64/26\",\r\n \"191.237.160.224/28\"\ + ,\r\n \"191.239.224.0/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"Storage.EastUS2EUAP\",\r\n \"id\": \"Storage.EastUS2EUAP\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"eastus2euap\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.47.6.0/24\",\r\n \"20.150.108.0/24\",\r\n \ + \ \"40.70.88.0/30\",\r\n \"40.70.88.4/31\",\r\n \ + \ \"40.70.88.6/32\",\r\n \"40.70.88.8/31\",\r\n \"40.70.88.10/32\"\ + ,\r\n \"40.70.88.12/32\",\r\n \"40.70.88.14/31\",\r\n \ + \ \"40.79.88.16/30\",\r\n \"40.79.88.20/31\",\r\n \ + \ \"40.79.88.22/32\",\r\n \"40.79.88.24/31\",\r\n \"40.79.88.26/32\"\ + ,\r\n \"40.79.88.28/32\",\r\n \"40.79.88.30/31\",\r\n \ + \ \"52.184.168.32/30\",\r\n \"52.184.168.36/31\",\r\n \ + \ \"52.184.168.38/32\",\r\n \"52.184.168.40/31\",\r\n \ + \ \"52.184.168.42/32\",\r\n \"52.184.168.44/32\",\r\n \ + \ \"52.184.168.46/31\",\r\n \"52.239.157.224/31\",\r\n \ + \ \"52.239.157.226/32\",\r\n \"52.239.157.228/31\",\r\n \ + \ \"52.239.157.230/32\",\r\n \"52.239.157.232/32\",\r\n \ + \ \"52.239.157.234/31\",\r\n \"52.239.157.236/30\",\r\n \ + \ \"52.239.157.240/31\",\r\n \"52.239.157.242/32\",\r\n \ + \ \"52.239.157.244/31\",\r\n \"52.239.157.246/32\",\r\n \ + \ \"52.239.157.248/32\",\r\n \"52.239.157.250/31\",\r\n \ + \ \"52.239.157.252/30\",\r\n \"52.239.165.192/31\",\r\n \ + \ \"52.239.165.194/32\",\r\n \"52.239.165.196/31\",\r\n \ + \ \"52.239.165.198/32\",\r\n \"52.239.165.200/32\",\r\n \ + \ \"52.239.165.202/31\",\r\n \"52.239.165.204/30\",\r\n \ + \ \"52.239.165.208/28\",\r\n \"52.239.165.224/27\",\r\n \ + \ \"52.239.184.128/27\",\r\n \"52.239.184.176/31\",\r\n \ + \ \"52.239.184.178/32\",\r\n \"52.239.184.180/31\",\r\n \ + \ \"52.239.184.182/32\",\r\n \"52.239.184.184/32\",\r\n \ + \ \"52.239.184.186/31\",\r\n \"52.239.184.188/30\",\r\n \ + \ \"52.239.184.224/31\",\r\n \"52.239.184.226/32\",\r\n \ + \ \"52.239.184.228/31\",\r\n \"52.239.184.230/32\",\r\n \ + \ \"52.239.184.232/32\",\r\n \"52.239.184.234/31\",\r\n \ + \ \"52.239.184.236/30\",\r\n \"52.239.184.240/28\",\r\n \ + \ \"52.239.185.0/28\",\r\n \"52.239.192.128/31\",\r\n \"\ + 52.239.192.130/32\",\r\n \"52.239.192.132/31\",\r\n \"52.239.192.134/32\"\ + ,\r\n \"52.239.192.136/32\",\r\n \"52.239.192.138/31\",\r\ + \n \"52.239.192.140/30\",\r\n \"52.239.192.144/28\",\r\n\ + \ \"52.239.198.128/31\",\r\n \"52.239.198.130/32\",\r\n\ + \ \"52.239.198.132/31\",\r\n \"52.239.198.134/32\",\r\n\ + \ \"52.239.198.136/32\",\r\n \"52.239.198.138/31\",\r\n\ + \ \"52.239.198.140/30\",\r\n \"52.239.198.144/31\",\r\n\ + \ \"52.239.198.146/32\",\r\n \"52.239.198.148/31\",\r\n\ + \ \"52.239.198.150/32\",\r\n \"52.239.198.152/32\",\r\n\ + \ \"52.239.198.154/31\",\r\n \"52.239.198.156/30\",\r\n\ + \ \"52.239.230.0/24\",\r\n \"52.239.239.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.EastUS2Stage\"\ + ,\r\n \"id\": \"Storage.EastUS2Stage\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"137.116.2.64/27\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.FranceCentral\"\ + ,\r\n \"id\": \"Storage.FranceCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.44.0/24\"\ + ,\r\n \"20.60.13.0/24\",\r\n \"20.150.61.0/24\",\r\n \ + \ \"52.239.134.0/24\",\r\n \"52.239.194.0/24\",\r\n \ + \ \"52.239.241.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.FranceSouth\",\r\n \"id\": \"Storage.FranceSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southfrance\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.47.28.0/24\",\r\n \"20.60.11.0/24\",\r\n \ + \ \"20.150.19.0/24\",\r\n \"52.239.135.0/26\",\r\n \ + \ \"52.239.196.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.GermanyNorth\",\r\n \"id\": \"Storage.GermanyNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"germanyn\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.115.0/24\",\r\n \"20.47.45.0/24\",\r\n \ + \ \"20.150.60.0/24\",\r\n \"20.150.112.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.GermanyWestCentral\"\ + ,\r\n \"id\": \"Storage.GermanyWestCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"germanywc\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.118.0/24\"\ + ,\r\n \"20.47.27.0/24\",\r\n \"20.150.54.0/24\",\r\n \ + \ \"20.150.125.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Storage.JapanEast\",\r\n \"id\": \"Storage.JapanEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"japaneast\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.73.8.16/28\",\r\n \"13.73.8.32/28\",\r\n \ + \ \"20.38.116.0/23\",\r\n \"20.47.12.0/24\",\r\n \ + \ \"20.150.85.0/24\",\r\n \"20.150.105.0/24\",\r\n \"23.98.57.64/26\"\ + ,\r\n \"40.115.169.32/28\",\r\n \"40.115.175.16/28\",\r\n\ + \ \"40.115.175.32/28\",\r\n \"40.115.227.80/28\",\r\n \ + \ \"40.115.229.16/28\",\r\n \"40.115.229.32/28\",\r\n \ + \ \"40.115.231.64/27\",\r\n \"40.115.231.112/28\",\r\n \ + \ \"40.115.231.128/28\",\r\n \"52.239.144.0/23\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"Storage.JapanWest\",\r\n\ + \ \"id\": \"Storage.JapanWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.10.0/24\"\ + ,\r\n \"20.60.12.0/24\",\r\n \"20.150.10.0/23\",\r\n \ + \ \"23.98.56.0/26\",\r\n \"52.239.146.0/23\",\r\n \ + \ \"104.214.152.16/28\",\r\n \"104.214.152.176/28\",\r\n \ + \ \"104.215.32.16/28\",\r\n \"104.215.32.32/28\",\r\n \"\ + 104.215.32.64/27\",\r\n \"104.215.35.32/27\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"Storage.KoreaCentral\",\r\n\ + \ \"id\": \"Storage.KoreaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.46.0/24\"\ + ,\r\n \"20.60.16.0/24\",\r\n \"20.150.4.0/23\",\r\n \ + \ \"52.231.80.64/27\",\r\n \"52.231.80.112/28\",\r\n \ + \ \"52.231.80.128/28\",\r\n \"52.231.80.160/27\",\r\n \ + \ \"52.239.148.0/27\",\r\n \"52.239.164.192/26\",\r\n \"\ + 52.239.190.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"Storage.KoreaSouth\",\r\n \"id\": \"Storage.KoreaSouth\",\r\ + \n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"\ + region\": \"koreasouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.47.47.0/24\",\r\n \"20.150.14.0/23\",\r\n \ + \ \"52.231.168.64/27\",\r\n \"52.231.168.112/28\",\r\n \ + \ \"52.231.168.128/28\",\r\n \"52.231.208.16/28\",\r\n \"\ + 52.231.208.32/28\",\r\n \"52.239.165.0/26\",\r\n \"52.239.165.160/27\"\ + ,\r\n \"52.239.190.192/26\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"Storage.NorthCentralUS\",\r\n \"id\": \"\ + Storage.NorthCentralUS\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"northcentralus\",\r\n \"state\":\ + \ \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.47.3.0/24\",\r\n \ + \ \"20.47.15.0/24\",\r\n \"20.150.17.0/25\",\r\n \"\ + 20.150.25.0/24\",\r\n \"20.150.49.0/24\",\r\n \"20.150.67.0/24\"\ + ,\r\n \"20.150.126.0/24\",\r\n \"23.98.49.0/26\",\r\n \ + \ \"23.98.49.192/26\",\r\n \"23.98.55.0/26\",\r\n \ + \ \"23.98.55.112/28\",\r\n \"23.98.55.144/28\",\r\n \"\ + 40.116.120.16/28\",\r\n \"40.116.232.16/28\",\r\n \"40.116.232.48/28\"\ + ,\r\n \"40.116.232.96/28\",\r\n \"52.162.56.16/28\",\r\n\ + \ \"52.162.56.32/28\",\r\n \"52.162.56.64/27\",\r\n \ + \ \"52.162.56.112/28\",\r\n \"52.162.56.128/28\",\r\n \ + \ \"52.239.149.0/24\",\r\n \"52.239.186.0/24\",\r\n \"\ + 52.239.253.0/24\",\r\n \"157.56.216.0/26\",\r\n \"168.62.96.128/26\"\ + ,\r\n \"168.62.96.210/32\",\r\n \"168.62.96.224/27\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.NorthCentralUSStage\"\ + ,\r\n \"id\": \"Storage.NorthCentralUSStage\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"168.62.96.192/29\"\ + ,\r\n \"168.62.96.200/30\",\r\n \"168.62.96.204/32\",\r\n\ + \ \"168.62.96.206/31\",\r\n \"168.62.96.208/32\",\r\n \ + \ \"168.62.96.212/30\",\r\n \"168.62.96.216/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.NorthEurope\"\ + ,\r\n \"id\": \"Storage.NorthEurope\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.70.208.16/28\"\ + ,\r\n \"13.74.208.64/28\",\r\n \"13.74.208.112/28\",\r\n\ + \ \"13.74.208.144/28\",\r\n \"13.79.176.16/28\",\r\n \ + \ \"13.79.176.48/28\",\r\n \"13.79.176.80/28\",\r\n \ + \ \"20.38.102.0/23\",\r\n \"20.47.8.0/24\",\r\n \"20.47.20.0/23\"\ + ,\r\n \"20.47.32.0/24\",\r\n \"20.60.19.0/24\",\r\n \ + \ \"20.150.26.0/24\",\r\n \"20.150.47.128/25\",\r\n \ + \ \"20.150.48.0/24\",\r\n \"20.150.75.0/24\",\r\n \"20.150.84.0/24\"\ + ,\r\n \"20.150.104.0/24\",\r\n \"40.85.105.32/28\",\r\n\ + \ \"40.113.27.176/28\",\r\n \"52.164.112.16/28\",\r\n \ + \ \"52.164.232.16/28\",\r\n \"52.164.232.32/28\",\r\n \ + \ \"52.164.232.64/28\",\r\n \"52.169.168.32/27\",\r\n \ + \ \"52.169.240.16/28\",\r\n \"52.169.240.32/28\",\r\n \ + \ \"52.169.240.64/28\",\r\n \"52.178.168.32/27\",\r\n \"\ + 52.178.168.80/28\",\r\n \"52.178.168.96/28\",\r\n \"52.178.168.128/27\"\ + ,\r\n \"52.236.40.16/28\",\r\n \"52.236.40.32/28\",\r\n\ + \ \"52.239.136.0/22\",\r\n \"52.239.205.0/24\",\r\n \ + \ \"52.239.248.0/24\",\r\n \"52.245.40.0/24\",\r\n \ + \ \"104.41.232.16/28\",\r\n \"137.135.192.64/26\",\r\n \"\ + 137.135.192.192/26\",\r\n \"137.135.193.192/26\",\r\n \"\ + 137.135.194.0/25\",\r\n \"137.135.194.192/26\",\r\n \"168.61.120.32/27\"\ + ,\r\n \"168.61.120.64/27\",\r\n \"168.61.121.0/26\",\r\n\ + \ \"168.63.32.0/26\",\r\n \"168.63.33.192/26\",\r\n \ + \ \"191.235.192.192/26\",\r\n \"191.235.193.32/28\",\r\n \ + \ \"191.235.255.192/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.NorwayEast\",\r\n \"id\": \"Storage.NorwayEast\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"norwaye\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.120.0/24\",\r\n \"20.47.48.0/24\",\r\n \ + \ \"20.150.53.0/24\",\r\n \"20.150.121.0/24\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"Storage.NorwayWest\",\r\n\ + \ \"id\": \"Storage.NorwayWest\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.49.0/24\"\ + ,\r\n \"20.60.15.0/24\",\r\n \"20.150.0.0/24\",\r\n \ + \ \"20.150.56.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.SouthAfricaNorth\",\r\n \"id\": \"Storage.SouthAfricaNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"AzureStorage\",\r\n \"\ + addressPrefixes\": [\r\n \"20.38.114.128/25\",\r\n \"20.47.50.0/24\"\ + ,\r\n \"20.150.21.0/24\",\r\n \"20.150.62.0/24\",\r\n \ + \ \"20.150.101.0/24\",\r\n \"52.239.232.0/25\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.SouthAfricaWest\"\ + ,\r\n \"id\": \"Storage.SouthAfricaWest\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.38.121.0/25\"\ + ,\r\n \"20.47.51.0/24\",\r\n \"20.60.8.0/24\",\r\n \ + \ \"20.150.20.0/25\",\r\n \"52.239.232.128/25\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"Storage.SouthCentralUS\"\ + ,\r\n \"id\": \"Storage.SouthCentralUS\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.65.107.32/28\"\ + ,\r\n \"13.65.160.16/28\",\r\n \"13.65.160.48/28\",\r\n\ + \ \"13.65.160.64/28\",\r\n \"13.84.56.16/28\",\r\n \ + \ \"13.85.88.16/28\",\r\n \"13.85.200.128/28\",\r\n \ + \ \"20.38.104.0/23\",\r\n \"20.47.0.0/27\",\r\n \"20.47.24.0/23\"\ + ,\r\n \"20.47.29.0/24\",\r\n \"20.150.20.128/25\",\r\n \ + \ \"20.150.38.0/23\",\r\n \"20.150.70.0/24\",\r\n \ + \ \"20.150.79.0/24\",\r\n \"20.150.93.0/24\",\r\n \"20.150.94.0/24\"\ + ,\r\n \"23.98.160.64/26\",\r\n \"23.98.162.192/26\",\r\n\ + \ \"23.98.168.0/24\",\r\n \"23.98.192.64/26\",\r\n \ + \ \"23.98.255.64/26\",\r\n \"52.171.144.32/27\",\r\n \ + \ \"52.171.144.80/28\",\r\n \"52.171.144.96/28\",\r\n \"\ + 52.171.144.128/28\",\r\n \"52.185.233.0/24\",\r\n \"52.189.177.0/24\"\ + ,\r\n \"52.239.158.0/23\",\r\n \"52.239.178.0/23\",\r\n\ + \ \"52.239.180.0/22\",\r\n \"52.239.199.0/24\",\r\n \ + \ \"52.239.200.0/23\",\r\n \"52.239.203.0/24\",\r\n \ + \ \"52.239.204.0/24\",\r\n \"52.239.208.0/23\",\r\n \"\ + 104.214.40.16/28\",\r\n \"104.214.80.16/28\",\r\n \"104.214.80.48/28\"\ + ,\r\n \"104.215.104.64/28\",\r\n \"168.62.128.128/26\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.SoutheastAsia\"\ + ,\r\n \"id\": \"Storage.SoutheastAsia\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"13.76.104.16/28\"\ + ,\r\n \"20.47.9.0/24\",\r\n \"20.47.33.0/24\",\r\n \ + \ \"20.150.17.128/25\",\r\n \"20.150.28.0/24\",\r\n \ + \ \"20.150.86.0/24\",\r\n \"20.150.127.0/24\",\r\n \"52.163.176.16/28\"\ + ,\r\n \"52.163.232.16/28\",\r\n \"52.187.141.32/27\",\r\n\ + \ \"52.237.104.16/28\",\r\n \"52.237.104.32/28\",\r\n \ + \ \"52.239.129.0/24\",\r\n \"52.239.197.0/24\",\r\n \ + \ \"52.239.227.0/24\",\r\n \"52.239.249.0/24\",\r\n \"\ + 104.43.80.16/28\",\r\n \"104.215.240.64/28\",\r\n \"104.215.240.96/28\"\ + ,\r\n \"168.63.160.0/26\",\r\n \"168.63.160.192/26\",\r\n\ + \ \"168.63.161.64/26\",\r\n \"168.63.161.160/27\",\r\n \ + \ \"168.63.161.192/26\",\r\n \"168.63.162.32/27\",\r\n \ + \ \"168.63.162.64/26\",\r\n \"168.63.162.144/28\",\r\n \ + \ \"168.63.162.192/26\",\r\n \"168.63.163.128/26\",\r\n \ + \ \"168.63.180.64/26\",\r\n \"191.238.64.64/26\",\r\n \ + \ \"191.238.64.192/28\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Storage.SouthIndia\",\r\n \"id\": \"Storage.SouthIndia\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southindia\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.47.52.0/24\",\r\n \"20.60.10.0/24\",\r\n \ + \ \"20.150.24.0/24\",\r\n \"52.172.16.16/28\",\r\n \ + \ \"52.172.16.80/28\",\r\n \"52.172.16.96/28\",\r\n \"\ + 52.172.16.128/27\",\r\n \"52.239.135.128/26\",\r\n \"52.239.188.0/24\"\ + ,\r\n \"104.211.232.16/28\",\r\n \"104.211.232.48/28\",\r\ + \n \"104.211.232.80/28\",\r\n \"104.211.232.176/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.SwitzerlandNorth\"\ + ,\r\n \"id\": \"Storage.SwitzerlandNorth\",\r\n \"properties\":\ + \ {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.53.0/24\"\ + ,\r\n \"20.150.59.0/24\",\r\n \"20.150.118.0/24\",\r\n \ + \ \"52.239.251.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.SwitzerlandWest\",\r\n \"id\": \"Storage.SwitzerlandWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"switzerlandw\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.47.26.0/24\",\r\n \"20.150.55.0/24\",\r\n \ + \ \"20.150.116.0/24\",\r\n \"52.239.250.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.UAECentral\"\ + ,\r\n \"id\": \"Storage.UAECentral\",\r\n \"properties\": {\r\n\ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\",\r\ + \n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.54.0/24\"\ + ,\r\n \"20.150.6.0/23\",\r\n \"20.150.115.0/24\",\r\n \ + \ \"52.239.233.0/25\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Storage.UAENorth\",\r\n \"id\": \"Storage.UAENorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaenorth\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"20.38.124.0/23\",\r\n \"20.47.55.0/24\",\r\n \ + \ \"52.239.233.128/25\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.UKNorth\",\r\n \"id\": \"Storage.UKNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uknorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.87.104.64/28\",\r\n\ + \ \"13.87.104.96/28\",\r\n \"20.150.46.0/24\",\r\n \ + \ \"51.141.129.32/27\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"Storage.UKSouth\",\r\n \"id\": \"Storage.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.38.106.0/23\",\r\n \"20.47.11.0/24\",\r\n \ + \ \"20.47.34.0/24\",\r\n \"20.60.17.0/24\",\r\n \"20.150.18.0/25\"\ + ,\r\n \"20.150.40.0/25\",\r\n \"20.150.41.0/24\",\r\n \ + \ \"20.150.69.0/24\",\r\n \"51.140.16.16/28\",\r\n \ + \ \"51.140.16.32/28\",\r\n \"51.140.168.64/27\",\r\n \"\ + 51.140.168.112/28\",\r\n \"51.140.168.128/28\",\r\n \"51.141.128.32/27\"\ + ,\r\n \"51.141.129.64/26\",\r\n \"51.141.130.0/25\",\r\n\ + \ \"52.239.187.0/25\",\r\n \"52.239.231.0/24\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.UKSouth2\"\ + ,\r\n \"id\": \"Storage.UKSouth2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\"\r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n\ + \ \"addressPrefixes\": [\r\n \"13.87.40.64/28\",\r\n \ + \ \"13.87.40.96/28\",\r\n \"20.150.27.0/24\",\r\n \"\ + 51.141.129.0/27\",\r\n \"51.141.129.192/26\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"Storage.UKWest\",\r\n \"\ + id\": \"Storage.UKWest\",\r\n \"properties\": {\r\n \"changeNumber\"\ + : \"1\",\r\n \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\ + \n \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\ + \r\n ],\r\n \"systemService\": \"AzureStorage\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.47.56.0/24\",\r\n \"20.150.2.0/23\"\ + ,\r\n \"20.150.52.0/24\",\r\n \"20.150.110.0/24\",\r\n \ + \ \"51.140.232.64/27\",\r\n \"51.140.232.112/28\",\r\n \ + \ \"51.140.232.128/28\",\r\n \"51.140.232.160/27\",\r\n \ + \ \"51.141.128.0/27\",\r\n \"51.141.128.64/26\",\r\n \ + \ \"51.141.128.128/25\",\r\n \"51.141.129.128/26\",\r\n \ + \ \"52.239.240.0/24\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"Storage.WestCentralUS\",\r\n \"id\": \"Storage.WestCentralUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westcentralus\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\"\r\n ],\r\n \"\ + systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.200.64/28\",\r\n \"13.71.200.96/28\",\r\n \ + \ \"13.71.200.240/28\",\r\n \"13.71.202.16/28\",\r\n \ + \ \"13.71.202.32/28\",\r\n \"13.71.202.64/27\",\r\n \"\ + 13.78.152.64/28\",\r\n \"13.78.240.16/28\",\r\n \"20.47.4.0/24\"\ + ,\r\n \"20.60.4.0/24\",\r\n \"20.150.81.0/24\",\r\n \ + \ \"20.150.98.0/24\",\r\n \"52.161.112.16/28\",\r\n \ + \ \"52.161.112.32/28\",\r\n \"52.161.168.16/28\",\r\n \"\ + 52.161.168.32/28\",\r\n \"52.239.164.0/25\",\r\n \"52.239.167.0/24\"\ + ,\r\n \"52.239.244.0/23\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"Storage.WestEurope\",\r\n \"id\": \"Storage.WestEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westeurope\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"AzureStorage\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.69.40.16/28\",\r\n \"13.95.96.176/28\",\r\n\ + \ \"13.95.240.16/28\",\r\n \"13.95.240.32/28\",\r\n \ + \ \"13.95.240.64/27\",\r\n \"20.38.108.0/23\",\r\n \ + \ \"20.47.7.0/24\",\r\n \"20.47.18.0/23\",\r\n \"20.47.30.0/24\"\ + ,\r\n \"20.150.8.0/23\",\r\n \"20.150.37.0/24\",\r\n \ + \ \"20.150.42.0/24\",\r\n \"20.150.74.0/24\",\r\n \ + \ \"20.150.76.0/24\",\r\n \"20.150.83.0/24\",\r\n \"20.150.122.0/24\"\ + ,\r\n \"40.68.176.16/28\",\r\n \"40.68.176.48/28\",\r\n\ + \ \"40.68.232.16/28\",\r\n \"40.68.232.48/28\",\r\n \ + \ \"40.114.152.16/28\",\r\n \"40.114.152.48/28\",\r\n \ + \ \"40.118.72.176/28\",\r\n \"40.118.73.48/28\",\r\n \ + \ \"40.118.73.176/28\",\r\n \"40.118.73.208/28\",\r\n \"\ + 52.166.80.32/27\",\r\n \"52.166.80.80/28\",\r\n \"52.166.80.96/28\"\ + ,\r\n \"52.174.8.32/28\",\r\n \"52.174.224.16/28\",\r\n\ + \ \"52.174.224.32/28\",\r\n \"52.174.224.64/27\",\r\n \ + \ \"52.174.224.112/28\",\r\n \"52.174.224.128/28\",\r\n \ + \ \"52.236.240.48/28\",\r\n \"52.236.240.64/28\",\r\n \ + \ \"52.239.140.0/22\",\r\n \"52.239.212.0/23\",\r\n \ + \ \"52.239.242.0/23\",\r\n \"104.214.243.32/28\",\r\n \"\ + 168.61.57.64/26\",\r\n \"168.61.57.128/25\",\r\n \"168.61.58.0/26\"\ + ,\r\n \"168.61.58.128/26\",\r\n \"168.61.59.64/26\",\r\n\ + \ \"168.61.61.0/26\",\r\n \"168.61.61.192/26\",\r\n \ + \ \"168.63.0.0/26\",\r\n \"168.63.2.64/26\",\r\n \"\ + 168.63.3.32/27\",\r\n \"168.63.3.64/27\",\r\n \"168.63.113.32/27\"\ + ,\r\n \"168.63.113.64/27\",\r\n \"191.237.232.32/28\",\r\ + \n \"191.237.232.128/28\",\r\n \"191.239.203.0/28\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.WestIndia\"\ + ,\r\n \"id\": \"Storage.WestIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westindia\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \"20.47.57.0/24\"\ + ,\r\n \"20.150.18.128/25\",\r\n \"20.150.43.0/25\",\r\n\ + \ \"20.150.106.0/24\",\r\n \"52.239.135.192/26\",\r\n \ + \ \"52.239.187.128/25\",\r\n \"104.211.168.16/28\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"Storage.WestUS\"\ + ,\r\n \"id\": \"Storage.WestUS\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westus\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"AzureStorage\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.83.72.16/28\",\r\n \ + \ \"13.88.144.112/28\",\r\n \"13.88.144.240/28\",\r\n \ + \ \"13.88.145.64/28\",\r\n \"13.88.145.96/28\",\r\n \ + \ \"13.88.145.128/28\",\r\n \"13.93.168.80/28\",\r\n \"\ + 13.93.168.112/28\",\r\n \"13.93.168.144/28\",\r\n \"20.47.2.0/24\"\ + ,\r\n \"20.47.22.0/23\",\r\n \"20.150.34.0/23\",\r\n \ + \ \"20.150.91.0/24\",\r\n \"20.150.102.0/24\",\r\n \ + \ \"20.157.32.0/24\",\r\n \"23.99.32.64/26\",\r\n \"23.99.34.224/28\"\ + ,\r\n \"23.99.37.96/28\",\r\n \"23.99.47.32/28\",\r\n \ + \ \"40.78.72.16/28\",\r\n \"40.78.112.64/28\",\r\n \ + \ \"40.83.225.32/28\",\r\n \"40.83.227.16/28\",\r\n \"\ + 40.112.152.16/28\",\r\n \"40.112.224.16/28\",\r\n \"40.112.224.48/28\"\ + ,\r\n \"52.180.40.16/28\",\r\n \"52.180.40.32/28\",\r\n\ + \ \"52.190.240.16/28\",\r\n \"52.190.240.32/28\",\r\n \ + \ \"52.190.240.64/27\",\r\n \"52.190.240.112/28\",\r\n \ + \ \"52.190.240.128/28\",\r\n \"52.225.40.32/27\",\r\n \ + \ \"52.238.56.16/28\",\r\n \"52.238.56.32/28\",\r\n \ + \ \"52.238.56.64/27\",\r\n \"52.238.56.112/28\",\r\n \"\ + 52.238.56.128/28\",\r\n \"52.238.56.160/27\",\r\n \"52.239.104.16/28\"\ + ,\r\n \"52.239.104.32/28\",\r\n \"52.239.160.0/22\",\r\n\ + \ \"52.239.228.0/23\",\r\n \"52.239.254.0/23\",\r\n \ + \ \"52.241.88.16/28\",\r\n \"52.241.88.32/28\",\r\n \ + \ \"52.241.88.64/27\",\r\n \"104.42.200.16/28\",\r\n \"\ + 138.91.128.128/26\",\r\n \"138.91.129.0/26\",\r\n \"168.62.0.0/26\"\ + ,\r\n \"168.62.1.128/26\",\r\n \"168.63.89.64/26\",\r\n\ + \ \"168.63.89.128/26\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"Storage.WestUS2\",\r\n \"id\": \"Storage.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"AzureStorage\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.176.16/28\",\r\n \"13.66.176.48/28\",\r\n \ + \ \"13.66.232.64/28\",\r\n \"13.66.232.208/28\",\r\n \ + \ \"13.66.232.224/28\",\r\n \"13.66.234.0/27\",\r\n \"\ + 13.77.184.64/28\",\r\n \"20.38.99.0/24\",\r\n \"20.47.62.0/23\"\ + ,\r\n \"20.60.20.0/24\",\r\n \"20.150.68.0/24\",\r\n \ + \ \"20.150.78.0/24\",\r\n \"20.150.87.0/24\",\r\n \ + \ \"20.150.107.0/24\",\r\n \"52.183.48.16/28\",\r\n \"52.183.104.16/28\"\ + ,\r\n \"52.183.104.32/28\",\r\n \"52.191.176.16/28\",\r\n\ + \ \"52.191.176.32/28\",\r\n \"52.239.148.128/25\",\r\n \ + \ \"52.239.176.128/25\",\r\n \"52.239.193.0/24\",\r\n \ + \ \"52.239.210.0/23\",\r\n \"52.239.236.0/23\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService\",\r\n\ + \ \"id\": \"StorageSyncService\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \"state\"\ + : \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\n \ + \ \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.70.176.196/32\",\r\n \"13.73.248.112/29\",\r\n \"13.75.153.240/32\"\ + ,\r\n \"13.76.81.46/32\",\r\n \"20.36.120.216/29\",\r\n\ + \ \"20.37.64.216/29\",\r\n \"20.37.157.80/29\",\r\n \ + \ \"20.37.195.96/29\",\r\n \"20.37.224.216/29\",\r\n \ + \ \"20.38.85.152/29\",\r\n \"20.38.136.224/29\",\r\n \"\ + 20.39.11.96/29\",\r\n \"20.41.5.144/29\",\r\n \"20.41.65.184/29\"\ + ,\r\n \"20.41.193.160/29\",\r\n \"20.42.4.248/29\",\r\n\ + \ \"20.42.131.224/29\",\r\n \"20.42.227.128/29\",\r\n \ + \ \"20.43.42.8/29\",\r\n \"20.43.66.0/29\",\r\n \"\ + 20.43.131.40/29\",\r\n \"20.45.71.151/32\",\r\n \"20.45.112.216/29\"\ + ,\r\n \"20.45.192.248/29\",\r\n \"20.50.1.0/29\",\r\n \ + \ \"20.150.161.152/29\",\r\n \"20.189.108.56/29\",\r\n \ + \ \"20.192.161.128/29\",\r\n \"20.192.225.200/29\",\r\n \ + \ \"23.100.106.151/32\",\r\n \"23.102.225.54/32\",\r\n \ + \ \"40.67.48.208/29\",\r\n \"40.80.57.192/29\",\r\n \ + \ \"40.80.169.176/29\",\r\n \"40.80.188.24/29\",\r\n \"\ + 40.82.253.192/29\",\r\n \"40.89.17.232/29\",\r\n \"40.112.150.67/32\"\ + ,\r\n \"40.113.94.67/32\",\r\n \"40.123.47.110/32\",\r\n\ + \ \"40.123.216.130/32\",\r\n \"51.104.25.224/29\",\r\n \ + \ \"51.105.80.208/29\",\r\n \"51.105.88.248/29\",\r\n \ + \ \"51.107.48.224/29\",\r\n \"51.107.144.216/29\",\r\n \ + \ \"51.120.40.224/29\",\r\n \"51.120.224.216/29\",\r\n \ + \ \"51.137.161.240/29\",\r\n \"51.140.67.72/32\",\r\n \ + \ \"51.140.202.34/32\",\r\n \"51.143.192.208/29\",\r\n \ + \ \"52.136.48.216/29\",\r\n \"52.136.131.99/32\",\r\n \"\ + 52.140.105.184/29\",\r\n \"52.143.166.54/32\",\r\n \"52.150.139.104/29\"\ + ,\r\n \"52.161.25.233/32\",\r\n \"52.176.149.179/32\",\r\ + \n \"52.183.27.204/32\",\r\n \"52.225.171.85/32\",\r\n \ + \ \"52.228.42.41/32\",\r\n \"52.228.81.248/29\",\r\n \ + \ \"52.231.67.75/32\",\r\n \"52.231.159.38/32\",\r\n \ + \ \"52.235.36.119/32\",\r\n \"65.52.62.167/32\",\r\n \"\ + 102.133.56.128/29\",\r\n \"102.133.75.173/32\",\r\n \"102.133.175.72/32\"\ + ,\r\n \"104.40.191.8/32\",\r\n \"104.41.148.238/32\",\r\n\ + \ \"104.41.161.113/32\",\r\n \"104.208.61.223/32\",\r\n\ + \ \"104.210.219.252/32\",\r\n \"104.211.73.56/32\",\r\n\ + \ \"104.211.231.18/32\",\r\n \"191.233.9.96/29\",\r\n \ + \ \"191.235.225.216/29\",\r\n \"191.237.253.115/32\",\r\n\ + \ \"2603:1000:104:1::300/123\",\r\n \"2603:1010:6:1::300/123\"\ + ,\r\n \"2603:1020:5:1::300/123\",\r\n \"2603:1020:206:1::300/123\"\ + ,\r\n \"2603:1020:705:1::300/123\",\r\n \"2603:1020:805:1::300/123\"\ + ,\r\n \"2603:1020:a04:1::300/123\",\r\n \"2603:1020:c04:1::300/123\"\ + ,\r\n \"2603:1020:e04:1::300/123\",\r\n \"2603:1020:1004::300/123\"\ + ,\r\n \"2603:1030:10:1::300/123\",\r\n \"2603:1030:104:1::300/123\"\ + ,\r\n \"2603:1030:210:1::300/123\",\r\n \"2603:1030:40b:1::300/123\"\ + ,\r\n \"2603:1030:40c:1::300/123\",\r\n \"2603:1030:504:1::300/123\"\ + ,\r\n \"2603:1030:807:1::300/123\",\r\n \"2603:1030:c06:1::300/123\"\ + ,\r\n \"2603:1030:f05:1::300/123\",\r\n \"2603:1040:5:1::300/123\"\ + ,\r\n \"2603:1040:407:1::300/123\",\r\n \"2603:1040:904:1::300/123\"\ + ,\r\n \"2603:1040:a06:1::300/123\",\r\n \"2603:1040:d04::300/123\"\ + ,\r\n \"2603:1040:f05:1::300/123\",\r\n \"2603:1050:6:1::300/123\"\ + ,\r\n \"2603:1050:403::300/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"StorageSyncService.AustraliaCentral\",\r\n \ + \ \"id\": \"StorageSyncService.AustraliaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.224.216/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"StorageSyncService.AustraliaCentral2\",\r\n \"id\": \"StorageSyncService.AustraliaCentral2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"australiacentral2\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"StorageSyncService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"20.36.120.216/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.AustraliaEast\"\ + ,\r\n \"id\": \"StorageSyncService.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.75.153.240/32\",\r\n \"20.37.195.96/29\",\r\n \"2603:1010:6:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.AustraliaSoutheast\"\ + ,\r\n \"id\": \"StorageSyncService.AustraliaSoutheast\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"australiasoutheast\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\ + \n \"13.70.176.196/32\",\r\n \"20.42.227.128/29\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.BrazilSouth\"\ + ,\r\n \"id\": \"StorageSyncService.BrazilSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 191.235.225.216/29\",\r\n \"191.237.253.115/32\",\r\n \"\ + 2603:1050:6:1::300/123\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"StorageSyncService.CanadaCentral\",\r\n \"id\": \"StorageSyncService.CanadaCentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"canadacentral\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n\ + \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"52.228.42.41/32\",\r\n \ + \ \"52.228.81.248/29\",\r\n \"2603:1030:f05:1::300/123\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.CanadaEast\"\ + ,\r\n \"id\": \"StorageSyncService.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.89.17.232/29\",\r\n \"52.235.36.119/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.CentralIndia\"\ + ,\r\n \"id\": \"StorageSyncService.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 52.140.105.184/29\",\r\n \"104.211.73.56/32\",\r\n \"2603:1040:a06:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.CentralUS\"\ + ,\r\n \"id\": \"StorageSyncService.CentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.37.157.80/29\",\r\n \"52.176.149.179/32\",\r\n \"2603:1030:10:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.CentralUSEUAP\"\ + ,\r\n \"id\": \"StorageSyncService.CentralUSEUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centraluseuap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.45.192.248/29\",\r\n \"104.208.61.223/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastAsia\"\ + ,\r\n \"id\": \"StorageSyncService.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.189.108.56/29\",\r\n \"23.102.225.54/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastUS\"\ + ,\r\n \"id\": \"StorageSyncService.EastUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.42.4.248/29\",\r\n \"104.41.148.238/32\",\r\n \"2603:1030:210:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastUS2\"\ + ,\r\n \"id\": \"StorageSyncService.EastUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.41.5.144/29\",\r\n \"40.123.47.110/32\",\r\n \"2603:1030:40c:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.EastUS2EUAP\"\ + ,\r\n \"id\": \"StorageSyncService.EastUS2EUAP\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastus2euap\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.39.11.96/29\",\r\n \"52.225.171.85/32\",\r\n \"2603:1030:40b:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.FranceCentral\"\ + ,\r\n \"id\": \"StorageSyncService.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.43.42.8/29\",\r\n \"52.143.166.54/32\",\r\n \"2603:1020:805:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.FranceSouth\"\ + ,\r\n \"id\": \"StorageSyncService.FranceSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.105.88.248/29\",\r\n \"52.136.131.99/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.GermanyWestCentral\"\ + ,\r\n \"id\": \"StorageSyncService.GermanyWestCentral\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\ + \n \"2603:1020:c04:1::300/123\"\r\n ]\r\n }\r\n },\r\ + \n {\r\n \"name\": \"StorageSyncService.JapanEast\",\r\n \"id\"\ + : \"StorageSyncService.JapanEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.43.66.0/29\",\r\n \ + \ \"104.41.161.113/32\",\r\n \"2603:1040:407:1::300/123\"\r\ + \n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.JapanWest\"\ + ,\r\n \"id\": \"StorageSyncService.JapanWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"japanwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 23.100.106.151/32\",\r\n \"40.80.57.192/29\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.KoreaCentral\"\ + ,\r\n \"id\": \"StorageSyncService.KoreaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.41.65.184/29\",\r\n \"52.231.67.75/32\",\r\n \"2603:1040:f05:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.KoreaSouth\"\ + ,\r\n \"id\": \"StorageSyncService.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.169.176/29\",\r\n \"52.231.159.38/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorthCentralUS\"\ + ,\r\n \"id\": \"StorageSyncService.NorthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 40.80.188.24/29\",\r\n \"65.52.62.167/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorthEurope\"\ + ,\r\n \"id\": \"StorageSyncService.NorthEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"northeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.38.85.152/29\",\r\n \"40.113.94.67/32\",\r\n \"2603:1020:5:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorwayEast\"\ + ,\r\n \"id\": \"StorageSyncService.NorwayEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.120.40.224/29\",\r\n \"2603:1020:e04:1::300/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.NorwayWest\"\ + ,\r\n \"id\": \"StorageSyncService.NorwayWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"norwayw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.120.224.216/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"StorageSyncService.SouthAfricaNorth\",\r\n \"id\": \"StorageSyncService.SouthAfricaNorth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\ + \n ],\r\n \"systemService\": \"StorageSyncService\",\r\n \ + \ \"addressPrefixes\": [\r\n \"102.133.175.72/32\",\r\n \ + \ \"2603:1000:104:1::300/123\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"StorageSyncService.SouthAfricaWest\",\r\n \ + \ \"id\": \"StorageSyncService.SouthAfricaWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southafricawest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 102.133.56.128/29\",\r\n \"102.133.75.173/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthCentralUS\"\ + ,\r\n \"id\": \"StorageSyncService.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.73.248.112/29\",\r\n \"104.210.219.252/32\",\r\n \"2603:1030:807:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SoutheastAsia\"\ + ,\r\n \"id\": \"StorageSyncService.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.76.81.46/32\",\r\n \"20.43.131.40/29\",\r\n \"2603:1040:5:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SouthIndia\"\ + ,\r\n \"id\": \"StorageSyncService.SouthIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.41.193.160/29\",\r\n \"104.211.231.18/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SwitzerlandNorth\"\ + ,\r\n \"id\": \"StorageSyncService.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.48.224/29\",\r\n \"2603:1020:a04:1::300/123\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.SwitzerlandWest\"\ + ,\r\n \"id\": \"StorageSyncService.SwitzerlandWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandw\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.107.144.216/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"StorageSyncService.UAECentral\",\r\n \"id\": \"StorageSyncService.UAECentral\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uaecentral\",\r\n \"state\": \"GA\",\r\n \"\ + networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"StorageSyncService\",\r\n \"\ + addressPrefixes\": [\r\n \"20.37.64.216/29\",\r\n \"20.45.71.151/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.UAENorth\"\ + ,\r\n \"id\": \"StorageSyncService.UAENorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaenorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.38.136.224/29\",\r\n \"40.123.216.130/32\",\r\n \"2603:1040:904:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.UKNorth\"\ + ,\r\n \"id\": \"StorageSyncService.UKNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uknorth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.105.80.208/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"StorageSyncService.UKSouth\",\r\n \"id\": \"StorageSyncService.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\ + \n \"51.104.25.224/29\",\r\n \"51.140.67.72/32\",\r\n \ + \ \"2603:1020:705:1::300/123\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"StorageSyncService.UKSouth2\",\r\n \"id\"\ + : \"StorageSyncService.UKSouth2\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"uksouth2\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"StorageSyncService\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.143.192.208/29\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.UKWest\"\ + ,\r\n \"id\": \"StorageSyncService.UKWest\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"ukwest\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 51.137.161.240/29\",\r\n \"51.140.202.34/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestCentralUS\"\ + ,\r\n \"id\": \"StorageSyncService.WestCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 52.150.139.104/29\",\r\n \"52.161.25.233/32\"\r\n ]\r\n \ + \ }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestEurope\"\ + ,\r\n \"id\": \"StorageSyncService.WestEurope\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.50.1.0/29\",\r\n \"104.40.191.8/32\",\r\n \"2603:1020:206:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestIndia\"\ + ,\r\n \"id\": \"StorageSyncService.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 52.136.48.216/29\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"StorageSyncService.WestUS\",\r\n \"id\": \"StorageSyncService.WestUS\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\ + \n \"40.82.253.192/29\",\r\n \"40.112.150.67/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"StorageSyncService.WestUS2\"\ + ,\r\n \"id\": \"StorageSyncService.WestUS2\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westus2\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"StorageSyncService\",\r\n \"addressPrefixes\": [\r\n \"\ + 20.42.131.224/29\",\r\n \"52.183.27.204/32\",\r\n \"2603:1030:c06:1::300/123\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\",\r\n \"FW\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.66.251.49/32\",\r\n \"13.67.68.78/32\",\r\n \"\ + 13.68.76.104/32\",\r\n \"13.69.82.138/32\",\r\n \"13.69.156.85/32\"\ + ,\r\n \"13.70.40.201/32\",\r\n \"13.70.120.215/32\",\r\n\ + \ \"13.71.5.20/32\",\r\n \"13.71.67.87/32\",\r\n \ + \ \"13.71.81.161/32\",\r\n \"13.71.113.6/32\",\r\n \"\ + 13.73.237.154/32\",\r\n \"13.75.114.143/32\",\r\n \"13.75.171.61/32\"\ + ,\r\n \"13.75.198.169/32\",\r\n \"13.76.88.89/32\",\r\n\ + \ \"13.76.195.19/32\",\r\n \"13.76.230.148/32\",\r\n \ + \ \"13.77.45.213/32\",\r\n \"13.77.140.58/32\",\r\n \ + \ \"13.79.243.194/32\",\r\n \"13.88.221.28/32\",\r\n \"\ + 13.88.254.98/32\",\r\n \"20.36.33.29/32\",\r\n \"20.36.33.170/32\"\ + ,\r\n \"20.36.35.190/32\",\r\n \"20.36.38.195/32\",\r\n\ + \ \"20.36.39.50/32\",\r\n \"20.36.39.171/32\",\r\n \ + \ \"20.36.41.74/32\",\r\n \"20.41.77.252/32\",\r\n \"\ + 20.45.64.86/32\",\r\n \"20.45.67.112/32\",\r\n \"20.45.67.185/32\"\ + ,\r\n \"20.45.79.3/32\",\r\n \"20.45.79.24/32\",\r\n \ + \ \"20.45.79.91/32\",\r\n \"20.45.79.96/32\",\r\n \ + \ \"20.45.79.168/32\",\r\n \"20.188.3.1/32\",\r\n \"20.188.39.108/32\"\ + ,\r\n \"20.188.41.240/32\",\r\n \"20.188.45.82/32\",\r\n\ + \ \"20.190.43.99/32\",\r\n \"23.97.108.170/32\",\r\n \ + \ \"23.98.66.174/32\",\r\n \"23.98.133.187/32\",\r\n \ + \ \"23.99.141.138/32\",\r\n \"23.100.50.154/32\",\r\n \ + \ \"23.100.98.36/32\",\r\n \"23.101.5.54/32\",\r\n \"23.101.220.135/32\"\ + ,\r\n \"23.102.229.113/32\",\r\n \"40.65.122.222/32\",\r\ + \n \"40.68.18.120/32\",\r\n \"40.69.31.73/32\",\r\n \ + \ \"40.69.90.166/32\",\r\n \"40.69.102.46/32\",\r\n \ + \ \"40.69.149.151/32\",\r\n \"40.70.189.87/32\",\r\n \"\ + 40.74.84.253/32\",\r\n \"40.74.113.202/32\",\r\n \"40.74.118.163/32\"\ + ,\r\n \"40.74.136.34/32\",\r\n \"40.83.79.39/32\",\r\n \ + \ \"40.85.241.159/32\",\r\n \"40.86.204.245/32\",\r\n \ + \ \"40.86.205.216/32\",\r\n \"40.86.208.118/32\",\r\n \ + \ \"40.86.222.183/32\",\r\n \"40.89.129.146/32\",\r\n \ + \ \"40.89.154.76/32\",\r\n \"40.113.199.138/32\",\r\n \ + \ \"40.113.200.58/32\",\r\n \"40.114.241.90/32\",\r\n \"\ + 40.115.136.175/32\",\r\n \"40.122.28.196/32\",\r\n \"40.122.212.20/32\"\ + ,\r\n \"40.127.3.207/32\",\r\n \"51.11.13.248/32\",\r\n\ + \ \"51.11.241.142/32\",\r\n \"51.104.49.88/32\",\r\n \ + \ \"51.105.54.123/32\",\r\n \"51.107.68.172/32\",\r\n \ + \ \"51.107.69.35/32\",\r\n \"51.107.78.168/32\",\r\n \ + \ \"51.107.85.67/32\",\r\n \"51.107.85.110/32\",\r\n \"\ + 51.107.86.7/32\",\r\n \"51.107.86.99/32\",\r\n \"51.116.171.102/32\"\ + ,\r\n \"51.116.182.248/32\",\r\n \"51.116.225.43/32\",\r\ + \n \"51.116.225.44/32\",\r\n \"51.116.225.55/32\",\r\n \ + \ \"51.116.236.74/32\",\r\n \"51.116.236.84/32\",\r\n \ + \ \"51.120.69.158/32\",\r\n \"51.120.70.135/32\",\r\n \ + \ \"51.120.70.141/32\",\r\n \"51.120.77.155/32\",\r\n \ + \ \"51.120.78.142/32\",\r\n \"51.120.79.212/32\",\r\n \ + \ \"51.120.88.120/32\",\r\n \"51.132.29.107/32\",\r\n \"\ + 51.136.28.200/32\",\r\n \"51.137.89.79/32\",\r\n \"51.140.57.159/32\"\ + ,\r\n \"51.140.206.110/32\",\r\n \"51.140.231.223/32\",\r\ + \n \"51.140.255.55/32\",\r\n \"51.141.30.31/32\",\r\n \ + \ \"51.141.173.236/32\",\r\n \"51.143.39.79/32\",\r\n \ + \ \"51.143.164.192/32\",\r\n \"51.143.169.107/32\",\r\n \ + \ \"51.145.17.75/32\",\r\n \"52.137.2.50/32\",\r\n \ + \ \"52.138.20.115/32\",\r\n \"52.138.28.23/32\",\r\n \"\ + 52.141.37.201/32\",\r\n \"52.141.56.101/32\",\r\n \"52.142.161.0/32\"\ + ,\r\n \"52.142.162.226/32\",\r\n \"52.143.96.87/32\",\r\n\ + \ \"52.143.182.208/32\",\r\n \"52.147.3.93/32\",\r\n \ + \ \"52.151.53.196/32\",\r\n \"52.155.111.124/32\",\r\n \ + \ \"52.156.171.127/32\",\r\n \"52.163.209.255/32\",\r\n \ + \ \"52.164.126.124/32\",\r\n \"52.165.218.15/32\",\r\n \ + \ \"52.167.163.135/32\",\r\n \"52.167.171.53/32\",\r\n \ + \ \"52.169.5.116/32\",\r\n \"52.172.34.74/32\",\r\n \"\ + 52.172.40.215/32\",\r\n \"52.172.133.5/32\",\r\n \"52.172.194.109/32\"\ + ,\r\n \"52.172.210.235/32\",\r\n \"52.172.217.34/32\",\r\ + \n \"52.172.223.46/32\",\r\n \"52.173.89.168/32\",\r\n \ + \ \"52.175.144.120/32\",\r\n \"52.175.253.156/32\",\r\n \ + \ \"52.177.123.162/32\",\r\n \"52.177.172.247/32\",\r\n \ + \ \"52.183.19.64/32\",\r\n \"52.183.130.137/32\",\r\n \ + \ \"52.185.202.152/32\",\r\n \"52.187.127.152/32\",\r\n \ + \ \"52.189.194.14/32\",\r\n \"52.189.215.151/32\",\r\n \ + \ \"52.189.233.158/32\",\r\n \"52.191.129.231/32\",\r\n \ + \ \"52.228.29.164/32\",\r\n \"52.229.117.254/32\",\r\n \ + \ \"52.229.125.45/32\",\r\n \"52.229.207.180/32\",\r\n \ + \ \"52.231.13.193/32\",\r\n \"52.231.38.211/32\",\r\n \ + \ \"52.231.93.224/32\",\r\n \"52.231.98.58/32\",\r\n \"\ + 52.231.155.130/32\",\r\n \"52.231.156.19/32\",\r\n \"52.231.164.163/32\"\ + ,\r\n \"52.231.166.199/32\",\r\n \"52.231.195.7/32\",\r\n\ + \ \"52.231.197.195/32\",\r\n \"52.231.206.162/32\",\r\n\ + \ \"52.233.16.198/32\",\r\n \"52.237.20.14/32\",\r\n \ + \ \"52.237.201.246/32\",\r\n \"52.237.253.245/32\",\r\n \ + \ \"52.242.86.101/32\",\r\n \"52.243.65.107/32\",\r\n \ + \ \"52.243.74.213/32\",\r\n \"52.246.165.140/32\",\r\n \ + \ \"52.246.177.221/32\",\r\n \"52.246.191.98/32\",\r\n \ + \ \"52.247.122.225/32\",\r\n \"52.247.123.0/32\",\r\n \ + \ \"52.255.40.105/32\",\r\n \"52.255.61.145/32\",\r\n \"\ + 65.52.71.120/32\",\r\n \"65.52.158.177/32\",\r\n \"70.37.83.67/32\"\ + ,\r\n \"70.37.86.126/32\",\r\n \"70.37.99.24/32\",\r\n \ + \ \"102.37.42.159/32\",\r\n \"102.133.161.220/32\",\r\n \ + \ \"102.133.166.135/32\",\r\n \"102.133.172.191/32\",\r\n\ + \ \"102.133.175.200/32\",\r\n \"102.133.224.81/32\",\r\n\ + \ \"102.133.234.139/32\",\r\n \"104.40.156.194/32\",\r\n\ + \ \"104.41.45.182/32\",\r\n \"104.41.166.159/32\",\r\n \ + \ \"104.43.169.4/32\",\r\n \"104.46.237.209/32\",\r\n \ + \ \"104.208.28.82/32\",\r\n \"104.209.233.222/32\",\r\n \ + \ \"104.210.150.160/32\",\r\n \"104.211.78.17/32\",\r\n \ + \ \"104.211.114.61/32\",\r\n \"104.211.138.88/32\",\r\n \ + \ \"104.211.140.190/32\",\r\n \"104.211.155.114/32\",\r\n \ + \ \"104.211.165.123/32\",\r\n \"104.211.184.150/32\",\r\n\ + \ \"104.211.188.151/32\",\r\n \"104.211.211.213/32\",\r\n\ + \ \"104.211.216.230/32\",\r\n \"104.211.242.104/32\",\r\n\ + \ \"104.214.60.144/32\",\r\n \"104.214.237.23/32\",\r\n\ + \ \"104.215.51.3/32\",\r\n \"104.215.103.51/32\",\r\n \ + \ \"137.116.49.12/32\",\r\n \"137.116.248.148/32\",\r\n \ + \ \"137.117.171.26/32\",\r\n \"137.135.243.65/32\",\r\n \ + \ \"138.91.44.13/32\",\r\n \"168.61.167.193/32\",\r\n \ + \ \"168.63.31.54/32\",\r\n \"168.63.71.119/32\",\r\n \ + \ \"168.63.137.213/32\",\r\n \"191.232.49.74/32\",\r\n \ + \ \"191.232.166.149/32\",\r\n \"191.232.238.73/32\",\r\n \ + \ \"191.234.191.63/32\",\r\n \"191.235.65.127/32\",\r\n \ + \ \"191.235.73.211/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"WindowsVirtualDesktop.AustraliaCentral\",\r\n \"id\"\ + : \"WindowsVirtualDesktop.AustraliaCentral\",\r\n \"properties\": {\r\ + \n \"changeNumber\": \"1\",\r\n \"region\": \"australiacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.36.33.29/32\",\r\n \"20.36.33.170/32\",\r\n \"\ + 20.36.35.190/32\",\r\n \"20.36.38.195/32\",\r\n \"20.36.39.50/32\"\ + ,\r\n \"20.36.39.171/32\",\r\n \"20.36.41.74/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.AustraliaEast\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.AustraliaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.70.120.215/32\",\r\n \"13.75.171.61/32\",\r\n \"\ + 13.75.198.169/32\",\r\n \"23.101.220.135/32\",\r\n \"52.147.3.93/32\"\ + ,\r\n \"52.156.171.127/32\",\r\n \"52.237.201.246/32\",\r\ + \n \"52.237.253.245/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"WindowsVirtualDesktop.AustraliaSoutheast\",\r\n\ + \ \"id\": \"WindowsVirtualDesktop.AustraliaSoutheast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"australiasoutheast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.77.45.213/32\",\r\n \"52.189.194.14/32\",\r\n \"\ + 52.189.215.151/32\",\r\n \"52.189.233.158/32\",\r\n \"52.243.65.107/32\"\ + ,\r\n \"52.243.74.213/32\",\r\n \"52.255.40.105/32\",\r\n\ + \ \"52.255.61.145/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.BrazilSouth\",\r\n \"id\":\ + \ \"WindowsVirtualDesktop.BrazilSouth\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"brazilsouth\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.97.108.170/32\",\r\n \"104.41.45.182/32\",\r\n \ + \ \"191.232.49.74/32\",\r\n \"191.232.166.149/32\",\r\n \ + \ \"191.232.238.73/32\",\r\n \"191.234.191.63/32\",\r\n \ + \ \"191.235.65.127/32\",\r\n \"191.235.73.211/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CanadaCentral\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.CanadaCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadacentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.88.254.98/32\",\r\n \"40.85.241.159/32\",\r\n \"\ + 52.138.20.115/32\",\r\n \"52.138.28.23/32\",\r\n \"52.228.29.164/32\"\ + ,\r\n \"52.233.16.198/32\",\r\n \"52.237.20.14/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CanadaEast\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.CanadaEast\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"canadaeast\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"40.69.102.46/32\",\r\n \"40.86.204.245/32\",\r\n \"\ + 40.86.205.216/32\",\r\n \"40.86.208.118/32\",\r\n \"40.86.222.183/32\"\ + ,\r\n \"52.229.117.254/32\",\r\n \"52.229.125.45/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.CentralIndia\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.CentralIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.71.5.20/32\",\r\n \"52.172.133.5/32\",\r\n \"52.172.194.109/32\"\ + ,\r\n \"52.172.210.235/32\",\r\n \"52.172.217.34/32\",\r\ + \n \"52.172.223.46/32\",\r\n \"104.211.78.17/32\",\r\n \ + \ \"104.211.114.61/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.CentralUS\",\r\n \"id\": \"\ + WindowsVirtualDesktop.CentralUS\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"centralus\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\"\ + ,\r\n \"addressPrefixes\": [\r\n \"23.99.141.138/32\",\r\n\ + \ \"40.69.149.151/32\",\r\n \"40.113.199.138/32\",\r\n \ + \ \"40.113.200.58/32\",\r\n \"40.122.28.196/32\",\r\n \ + \ \"40.122.212.20/32\",\r\n \"52.165.218.15/32\",\r\n \ + \ \"52.173.89.168/32\",\r\n \"104.43.169.4/32\",\r\n \ + \ \"104.208.28.82/32\",\r\n \"168.61.167.193/32\"\r\n ]\r\ + \n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.EastAsia\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.EastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"eastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.70.40.201/32\",\r\n \"13.75.114.143/32\",\r\n \"\ + 13.88.221.28/32\",\r\n \"23.101.5.54/32\",\r\n \"23.102.229.113/32\"\ + ,\r\n \"40.83.79.39/32\",\r\n \"52.229.207.180/32\",\r\n\ + \ \"168.63.137.213/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"WindowsVirtualDesktop.EastUS2\",\r\n \"id\"\ + : \"WindowsVirtualDesktop.EastUS2\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"eastus2\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.68.76.104/32\",\r\n\ + \ \"40.70.189.87/32\",\r\n \"52.167.163.135/32\",\r\n \ + \ \"52.167.171.53/32\",\r\n \"52.177.123.162/32\",\r\n \ + \ \"52.177.172.247/32\",\r\n \"52.242.86.101/32\",\r\n \ + \ \"52.247.122.225/32\",\r\n \"52.247.123.0/32\",\r\n \ + \ \"104.209.233.222/32\",\r\n \"137.116.49.12/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.FranceCentral\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.FranceCentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"centralfrance\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.188.39.108/32\",\r\n \"20.188.41.240/32\",\r\n \ + \ \"20.188.45.82/32\",\r\n \"40.89.129.146/32\",\r\n \"\ + 40.89.154.76/32\",\r\n \"51.11.241.142/32\",\r\n \"52.143.182.208/32\"\ + \r\n ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.GermanyWestCentral\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.GermanyWestCentral\",\r\n \ + \ \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"germanywc\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.116.171.102/32\",\r\n \"51.116.182.248/32\"\ + ,\r\n \"51.116.225.43/32\",\r\n \"51.116.225.44/32\",\r\n\ + \ \"51.116.225.55/32\",\r\n \"51.116.236.74/32\",\r\n \ + \ \"51.116.236.84/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.JapanEast\",\r\n \"id\": \"\ + WindowsVirtualDesktop.JapanEast\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japaneast\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\"\ + ,\r\n \"addressPrefixes\": [\r\n \"20.188.3.1/32\",\r\n \ + \ \"23.100.98.36/32\",\r\n \"40.115.136.175/32\",\r\n \ + \ \"52.155.111.124/32\",\r\n \"52.246.165.140/32\",\r\n \ + \ \"52.246.177.221/32\",\r\n \"52.246.191.98/32\",\r\n \ + \ \"104.41.166.159/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"WindowsVirtualDesktop.JapanWest\",\r\n \"id\": \"\ + WindowsVirtualDesktop.JapanWest\",\r\n \"properties\": {\r\n \"\ + changeNumber\": \"1\",\r\n \"region\": \"japanwest\",\r\n \"\ + state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\",\r\ + \n \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\"\ + ,\r\n \"addressPrefixes\": [\r\n \"13.73.237.154/32\",\r\n\ + \ \"40.74.84.253/32\",\r\n \"40.74.113.202/32\",\r\n \ + \ \"40.74.118.163/32\",\r\n \"40.74.136.34/32\",\r\n \ + \ \"52.175.144.120/32\",\r\n \"104.46.237.209/32\",\r\n \ + \ \"104.215.51.3/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \ + \ \"name\": \"WindowsVirtualDesktop.KoreaCentral\",\r\n \"id\": \"\ + WindowsVirtualDesktop.KoreaCentral\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"koreacentral\",\r\n\ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.41.77.252/32\",\r\n \"52.141.37.201/32\",\r\n \"\ + 52.141.56.101/32\",\r\n \"52.231.13.193/32\",\r\n \"52.231.38.211/32\"\ + ,\r\n \"52.231.93.224/32\",\r\n \"52.231.98.58/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.KoreaSouth\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.KoreaSouth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"koreasouth\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.231.155.130/32\",\r\n \"52.231.156.19/32\",\r\n \ + \ \"52.231.164.163/32\",\r\n \"52.231.166.199/32\",\r\n \ + \ \"52.231.195.7/32\",\r\n \"52.231.197.195/32\",\r\n \"\ + 52.231.206.162/32\"\r\n ]\r\n }\r\n },\r\n {\r\n \"\ + name\": \"WindowsVirtualDesktop.NorthEurope\",\r\n \"id\": \"WindowsVirtualDesktop.NorthEurope\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"northeurope\",\r\n \"state\": \"GA\",\r\n \ + \ \"networkFeatures\": [\r\n \"API\",\r\n \"NSG\"\r\n \ + \ ],\r\n \"systemService\": \"WindowsVirtualDesktop\",\r\n \ + \ \"addressPrefixes\": [\r\n \"13.69.156.85/32\",\r\n \ + \ \"13.79.243.194/32\",\r\n \"23.100.50.154/32\",\r\n \ + \ \"40.69.31.73/32\",\r\n \"40.69.90.166/32\",\r\n \"52.164.126.124/32\"\ + ,\r\n \"52.169.5.116/32\",\r\n \"65.52.71.120/32\",\r\n\ + \ \"137.116.248.148/32\",\r\n \"137.135.243.65/32\",\r\n\ + \ \"168.63.71.119/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.NorwayEast\",\r\n \"id\": \"\ + WindowsVirtualDesktop.NorwayEast\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"norwaye\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"API\"\ + ,\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"WindowsVirtualDesktop\"\ + ,\r\n \"addressPrefixes\": [\r\n \"51.120.69.158/32\",\r\n\ + \ \"51.120.70.135/32\",\r\n \"51.120.70.141/32\",\r\n \ + \ \"51.120.77.155/32\",\r\n \"51.120.78.142/32\",\r\n \ + \ \"51.120.79.212/32\",\r\n \"51.120.88.120/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.SouthAfricaNorth\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.SouthAfricaNorth\",\r\n \"\ + properties\": {\r\n \"changeNumber\": \"1\",\r\n \"region\"\ + : \"southafricanorth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\"\ + : [\r\n \"40.127.3.207/32\",\r\n \"102.37.42.159/32\",\r\ + \n \"102.133.161.220/32\",\r\n \"102.133.166.135/32\",\r\ + \n \"102.133.172.191/32\",\r\n \"102.133.175.200/32\",\r\ + \n \"102.133.224.81/32\",\r\n \"102.133.234.139/32\"\r\n\ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.SouthCentralUS\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.SouthCentralUS\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southcentralus\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"23.98.133.187/32\",\r\n \"52.185.202.152/32\",\r\n \ + \ \"70.37.83.67/32\",\r\n \"70.37.86.126/32\",\r\n \"70.37.99.24/32\"\ + ,\r\n \"104.210.150.160/32\",\r\n \"104.214.60.144/32\"\ + ,\r\n \"104.215.103.51/32\"\r\n ]\r\n }\r\n },\r\n\ + \ {\r\n \"name\": \"WindowsVirtualDesktop.SoutheastAsia\",\r\n \ + \ \"id\": \"WindowsVirtualDesktop.SoutheastAsia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"southeastasia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"13.67.68.78/32\",\r\n \"13.76.88.89/32\",\r\n \"13.76.195.19/32\"\ + ,\r\n \"13.76.230.148/32\",\r\n \"23.98.66.174/32\",\r\n\ + \ \"52.163.209.255/32\",\r\n \"52.187.127.152/32\",\r\n\ + \ \"138.91.44.13/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.SouthIndia\",\r\n \"id\": \"\ + WindowsVirtualDesktop.SouthIndia\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"southindia\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.71.67.87/32\",\r\n \"13.71.81.161/32\",\r\n \"13.71.113.6/32\"\ + ,\r\n \"52.172.34.74/32\",\r\n \"52.172.40.215/32\",\r\n\ + \ \"104.211.211.213/32\",\r\n \"104.211.216.230/32\",\r\n\ + \ \"104.211.242.104/32\"\r\n ]\r\n }\r\n },\r\n \ + \ {\r\n \"name\": \"WindowsVirtualDesktop.SwitzerlandNorth\",\r\n \ + \ \"id\": \"WindowsVirtualDesktop.SwitzerlandNorth\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"switzerlandn\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"51.107.68.172/32\",\r\n \"51.107.69.35/32\",\r\n \"\ + 51.107.78.168/32\",\r\n \"51.107.85.67/32\",\r\n \"51.107.85.110/32\"\ + ,\r\n \"51.107.86.7/32\",\r\n \"51.107.86.99/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.UAECentral\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.UAECentral\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"uaecentral\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"20.45.64.86/32\",\r\n \"20.45.67.112/32\",\r\n \"\ + 20.45.67.185/32\",\r\n \"20.45.79.3/32\",\r\n \"20.45.79.24/32\"\ + ,\r\n \"20.45.79.91/32\",\r\n \"20.45.79.96/32\",\r\n \ + \ \"20.45.79.168/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"WindowsVirtualDesktop.UKSouth\",\r\n \"id\": \"WindowsVirtualDesktop.UKSouth\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"uksouth\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.11.13.248/32\",\r\n \"51.105.54.123/32\",\r\ + \n \"51.132.29.107/32\",\r\n \"51.140.57.159/32\",\r\n \ + \ \"51.143.164.192/32\",\r\n \"51.143.169.107/32\",\r\n \ + \ \"51.145.17.75/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.UKWest\",\r\n \"id\": \"WindowsVirtualDesktop.UKWest\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"ukwest\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\"\ + : [\r\n \"51.104.49.88/32\",\r\n \"51.140.206.110/32\",\r\ + \n \"51.140.231.223/32\",\r\n \"51.140.255.55/32\",\r\n\ + \ \"51.141.30.31/32\",\r\n \"52.142.161.0/32\",\r\n \ + \ \"52.142.162.226/32\"\r\n ]\r\n }\r\n },\r\n {\r\n\ + \ \"name\": \"WindowsVirtualDesktop.WestEurope\",\r\n \"id\": \"\ + WindowsVirtualDesktop.WestEurope\",\r\n \"properties\": {\r\n \ + \ \"changeNumber\": \"1\",\r\n \"region\": \"westeurope\",\r\n \ + \ \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \"\ + API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\": \"\ + WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \"\ + 13.69.82.138/32\",\r\n \"40.68.18.120/32\",\r\n \"40.114.241.90/32\"\ + ,\r\n \"51.136.28.200/32\",\r\n \"51.137.89.79/32\",\r\n\ + \ \"52.137.2.50/32\",\r\n \"65.52.158.177/32\",\r\n \ + \ \"104.40.156.194/32\",\r\n \"104.214.237.23/32\",\r\n \ + \ \"137.117.171.26/32\",\r\n \"168.63.31.54/32\"\r\n \ + \ ]\r\n }\r\n },\r\n {\r\n \"name\": \"WindowsVirtualDesktop.WestIndia\"\ + ,\r\n \"id\": \"WindowsVirtualDesktop.WestIndia\",\r\n \"properties\"\ + : {\r\n \"changeNumber\": \"1\",\r\n \"region\": \"westindia\"\ + ,\r\n \"state\": \"GA\",\r\n \"networkFeatures\": [\r\n \ + \ \"API\",\r\n \"NSG\"\r\n ],\r\n \"systemService\"\ + : \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\": [\r\n \ + \ \"52.183.130.137/32\",\r\n \"104.211.138.88/32\",\r\n \ + \ \"104.211.140.190/32\",\r\n \"104.211.155.114/32\",\r\n \ + \ \"104.211.165.123/32\",\r\n \"104.211.184.150/32\",\r\n \ + \ \"104.211.188.151/32\"\r\n ]\r\n }\r\n },\r\n {\r\ + \n \"name\": \"WindowsVirtualDesktop.WestUS2\",\r\n \"id\": \"WindowsVirtualDesktop.WestUS2\"\ + ,\r\n \"properties\": {\r\n \"changeNumber\": \"1\",\r\n \ + \ \"region\": \"westus2\",\r\n \"state\": \"GA\",\r\n \"networkFeatures\"\ + : [\r\n \"API\",\r\n \"NSG\"\r\n ],\r\n \"\ + systemService\": \"WindowsVirtualDesktop\",\r\n \"addressPrefixes\"\ + : [\r\n \"13.66.251.49/32\",\r\n \"13.77.140.58/32\",\r\n\ + \ \"20.190.43.99/32\",\r\n \"40.65.122.222/32\",\r\n \ + \ \"51.141.173.236/32\",\r\n \"51.143.39.79/32\",\r\n \ + \ \"52.143.96.87/32\",\r\n \"52.151.53.196/32\",\r\n \ + \ \"52.175.253.156/32\",\r\n \"52.183.19.64/32\",\r\n \"\ + 52.191.129.231/32\"\r\n ]\r\n }\r\n }\r\n ],\r\n \"nextLink\"\ + : \"\"\r\n}" headers: cache-control: - no-cache content-length: - - '1260977' + - '1260996' content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:56 GMT + - Tue, 26 Jan 2021 08:52:51 GMT expires: - '-1' pragma: @@ -16008,7 +19207,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 87850524-c4d3-46d0-af45-aa55b1eb292c + - 52dfe04f-e300-4b82-8176-e924baee2964 status: code: 200 message: OK @@ -16027,19 +19226,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\",\r\n - \ \"etag\": \"W/\\\"3273fa36-3dd9-43ff-9df1-40b1e4d09c42\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"access\": \"Allow\",\r\n - \ \"routeFilterRuleType\": \"Community\",\r\n \"communities\": [\r\n - \ \"12076:51004\"\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" + string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\"\ + ,\r\n \"etag\": \"W/\\\"56c60053-f744-4b24-91e2-8041eae07d90\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + access\": \"Allow\",\r\n \"routeFilterRuleType\": \"Community\",\r\n \ + \ \"communities\": [\r\n \"12076:51004\"\r\n ]\r\n },\r\n \"type\"\ + : \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f0bc4121-8096-4e1f-b980-833626e6f460?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/83f801b7-dfc6-4cae-9a72-1feece758cd1?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -16047,7 +19247,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:36:56 GMT + - Tue, 26 Jan 2021 08:52:52 GMT expires: - '-1' pragma: @@ -16060,9 +19260,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0ed59954-9723-442b-802d-5f2c234fcbb0 + - 93d41af4-c773-476e-b4db-2aa739f294c8 x-ms-ratelimit-remaining-subscription-writes: - - '1191' + - '1194' status: code: 201 message: Created @@ -16076,9 +19276,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f0bc4121-8096-4e1f-b980-833626e6f460?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/83f801b7-dfc6-4cae-9a72-1feece758cd1?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -16090,7 +19290,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:07 GMT + - Tue, 26 Jan 2021 08:53:02 GMT expires: - '-1' pragma: @@ -16107,7 +19307,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ab7555ec-1d51-4d78-958a-1d963574a6f8 + - f8f426a1-0898-4c8d-9c09-453c8796c1f3 status: code: 200 message: OK @@ -16121,16 +19321,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\",\r\n - \ \"etag\": \"W/\\\"9e0941ef-26d7-49aa-964a-a51adbe9d450\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"access\": \"Allow\",\r\n - \ \"routeFilterRuleType\": \"Community\",\r\n \"communities\": [\r\n - \ \"12076:51004\"\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" + string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\"\ + ,\r\n \"etag\": \"W/\\\"7a7f43be-5c0f-4a4a-a0af-af243cecff34\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + access\": \"Allow\",\r\n \"routeFilterRuleType\": \"Community\",\r\n \ + \ \"communities\": [\r\n \"12076:51004\"\r\n ]\r\n },\r\n \"type\"\ + : \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" headers: cache-control: - no-cache @@ -16139,9 +19340,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:07 GMT + - Tue, 26 Jan 2021 08:53:03 GMT etag: - - W/"9e0941ef-26d7-49aa-964a-a51adbe9d450" + - W/"7a7f43be-5c0f-4a4a-a0af-af243cecff34" expires: - '-1' pragma: @@ -16158,7 +19359,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6a957b10-97b5-4c06-989d-41e12776805a + - 3f9ecc44-0689-4a17-ba57-cd8aa853ff56 status: code: 200 message: OK @@ -16172,16 +19373,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\",\r\n - \ \"etag\": \"W/\\\"9e0941ef-26d7-49aa-964a-a51adbe9d450\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"access\": \"Allow\",\r\n - \ \"routeFilterRuleType\": \"Community\",\r\n \"communities\": [\r\n - \ \"12076:51004\"\r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" + string: "{\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\"\ + ,\r\n \"etag\": \"W/\\\"7a7f43be-5c0f-4a4a-a0af-af243cecff34\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + access\": \"Allow\",\r\n \"routeFilterRuleType\": \"Community\",\r\n \ + \ \"communities\": [\r\n \"12076:51004\"\r\n ]\r\n },\r\n \"type\"\ + : \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n}" headers: cache-control: - no-cache @@ -16190,9 +19392,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:07 GMT + - Tue, 26 Jan 2021 08:53:03 GMT etag: - - W/"9e0941ef-26d7-49aa-964a-a51adbe9d450" + - W/"7a7f43be-5c0f-4a4a-a0af-af243cecff34" expires: - '-1' pragma: @@ -16209,7 +19411,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5ea3f449-66e1-4f01-9572-ecf0dc1db0eb + - b7c1ca30-874e-4cb8-b48b-f9dac4fe8549 status: code: 200 message: OK @@ -16223,23 +19425,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\",\r\n - \ \"etag\": \"W/\\\"9e0941ef-26d7-49aa-964a-a51adbe9d450\\\"\",\r\n \"type\": - \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"rules\": [\r\n {\r\n \"name\": \"myRule\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\",\r\n - \ \"etag\": \"W/\\\"9e0941ef-26d7-49aa-964a-a51adbe9d450\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"access\": \"Allow\",\r\n \"routeFilterRuleType\": \"Community\",\r\n - \ \"communities\": [\r\n \"12076:51004\"\r\n ]\r\n - \ },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\"\ + ,\r\n \"etag\": \"W/\\\"7a7f43be-5c0f-4a4a-a0af-af243cecff34\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"rules\": [\r\n \ + \ {\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\"\ + ,\r\n \"etag\": \"W/\\\"7a7f43be-5c0f-4a4a-a0af-af243cecff34\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"access\": \"Allow\",\r\n \"routeFilterRuleType\"\ + : \"Community\",\r\n \"communities\": [\r\n \"12076:51004\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -16248,9 +19450,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:08 GMT + - Tue, 26 Jan 2021 08:53:03 GMT etag: - - W/"9e0941ef-26d7-49aa-964a-a51adbe9d450" + - W/"7a7f43be-5c0f-4a4a-a0af-af243cecff34" expires: - '-1' pragma: @@ -16267,7 +19469,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 23cc3dc2-1f9e-45dd-ba64-2d78c7961542 + - c7f58a37-3e7c-4b53-8509-adf1cb4ed602 status: code: 200 message: OK @@ -16285,23 +19487,23 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\",\r\n - \ \"etag\": \"W/\\\"46f7b113-ae53-4056-99e8-b6269ea13f77\\\"\",\r\n \"type\": - \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\",\r\n \"tags\": - {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"rules\": [\r\n {\r\n \"name\": \"myRule\",\r\n - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\",\r\n - \ \"etag\": \"W/\\\"46f7b113-ae53-4056-99e8-b6269ea13f77\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"access\": \"Allow\",\r\n \"routeFilterRuleType\": \"Community\",\r\n - \ \"communities\": [\r\n \"12076:51004\"\r\n ]\r\n - \ },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\r\n - \ }\r\n ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteFilter\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter\"\ + ,\r\n \"etag\": \"W/\\\"9d54e4e2-5dbc-4bc2-923e-5f4bc2774ec3\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeFilters\",\r\n \"location\": \"eastus\"\ + ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ + : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"rules\": [\r\n \ + \ {\r\n \"name\": \"myRule\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule\"\ + ,\r\n \"etag\": \"W/\\\"9d54e4e2-5dbc-4bc2-923e-5f4bc2774ec3\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"access\": \"Allow\",\r\n \"routeFilterRuleType\"\ + : \"Community\",\r\n \"communities\": [\r\n \"12076:51004\"\ + \r\n ]\r\n },\r\n \"type\": \"Microsoft.Network/routeFilters/routeFilterRules\"\ + \r\n }\r\n ]\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -16312,7 +19514,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:10 GMT + - Tue, 26 Jan 2021 08:53:06 GMT expires: - '-1' pragma: @@ -16329,9 +19531,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f1039dc6-bd51-4f74-96ae-e85fb6e38b8c + - a431487b-a25a-4ebc-8f6f-2ec32efed661 x-ms-ratelimit-remaining-subscription-writes: - - '1190' + - '1193' status: code: 200 message: OK @@ -16347,25 +19549,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter/routeFilterRules/myRule?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ab78b78f-2080-4846-b06a-666e29ae99f8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3e5d3ed2-4ba8-43b9-b307-1c3460d369b6?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:37:11 GMT + - Tue, 26 Jan 2021 08:53:07 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/ab78b78f-2080-4846-b06a-666e29ae99f8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/3e5d3ed2-4ba8-43b9-b307-1c3460d369b6?api-version=2020-08-01 pragma: - no-cache server: @@ -16376,9 +19578,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c87b36b2-cb90-4d45-8992-9bdb95a90507 + - 3d369745-c730-41f8-a6af-d780c1ac4ba4 x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 202 message: Accepted @@ -16392,9 +19594,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/ab78b78f-2080-4846-b06a-666e29ae99f8?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3e5d3ed2-4ba8-43b9-b307-1c3460d369b6?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -16406,7 +19608,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:21 GMT + - Tue, 26 Jan 2021 08:53:17 GMT expires: - '-1' pragma: @@ -16423,7 +19625,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ff339e33-b3a7-431b-8fae-637e42ebe0cf + - 892dd025-ff41-462f-a355-10f313070341 status: code: 200 message: OK @@ -16439,9 +19641,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeFilters/myRouteFilter?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeFilters/myRouteFilter?api-version=2020-08-01 response: body: string: '' @@ -16449,17 +19651,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e7bdca9a-ff69-4c91-981f-88839ae680da?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/27d7d582-dd1d-49e5-9ea5-6013d8e0c4ae?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:37:23 GMT + - Tue, 26 Jan 2021 08:53:18 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/e7bdca9a-ff69-4c91-981f-88839ae680da?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/27d7d582-dd1d-49e5-9ea5-6013d8e0c4ae?api-version=2020-08-01 pragma: - no-cache server: @@ -16470,9 +19672,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9c76057a-b8b0-42a1-a6d1-226d087f2365 + - 94f43f69-9f57-47d2-831d-9873eaf33577 x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14998' status: code: 202 message: Accepted @@ -16486,9 +19688,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/e7bdca9a-ff69-4c91-981f-88839ae680da?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/27d7d582-dd1d-49e5-9ea5-6013d8e0c4ae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -16500,7 +19702,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:33 GMT + - Tue, 26 Jan 2021 08:53:28 GMT expires: - '-1' pragma: @@ -16517,7 +19719,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d53ed495-cac6-4770-afd1-d5ed381a2943 + - f08d1c3e-f91c-48d9-8fa4-e3ebcd32a696 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_table.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_table.test_network.yaml index 7d02aabbede3..1f51ebd9e2c9 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_table.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_route_table.test_network.yaml @@ -13,21 +13,22 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\",\r\n - \ \"etag\": \"W/\\\"0046583c-43a8-4082-8c9e-8bfae508f67b\\\"\",\r\n \"type\": - \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"resourceGuid\": \"2fcb23f1-c8e5-432b-9943-e4ef03803686\",\r\n - \ \"disableBgpRoutePropagation\": false,\r\n \"routes\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\"\ + ,\r\n \"etag\": \"W/\\\"6082357e-430f-4561-8fff-a099c575471a\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ + \ \"resourceGuid\": \"00527bbc-ff38-4e3c-9c24-b81896817399\",\r\n \"\ + disableBgpRoutePropagation\": false,\r\n \"routes\": []\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/db2ca8a5-8d89-4b4a-a44c-48e47b54e043?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3ce05b4b-07db-4fe4-bec1-efe5a36ed49b?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -35,7 +36,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:43 GMT + - Tue, 26 Jan 2021 08:53:52 GMT expires: - '-1' pragma: @@ -48,9 +49,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5355dd11-a21f-4fe4-8cce-de5236b6c585 + - 049912b6-cd1d-4e1c-880b-09cb4371ac25 x-ms-ratelimit-remaining-subscription-writes: - - '1189' + - '1199' status: code: 201 message: Created @@ -64,9 +65,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/db2ca8a5-8d89-4b4a-a44c-48e47b54e043?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3ce05b4b-07db-4fe4-bec1-efe5a36ed49b?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -78,7 +79,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:54 GMT + - Tue, 26 Jan 2021 08:54:03 GMT expires: - '-1' pragma: @@ -95,7 +96,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5c2f5c09-7f52-40b2-916f-843b09481776 + - 28e102ee-5918-477b-b10b-d4a6226891f0 status: code: 200 message: OK @@ -109,16 +110,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\",\r\n - \ \"etag\": \"W/\\\"ed31a5b7-fa2a-4433-a1c8-d049f3ef9607\\\"\",\r\n \"type\": - \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"2fcb23f1-c8e5-432b-9943-e4ef03803686\",\r\n - \ \"disableBgpRoutePropagation\": false,\r\n \"routes\": []\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\"\ + ,\r\n \"etag\": \"W/\\\"bf9bb267-ea2d-4257-8a2e-42b893879124\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"00527bbc-ff38-4e3c-9c24-b81896817399\",\r\n \"\ + disableBgpRoutePropagation\": false,\r\n \"routes\": []\r\n }\r\n}" headers: cache-control: - no-cache @@ -127,9 +129,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:55 GMT + - Tue, 26 Jan 2021 08:54:03 GMT etag: - - W/"ed31a5b7-fa2a-4433-a1c8-d049f3ef9607" + - W/"bf9bb267-ea2d-4257-8a2e-42b893879124" expires: - '-1' pragma: @@ -146,7 +148,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7e126472-1567-47dc-87a2-ec12ea462b70 + - dbbe48cc-a013-4853-8408-70949d670afa status: code: 200 message: OK @@ -164,19 +166,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\",\r\n - \ \"etag\": \"W/\\\"048dde9b-d3b2-4b9c-80c7-01427d3aba79\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Updating\",\r\n \"addressPrefix\": \"10.0.3.0/24\",\r\n - \ \"nextHopType\": \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": - false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\r\n}" + string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\"\ + ,\r\n \"etag\": \"W/\\\"92905461-f087-4ad2-ad23-10c15a19d15f\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ + addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\": \"VirtualNetworkGateway\"\ + ,\r\n \"hasBgpOverride\": false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\ + \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/7bda7d8e-51a7-46bf-bef9-042e78c4c3b4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/d71bcbe9-78a6-46f8-a849-019e2761d2e7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -184,7 +187,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:37:55 GMT + - Tue, 26 Jan 2021 08:54:04 GMT expires: - '-1' pragma: @@ -197,9 +200,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 32bf7d70-fb7c-4fbb-9f51-ef754d60c6ee + - cc76ef35-6555-4257-992b-18af265de38d x-ms-ratelimit-remaining-subscription-writes: - - '1188' + - '1198' status: code: 201 message: Created @@ -213,9 +216,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/7bda7d8e-51a7-46bf-bef9-042e78c4c3b4?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/d71bcbe9-78a6-46f8-a849-019e2761d2e7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -227,7 +230,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:05 GMT + - Tue, 26 Jan 2021 08:54:14 GMT expires: - '-1' pragma: @@ -244,7 +247,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 71df93fb-fed6-47fe-98b2-3f5edb96ffb9 + - b48dd1f0-f10a-4236-9f16-982f572b20fb status: code: 200 message: OK @@ -258,16 +261,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\",\r\n - \ \"etag\": \"W/\\\"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.3.0/24\",\r\n - \ \"nextHopType\": \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": - false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\r\n}" + string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\"\ + ,\r\n \"etag\": \"W/\\\"7ca8dcbb-05f8-4822-93fb-1160a1818bf5\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\": \"VirtualNetworkGateway\"\ + ,\r\n \"hasBgpOverride\": false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\ + \r\n}" headers: cache-control: - no-cache @@ -276,9 +280,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:05 GMT + - Tue, 26 Jan 2021 08:54:15 GMT etag: - - W/"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c" + - W/"7ca8dcbb-05f8-4822-93fb-1160a1818bf5" expires: - '-1' pragma: @@ -295,7 +299,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bf859f7d-150c-4115-9b7b-00aeb4dad0b2 + - b6cd2675-06ac-4d45-b784-1d42e0cc7ab0 status: code: 200 message: OK @@ -309,16 +313,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\",\r\n - \ \"etag\": \"W/\\\"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c\\\"\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressPrefix\": \"10.0.3.0/24\",\r\n - \ \"nextHopType\": \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": - false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\r\n}" + string: "{\r\n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\"\ + ,\r\n \"etag\": \"W/\\\"7ca8dcbb-05f8-4822-93fb-1160a1818bf5\\\"\",\r\n \ + \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ + addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\": \"VirtualNetworkGateway\"\ + ,\r\n \"hasBgpOverride\": false\r\n },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\ + \r\n}" headers: cache-control: - no-cache @@ -327,9 +332,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:06 GMT + - Tue, 26 Jan 2021 08:54:15 GMT etag: - - W/"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c" + - W/"7ca8dcbb-05f8-4822-93fb-1160a1818bf5" expires: - '-1' pragma: @@ -346,7 +351,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5eed64c8-c581-4207-bb1c-c98b740f0ac2 + - 99993a2f-f05e-4f11-88c9-342fd2f663ef status: code: 200 message: OK @@ -360,23 +365,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\",\r\n - \ \"etag\": \"W/\\\"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c\\\"\",\r\n \"type\": - \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\",\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"2fcb23f1-c8e5-432b-9943-e4ef03803686\",\r\n - \ \"disableBgpRoutePropagation\": false,\r\n \"routes\": [\r\n {\r\n - \ \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\",\r\n - \ \"etag\": \"W/\\\"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\": - \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": false\r\n },\r\n - \ \"type\": \"Microsoft.Network/routeTables/routes\"\r\n }\r\n - \ ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\"\ + ,\r\n \"etag\": \"W/\\\"7ca8dcbb-05f8-4822-93fb-1160a1818bf5\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ + \ \"resourceGuid\": \"00527bbc-ff38-4e3c-9c24-b81896817399\",\r\n \"\ + disableBgpRoutePropagation\": false,\r\n \"routes\": [\r\n {\r\n \ + \ \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\"\ + ,\r\n \"etag\": \"W/\\\"7ca8dcbb-05f8-4822-93fb-1160a1818bf5\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\"\ + : \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": false\r\n \ + \ },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\r\n\ + \ }\r\n ]\r\n }\r\n}" headers: cache-control: - no-cache @@ -385,9 +391,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:06 GMT + - Tue, 26 Jan 2021 08:54:15 GMT etag: - - W/"4f789e09-995c-49f8-a3d6-5de4d7b7dd8c" + - W/"7ca8dcbb-05f8-4822-93fb-1160a1818bf5" expires: - '-1' pragma: @@ -404,7 +410,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 707bd62d-65b0-4bed-b493-5c4f9fdac92c + - fc764935-21e5-4adc-97cb-e904362f5a80 status: code: 200 message: OK @@ -422,24 +428,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\",\r\n - \ \"etag\": \"W/\\\"0ac1e3ab-4702-4505-a3d5-8f1d788b3b35\\\"\",\r\n \"type\": - \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\",\r\n \"tags\": - {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\r\n },\r\n \"properties\": - {\r\n \"provisioningState\": \"Succeeded\",\r\n \"resourceGuid\": \"2fcb23f1-c8e5-432b-9943-e4ef03803686\",\r\n - \ \"disableBgpRoutePropagation\": false,\r\n \"routes\": [\r\n {\r\n - \ \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\",\r\n - \ \"etag\": \"W/\\\"0ac1e3ab-4702-4505-a3d5-8f1d788b3b35\\\"\",\r\n - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n - \ \"addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\": - \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": false\r\n },\r\n - \ \"type\": \"Microsoft.Network/routeTables/routes\"\r\n }\r\n - \ ]\r\n }\r\n}" + string: "{\r\n \"name\": \"myRouteTable\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable\"\ + ,\r\n \"etag\": \"W/\\\"2e5f650d-1c5e-4607-83c8-a89e35d00f3d\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/routeTables\",\r\n \"location\": \"westus\"\ + ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ + \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"resourceGuid\": \"00527bbc-ff38-4e3c-9c24-b81896817399\",\r\n \ + \ \"disableBgpRoutePropagation\": false,\r\n \"routes\": [\r\n {\r\ + \n \"name\": \"myRoute\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute\"\ + ,\r\n \"etag\": \"W/\\\"2e5f650d-1c5e-4607-83c8-a89e35d00f3d\\\"\"\ + ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ + ,\r\n \"addressPrefix\": \"10.0.3.0/24\",\r\n \"nextHopType\"\ + : \"VirtualNetworkGateway\",\r\n \"hasBgpOverride\": false\r\n \ + \ },\r\n \"type\": \"Microsoft.Network/routeTables/routes\"\r\n\ + \ }\r\n ]\r\n }\r\n}" headers: azure-asyncnotification: - Enabled @@ -450,7 +457,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:08 GMT + - Tue, 26 Jan 2021 08:54:18 GMT expires: - '-1' pragma: @@ -467,9 +474,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f5fca9f7-cd27-439f-a0bf-6708b2bab8c6 + - 564ba5b7-defa-449f-90cc-2c22de9faffd x-ms-ratelimit-remaining-subscription-writes: - - '1187' + - '1197' status: code: 200 message: OK @@ -485,25 +492,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable/routes/myRoute?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/d0d52997-dfb5-4adc-8f86-3f6adef1c2ba?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/ec2ff8af-067b-4f89-ace8-ab6cde6ed007?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:38:09 GMT + - Tue, 26 Jan 2021 08:54:18 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/d0d52997-dfb5-4adc-8f86-3f6adef1c2ba?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/ec2ff8af-067b-4f89-ace8-ab6cde6ed007?api-version=2020-08-01 pragma: - no-cache server: @@ -514,9 +521,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9ddbc6b9-8e86-4563-8354-6a3ebcfbfb17 + - 4e854099-b0d5-43bb-8294-1b6dbf5666f7 x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14999' status: code: 202 message: Accepted @@ -530,9 +537,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/d0d52997-dfb5-4adc-8f86-3f6adef1c2ba?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/ec2ff8af-067b-4f89-ace8-ab6cde6ed007?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -544,7 +551,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:19 GMT + - Tue, 26 Jan 2021 08:54:29 GMT expires: - '-1' pragma: @@ -561,7 +568,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f5435236-ea3a-43a2-9de6-7cc68a9d727a + - 5d93cc7c-32c2-4375-90eb-a1870c2911e4 status: code: 200 message: OK @@ -577,9 +584,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/routeTables/myRouteTable?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/routeTables/myRouteTable?api-version=2020-08-01 response: body: string: '' @@ -587,17 +594,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/830ce2c1-a17b-4e30-a050-cbbdae71faa1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e5d6f8ac-e3b2-4c1d-bab0-0e49d177a059?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 10:38:20 GMT + - Tue, 26 Jan 2021 08:54:30 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/830ce2c1-a17b-4e30-a050-cbbdae71faa1?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/e5d6f8ac-e3b2-4c1d-bab0-0e49d177a059?api-version=2020-08-01 pragma: - no-cache server: @@ -608,9 +615,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 748d6358-0612-44b1-b44d-b338064734a8 + - 77d21a2d-4b14-4bcd-af2c-eb5aa599d5c8 x-ms-ratelimit-remaining-subscription-deletes: - - '14995' + - '14998' status: code: 202 message: Accepted @@ -624,9 +631,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/830ce2c1-a17b-4e30-a050-cbbdae71faa1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e5d6f8ac-e3b2-4c1d-bab0-0e49d177a059?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -638,7 +645,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 10:38:30 GMT + - Tue, 26 Jan 2021 08:54:40 GMT expires: - '-1' pragma: @@ -655,7 +662,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fe195bd2-b30f-405a-a81a-31fd3c425bc1 + - 01802f08-7e60-4747-9576-84ebede3a11f status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_wan_hub.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_wan_hub.test_network.yaml index e0226900dc8f..653c1c4a8a94 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_wan_hub.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_wan_hub.test_network.yaml @@ -14,13 +14,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"66349bc8-5124-439e-8ca4-963983caa916\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"45c25697-db6c-45dd-9d91-c5cdd16d7dec\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"disableVpnEncryption\"\ @@ -30,7 +30,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f828ea18-8cb1-4cbb-9876-efc8d4e704d3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/473b42d8-a2a3-46fe-ae6d-2c033a9198ed?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -38,7 +38,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:30:35 GMT + - Tue, 26 Jan 2021 08:54:57 GMT expires: - '-1' pragma: @@ -51,7 +51,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 383d3233-e9a7-4765-ba0e-7b91f08567bf + - 2167d391-3720-4cc7-96b5-d0fabf694b62 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -67,9 +67,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/f828ea18-8cb1-4cbb-9876-efc8d4e704d3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/473b42d8-a2a3-46fe-ae6d-2c033a9198ed?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -81,7 +81,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:30:45 GMT + - Tue, 26 Jan 2021 08:55:08 GMT expires: - '-1' pragma: @@ -98,7 +98,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5a94ab0b-eae2-47a6-8b27-33f6d5451a9c + - 726a2c88-9e24-4f06-92c8-f6dcfd686565 status: code: 200 message: OK @@ -112,13 +112,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"e446bf3e-9b9e-4ea8-9344-5c11357a2eda\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"a71d96c6-7c40-4ab7-9ca6-8ec0fe23f7a6\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"disableVpnEncryption\"\ @@ -132,9 +132,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:30:46 GMT + - Tue, 26 Jan 2021 08:55:08 GMT etag: - - W/"e446bf3e-9b9e-4ea8-9344-5c11357a2eda" + - W/"a71d96c6-7c40-4ab7-9ca6-8ec0fe23f7a6" expires: - '-1' pragma: @@ -151,7 +151,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7528c036-e682-429a-8036-ceadafdcb167 + - b99bac98-6431-4ba4-9211-507e9d6f10b2 status: code: 200 message: OK @@ -174,13 +174,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnSites/vnpsite76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vnpsite76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"1ecf456e-7f7c-4e19-aead-3714b8e7de35\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"bbb26195-004a-4b6f-a0c5-7996113227bf\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnSites\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"addressSpace\": {\r\ @@ -192,7 +192,7 @@ interactions: \ \"allow\": false,\r\n \"default\": false\r\n }\r\n },\r\ \n \"vpnSiteLinks\": [\r\n {\r\n \"name\": \"vpnSiteLink1\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ - ,\r\n \"etag\": \"W/\\\"1ecf456e-7f7c-4e19-aead-3714b8e7de35\\\"\"\ + ,\r\n \"etag\": \"W/\\\"bbb26195-004a-4b6f-a0c5-7996113227bf\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"ipAddress\": \"50.50.50.56\",\r\n \"bgpProperties\"\ : {\r\n \"asn\": 1234,\r\n \"bgpPeeringAddress\": \"\ @@ -204,7 +204,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/dfb0b51f-1048-4127-bf78-68c389daf404?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8fdd2af0-9d4a-4223-9157-8eb87513ffe7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -212,7 +212,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:30:50 GMT + - Tue, 26 Jan 2021 08:55:15 GMT expires: - '-1' pragma: @@ -225,7 +225,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f96d8670-9afe-486e-8ffb-fa94edce27f2 + - 985bef36-c102-4ebf-8a70-db4ef5c81376 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -241,9 +241,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/dfb0b51f-1048-4127-bf78-68c389daf404?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8fdd2af0-9d4a-4223-9157-8eb87513ffe7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -255,7 +255,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:00 GMT + - Tue, 26 Jan 2021 08:55:25 GMT expires: - '-1' pragma: @@ -272,7 +272,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8b41a3dc-bb9c-48b3-869b-2e9fc68d5691 + - f08384c7-4ec7-4a60-9e51-231fce315fb9 status: code: 200 message: OK @@ -286,13 +286,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnSites/vnpsite76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vnpsite76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"19efea61-be19-47c0-82e8-2045bb5c13df\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5e1312cb-df62-4bd1-8ed6-52338292e69e\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnSites\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"addressSpace\":\ @@ -304,7 +304,7 @@ interactions: \ \"allow\": false,\r\n \"default\": false\r\n }\r\n },\r\ \n \"vpnSiteLinks\": [\r\n {\r\n \"name\": \"vpnSiteLink1\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ - ,\r\n \"etag\": \"W/\\\"19efea61-be19-47c0-82e8-2045bb5c13df\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5e1312cb-df62-4bd1-8ed6-52338292e69e\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipAddress\": \"50.50.50.56\",\r\n \"bgpProperties\"\ : {\r\n \"asn\": 1234,\r\n \"bgpPeeringAddress\": \"\ @@ -320,9 +320,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:01 GMT + - Tue, 26 Jan 2021 08:55:25 GMT etag: - - W/"19efea61-be19-47c0-82e8-2045bb5c13df" + - W/"5e1312cb-df62-4bd1-8ed6-52338292e69e" expires: - '-1' pragma: @@ -339,7 +339,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e05dc2ae-11e7-48dc-b821-e920c556e4d4 + - 072577a9-d0ce-4afa-bb3d-377547cbeb2d status: code: 200 message: OK @@ -359,34 +359,34 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhubx76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"2a1ea932-132c-4623-8224-ed24a63823eb\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"6fbd3513-19e5-4cfc-b31c-b7e1017c6399\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"virtualHubRouteTableV2s\"\ : [],\r\n \"addressPrefix\": \"10.168.0.0/24\",\r\n \"virtualRouterAsn\"\ : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ - \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\"\r\n\ - \ }\r\n}" + \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\",\r\ + \n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 cache-control: - no-cache content-length: - - '958' + - '1000' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:06 GMT + - Tue, 26 Jan 2021 08:55:29 GMT expires: - '-1' pragma: @@ -399,7 +399,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 14c6b95b-7184-4ae8-9209-c66cac9d6534 + - 25b5a7c0-3af1-43d1-ba61-fc220f8f92c9 x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -415,9 +415,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -429,7 +429,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:16 GMT + - Tue, 26 Jan 2021 08:55:39 GMT expires: - '-1' pragma: @@ -446,7 +446,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 77197c37-8fdb-4aa2-b2cb-5c5e27827c56 + - a95437c3-d025-4fa6-8697-dea710f72cbb status: code: 200 message: OK @@ -460,9 +460,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -474,7 +474,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:27 GMT + - Tue, 26 Jan 2021 08:55:49 GMT expires: - '-1' pragma: @@ -491,7 +491,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2cd7e574-52a6-4a7e-ac20-cd6c95ec7700 + - e8729d26-aa8f-4cc4-ba79-960285ef62b0 status: code: 200 message: OK @@ -505,9 +505,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -519,7 +519,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:31:48 GMT + - Tue, 26 Jan 2021 08:56:09 GMT expires: - '-1' pragma: @@ -536,7 +536,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4996079f-40d9-46d3-bc7c-f12acb38aaf5 + - e694030b-e080-414b-92cf-8098fccea508 status: code: 200 message: OK @@ -550,9 +550,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -564,7 +564,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:32:08 GMT + - Tue, 26 Jan 2021 08:56:30 GMT expires: - '-1' pragma: @@ -581,7 +581,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 02fcaa0b-6827-4f09-b0ca-de6a4fe0d356 + - cd3c6409-df0a-469f-96f2-844702ba1952 status: code: 200 message: OK @@ -595,9 +595,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -609,7 +609,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:32:48 GMT + - Tue, 26 Jan 2021 08:57:10 GMT expires: - '-1' pragma: @@ -626,7 +626,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0421acbc-15e8-4a72-a560-4d0956d0e928 + - 810409db-9b26-4003-b469-7476e7967c07 status: code: 200 message: OK @@ -640,9 +640,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -654,7 +654,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:33:28 GMT + - Tue, 26 Jan 2021 08:57:52 GMT expires: - '-1' pragma: @@ -671,7 +671,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f25a3d7c-63ce-4663-ab09-ffd540969b32 + - 1a5c1708-3177-4080-9609-d09482b995d8 status: code: 200 message: OK @@ -685,9 +685,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/233c7ac8-93a6-4233-8f62-30feb67d4b42?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/0622f9b4-dfba-4b08-95fb-d1cbf840ecce?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -699,7 +699,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:34:50 GMT + - Tue, 26 Jan 2021 08:59:11 GMT expires: - '-1' pragma: @@ -716,7 +716,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 40221851-f25f-449e-a170-6a022ca2491f + - fa70d3ac-f741-4472-9137-bee7c44a374e status: code: 200 message: OK @@ -730,13 +730,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhubx76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"b375a5ed-7205-4707-a010-ba622d989253\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7bdb2b62-108f-4198-99ae-3189be4c055c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"virtualHubRouteTableV2s\"\ @@ -744,16 +744,16 @@ interactions: : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioning\"\ - \r\n }\r\n}" + ,\r\n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '967' + - '1009' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:34:50 GMT + - Tue, 26 Jan 2021 08:59:12 GMT expires: - '-1' pragma: @@ -770,7 +770,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5fee39ab-396e-4513-9687-3ef3b358145a + - 31cf26a5-8955-4029-a628-e0c9df1c21db status: code: 200 message: OK @@ -795,18 +795,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnGateways/vpngateway76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vpngateway76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"32ef06e9-bd1b-4835-a465-d5b4bd452c21\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1d4ac3d9-2be3-4749-a0df-be3c244cd3aa\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnGateways\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"connections\": [\r\ \n {\r\n \"name\": \"vpnConnection1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1\"\ - ,\r\n \"etag\": \"W/\\\"32ef06e9-bd1b-4835-a465-d5b4bd452c21\\\"\"\ + ,\r\n \"etag\": \"W/\\\"1d4ac3d9-2be3-4749-a0df-be3c244cd3aa\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections\",\r\ \n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"routingConfiguration\": {\r\n \"associatedRouteTable\"\ @@ -822,7 +822,7 @@ interactions: \r\n },\r\n \"vpnLinkConnections\": [\r\n {\r\ \n \"name\": \"Connection-Link1\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1/vpnLinkConnections/Connection-Link1\"\ - ,\r\n \"etag\": \"W/\\\"32ef06e9-bd1b-4835-a465-d5b4bd452c21\\\ + ,\r\n \"etag\": \"W/\\\"1d4ac3d9-2be3-4749-a0df-be3c244cd3aa\\\ \"\",\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Updating\",\r\n \"vpnSiteLink\": {\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ @@ -834,8 +834,9 @@ interactions: \ \"enableBgp\": false,\r\n \"enableRateLimiting\"\ : false,\r\n \"useLocalAzureIpAddress\": false,\r\n \ \ \"usePolicyBasedTrafficSelectors\": false,\r\n \"\ - routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0\r\n \ - \ },\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ + routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0,\r\n \ + \ \"vpnLinkConnectionMode\": \"Default\"\r\n },\r\n\ + \ \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ \r\n }\r\n ],\r\n \"ingressBytesTransferred\"\ : 0,\r\n \"egressBytesTransferred\": 0\r\n }\r\n }\r\n\ \ ],\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ @@ -848,15 +849,15 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 cache-control: - no-cache content-length: - - '4422' + - '4475' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:34:57 GMT + - Tue, 26 Jan 2021 08:59:20 GMT expires: - '-1' pragma: @@ -869,7 +870,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4f25643e-dfb0-43e7-94fb-984cbe554eed + - 088d7d23-e7d5-44c0-a888-2f17c317ee12 x-ms-ratelimit-remaining-subscription-writes: - '1196' status: @@ -885,9 +886,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -899,7 +900,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:35:07 GMT + - Tue, 26 Jan 2021 08:59:30 GMT expires: - '-1' pragma: @@ -916,7 +917,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7af3d5cd-45a8-4697-a003-f1518612ca26 + - 6ce4b7e1-035f-4643-878f-9fc0f78cbc6e status: code: 200 message: OK @@ -930,9 +931,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -944,7 +945,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:35:18 GMT + - Tue, 26 Jan 2021 08:59:40 GMT expires: - '-1' pragma: @@ -961,7 +962,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 23807094-7675-402c-b36a-5abc6761d52e + - f4f0b686-27d9-40e8-a906-280cb30ccc59 status: code: 200 message: OK @@ -975,9 +976,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -989,7 +990,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:35:38 GMT + - Tue, 26 Jan 2021 09:00:00 GMT expires: - '-1' pragma: @@ -1006,7 +1007,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 472c130d-0e41-4a20-8337-38bf89d33034 + - cc401e0f-c127-42ea-a7ea-86afeaf58993 status: code: 200 message: OK @@ -1020,9 +1021,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1034,7 +1035,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:35:58 GMT + - Tue, 26 Jan 2021 09:00:21 GMT expires: - '-1' pragma: @@ -1051,7 +1052,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f26f0aa7-9802-4903-bc41-520707aa9c42 + - 166ad71f-1d75-4d1f-b8a1-6b0b18272969 status: code: 200 message: OK @@ -1065,9 +1066,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1079,7 +1080,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:36:39 GMT + - Tue, 26 Jan 2021 09:01:02 GMT expires: - '-1' pragma: @@ -1096,7 +1097,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 01cb44f2-c98a-4a91-a689-a1b3c2361b02 + - e9ab887d-b044-4a7f-a1b4-1923820c4d55 status: code: 200 message: OK @@ -1110,9 +1111,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1124,7 +1125,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:37:19 GMT + - Tue, 26 Jan 2021 09:01:42 GMT expires: - '-1' pragma: @@ -1141,7 +1142,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3b8efec7-26c7-4705-96a2-62add4eb060c + - a2405680-0f16-4901-b6a8-151775e5b666 status: code: 200 message: OK @@ -1155,9 +1156,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1169,7 +1170,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:38:39 GMT + - Tue, 26 Jan 2021 09:03:02 GMT expires: - '-1' pragma: @@ -1186,7 +1187,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 27f53527-cbcd-4c58-b683-1dc04a7f9ee0 + - 97406575-4ee8-4a5e-b6a1-fb008b198edb status: code: 200 message: OK @@ -1200,9 +1201,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1214,7 +1215,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:41:22 GMT + - Tue, 26 Jan 2021 09:05:44 GMT expires: - '-1' pragma: @@ -1231,7 +1232,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 53404a16-2c04-4366-a46e-26bb9f0c2728 + - 42692a7f-2132-4e6a-8cdc-bc5259eb0974 status: code: 200 message: OK @@ -1245,9 +1246,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1259,7 +1260,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:43:03 GMT + - Tue, 26 Jan 2021 09:07:23 GMT expires: - '-1' pragma: @@ -1276,7 +1277,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7f0e878e-ffde-4880-9468-9d720d3a2ba3 + - 8f1b2e46-8e12-4322-9408-8cef6a4febe0 status: code: 200 message: OK @@ -1290,9 +1291,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1304,7 +1305,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:44:43 GMT + - Tue, 26 Jan 2021 09:09:04 GMT expires: - '-1' pragma: @@ -1321,7 +1322,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1bfc2f79-f3e1-4ad0-bcc5-799876a95524 + - 61373f18-c393-408d-949d-d54ad0b03312 status: code: 200 message: OK @@ -1335,9 +1336,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1349,7 +1350,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:46:24 GMT + - Tue, 26 Jan 2021 09:10:45 GMT expires: - '-1' pragma: @@ -1366,7 +1367,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0b9c704d-447e-4159-87af-05b6d4e3a0ec + - 825b597f-3a96-48af-b60d-a232b0150022 status: code: 200 message: OK @@ -1380,9 +1381,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1394,7 +1395,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:48:06 GMT + - Tue, 26 Jan 2021 09:12:25 GMT expires: - '-1' pragma: @@ -1411,7 +1412,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5940ff9b-518d-433b-88fd-527e8cae0dd8 + - 67b676ac-e7dd-4dfb-9723-c511e89f47c0 status: code: 200 message: OK @@ -1425,9 +1426,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1439,7 +1440,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:49:46 GMT + - Tue, 26 Jan 2021 09:14:05 GMT expires: - '-1' pragma: @@ -1456,7 +1457,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 91312dab-d686-42d7-9e02-0c87b6085179 + - 1d98185a-2715-4d72-8864-abcc120584c9 status: code: 200 message: OK @@ -1470,9 +1471,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1484,7 +1485,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:51:27 GMT + - Tue, 26 Jan 2021 09:15:46 GMT expires: - '-1' pragma: @@ -1501,7 +1502,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4b348564-6c81-4c28-871d-5a72255d0ee9 + - b6ea8581-88d8-411d-95d0-d62a6f4ac172 status: code: 200 message: OK @@ -1515,9 +1516,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1529,7 +1530,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:53:08 GMT + - Tue, 26 Jan 2021 09:17:26 GMT expires: - '-1' pragma: @@ -1546,7 +1547,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5e2e1ef7-802e-45cc-a103-66c1ac31b977 + - fd31f68c-7db1-461d-8229-133b1dca908f status: code: 200 message: OK @@ -1560,9 +1561,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1574,7 +1575,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:54:49 GMT + - Tue, 26 Jan 2021 09:19:07 GMT expires: - '-1' pragma: @@ -1591,7 +1592,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3322955e-3ab1-4d51-8019-14dbec99eb42 + - eada31d9-3774-41cf-8ff1-2898fb715a94 status: code: 200 message: OK @@ -1605,9 +1606,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1619,7 +1620,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:56:30 GMT + - Tue, 26 Jan 2021 09:20:47 GMT expires: - '-1' pragma: @@ -1636,7 +1637,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4e3f8c44-69d5-4e32-875c-0424139c3d87 + - f9afbb37-2f0a-4931-947a-8827fe86c7cc status: code: 200 message: OK @@ -1650,9 +1651,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1664,7 +1665,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:58:11 GMT + - Tue, 26 Jan 2021 09:22:28 GMT expires: - '-1' pragma: @@ -1681,7 +1682,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f6b94f12-0496-4700-9fa9-75dff25be2c5 + - 59bf0452-68bf-474c-8c6b-f6a9aa4ae6ee status: code: 200 message: OK @@ -1695,9 +1696,99 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3a2e097d-6305-4aa7-b253-43d127447f36?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 09:24:08 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 6eb7f934-7c09-4b9a-8920-d5171dda355e + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 09:25:48 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 8fcb5686-797b-47af-b2af-3256bb28fee5 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/267624e6-b976-4611-95f5-29afc0b6fcae?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1709,7 +1800,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:59:52 GMT + - Tue, 26 Jan 2021 09:27:28 GMT expires: - '-1' pragma: @@ -1726,7 +1817,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9756ff93-cf94-4388-ad19-e78cc07cf1f6 + - d0897344-a78d-4404-914c-8cbc8a74aebb status: code: 200 message: OK @@ -1740,18 +1831,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnGateways/vpngateway76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vpngateway76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnGateways\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"connections\": [\r\ \n {\r\n \"name\": \"vpnConnection1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\"\"\ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections\",\r\ \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"routingConfiguration\": {\r\n \"associatedRouteTable\"\ @@ -1767,7 +1858,7 @@ interactions: \r\n },\r\n \"vpnLinkConnections\": [\r\n {\r\ \n \"name\": \"Connection-Link1\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1/vpnLinkConnections/Connection-Link1\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\ \"\",\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"vpnSiteLink\": {\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ @@ -1779,8 +1870,9 @@ interactions: \ \"enableBgp\": false,\r\n \"enableRateLimiting\"\ : false,\r\n \"useLocalAzureIpAddress\": false,\r\n \ \ \"usePolicyBasedTrafficSelectors\": false,\r\n \"\ - routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0\r\n \ - \ },\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ + routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0,\r\n \ + \ \"vpnLinkConnectionMode\": \"Default\"\r\n },\r\n\ + \ \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ \r\n }\r\n ],\r\n \"ingressBytesTransferred\"\ : 0,\r\n \"egressBytesTransferred\": 0\r\n }\r\n }\r\n\ \ ],\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ @@ -1788,17 +1880,17 @@ interactions: peerWeight\": 0,\r\n \"bgpPeeringAddresses\": [\r\n {\r\n \ \ \"ipconfigurationId\": \"Instance0\",\r\n \"defaultBgpIpAddresses\"\ : [\r\n \"10.168.0.12\"\r\n ],\r\n \"customBgpIpAddresses\"\ - : [],\r\n \"tunnelIpAddresses\": [\r\n \"52.155.35.156\"\ + : [],\r\n \"tunnelIpAddresses\": [\r\n \"40.118.162.195\"\ ,\r\n \"10.168.0.4\"\r\n ]\r\n },\r\n {\r\ \n \"ipconfigurationId\": \"Instance1\",\r\n \"defaultBgpIpAddresses\"\ : [\r\n \"10.168.0.13\"\r\n ],\r\n \"customBgpIpAddresses\"\ - : [],\r\n \"tunnelIpAddresses\": [\r\n \"52.155.35.155\"\ + : [],\r\n \"tunnelIpAddresses\": [\r\n \"40.118.163.16\"\ ,\r\n \"10.168.0.5\"\r\n ]\r\n }\r\n ]\r\n\ \ },\r\n \"vpnGatewayScaleUnit\": 1,\r\n \"packetCaptureDiagnosticState\"\ : \"None\",\r\n \"ipConfigurations\": [\r\n {\r\n \"id\": \"\ - Instance0\",\r\n \"publicIpAddress\": \"52.155.35.156\",\r\n \ - \ \"privateIpAddress\": \"10.168.0.4\"\r\n },\r\n {\r\n \ - \ \"id\": \"Instance1\",\r\n \"publicIpAddress\": \"52.155.35.155\"\ + Instance0\",\r\n \"publicIpAddress\": \"40.118.162.195\",\r\n \ + \ \"privateIpAddress\": \"10.168.0.4\"\r\n },\r\n {\r\n \ + \ \"id\": \"Instance1\",\r\n \"publicIpAddress\": \"40.118.163.16\"\ ,\r\n \"privateIpAddress\": \"10.168.0.5\"\r\n }\r\n ],\r\n\ \ \"natRules\": [],\r\n \"enableBgpRouteTranslationForNat\": false,\r\ \n \"isRoutingPreferenceInternet\": false\r\n }\r\n}" @@ -1806,11 +1898,11 @@ interactions: cache-control: - no-cache content-length: - - '5317' + - '5372' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 06:59:52 GMT + - Tue, 26 Jan 2021 09:27:28 GMT expires: - '-1' pragma: @@ -1827,7 +1919,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 55b07239-18c9-42d2-89da-553159bbeeb3 + - 312bfd39-9f68-413c-bbdd-256a9b62fb3c status: code: 200 message: OK @@ -1846,14 +1938,14 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"mySecurityPartnerProvider76dc116f\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"60ba88bd-95e2-4d18-9ce8-899b0ed780a2\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d7a111fe-f492-47d5-bd8d-5cf6fe403f77\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/securityPartnerProviders\",\r\n \"location\"\ : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"\ properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"securityProviderName\"\ @@ -1863,7 +1955,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/7f9bfa15-dc80-4d71-9a1c-5aa97cad3a64?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/067853af-5d5e-42bc-ac8f-9032edb04b1d?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1871,7 +1963,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:02 GMT + - Tue, 26 Jan 2021 09:27:38 GMT expires: - '-1' pragma: @@ -1884,9 +1976,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 070321fe-b661-40b9-8f46-d4e65bc23683 + - 6df4b67c-946c-484f-8555-71884f8227fa x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1196' status: code: 201 message: Created @@ -1900,9 +1992,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/7f9bfa15-dc80-4d71-9a1c-5aa97cad3a64?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/067853af-5d5e-42bc-ac8f-9032edb04b1d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1914,7 +2006,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:12 GMT + - Tue, 26 Jan 2021 09:27:48 GMT expires: - '-1' pragma: @@ -1931,7 +2023,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8284ee32-f6bb-4155-9c08-b2c1d4420ba2 + - 2766e5cb-10be-4e3e-ac44-b8b12e0783e4 status: code: 200 message: OK @@ -1945,14 +2037,14 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"mySecurityPartnerProvider76dc116f\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"05365873-9bbe-453d-b71b-3f1c32a59cfd\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"16fae404-83e8-4ef1-8254-ea6d2a615da0\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/securityPartnerProviders\",\r\n \"location\"\ : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"\ properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"securityProviderName\"\ @@ -1966,7 +2058,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:12 GMT + - Tue, 26 Jan 2021 09:27:48 GMT expires: - '-1' pragma: @@ -1983,7 +2075,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5e5332b6-18ec-40fc-9a98-bf771e79543f + - 5534ddee-0b30-4f01-ba5e-07687ecfcc98 status: code: 200 message: OK @@ -1997,34 +2089,34 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhubx76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"cca95dfa-504e-4438-8f88-14a7a1e994ce\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"f9c5dc63-6d5b-4b14-99d6-18f893fe54e8\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"virtualHubRouteTableV2s\"\ : [],\r\n \"addressPrefix\": \"10.168.0.0/24\",\r\n \"virtualRouterAsn\"\ - : 65515,\r\n \"virtualRouterIps\": [\r\n \"10.168.0.100\",\r\n \ - \ \"10.168.0.101\"\r\n ],\r\n \"routeTable\": {\r\n \"routes\"\ + : 65515,\r\n \"virtualRouterIps\": [\r\n \"10.168.0.68\",\r\n \ + \ \"10.168.0.69\"\r\n ],\r\n \"routeTable\": {\r\n \"routes\"\ : []\r\n },\r\n \"securityProviderName\": \"zscaler\",\r\n \"virtualWan\"\ : {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ \r\n },\r\n \"vpnGateway\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f\"\ \r\n },\r\n \"securityPartnerProvider\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioned\"\ - \r\n }\r\n}" + ,\r\n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '1594' + - '1634' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:13 GMT + - Tue, 26 Jan 2021 09:27:49 GMT expires: - '-1' pragma: @@ -2041,7 +2133,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1dd18222-04b5-43f1-b48d-2d59449fab95 + - fc44572c-c9b3-439d-946a-bd44d89daa3a status: code: 200 message: OK @@ -2055,18 +2147,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnGateways/vpngateway76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vpngateway76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnGateways\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"connections\": [\r\ \n {\r\n \"name\": \"vpnConnection1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\"\"\ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections\",\r\ \n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"routingConfiguration\": {\r\n \"associatedRouteTable\"\ @@ -2082,7 +2174,7 @@ interactions: \r\n },\r\n \"vpnLinkConnections\": [\r\n {\r\ \n \"name\": \"Connection-Link1\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/vpnConnections/vpnConnection1/vpnLinkConnections/Connection-Link1\"\ - ,\r\n \"etag\": \"W/\\\"c70b6d86-39ac-43c8-a8dd-020432d838c4\\\ + ,\r\n \"etag\": \"W/\\\"9bb5c24c-c80a-4f24-ae2e-cd76d1ace947\\\ \"\",\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"vpnSiteLink\": {\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ @@ -2094,8 +2186,9 @@ interactions: \ \"enableBgp\": false,\r\n \"enableRateLimiting\"\ : false,\r\n \"useLocalAzureIpAddress\": false,\r\n \ \ \"usePolicyBasedTrafficSelectors\": false,\r\n \"\ - routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0\r\n \ - \ },\r\n \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ + routingWeight\": 0,\r\n \"dpdTimeoutSeconds\": 0,\r\n \ + \ \"vpnLinkConnectionMode\": \"Default\"\r\n },\r\n\ + \ \"type\": \"Microsoft.Network/vpnGateways/vpnConnections/vpnLinkConnections\"\ \r\n }\r\n ],\r\n \"ingressBytesTransferred\"\ : 0,\r\n \"egressBytesTransferred\": 0\r\n }\r\n }\r\n\ \ ],\r\n \"virtualHub\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ @@ -2103,17 +2196,17 @@ interactions: peerWeight\": 0,\r\n \"bgpPeeringAddresses\": [\r\n {\r\n \ \ \"ipconfigurationId\": \"Instance0\",\r\n \"defaultBgpIpAddresses\"\ : [\r\n \"10.168.0.12\"\r\n ],\r\n \"customBgpIpAddresses\"\ - : [],\r\n \"tunnelIpAddresses\": [\r\n \"52.155.35.156\"\ + : [],\r\n \"tunnelIpAddresses\": [\r\n \"40.118.162.195\"\ ,\r\n \"10.168.0.4\"\r\n ]\r\n },\r\n {\r\ \n \"ipconfigurationId\": \"Instance1\",\r\n \"defaultBgpIpAddresses\"\ : [\r\n \"10.168.0.13\"\r\n ],\r\n \"customBgpIpAddresses\"\ - : [],\r\n \"tunnelIpAddresses\": [\r\n \"52.155.35.155\"\ + : [],\r\n \"tunnelIpAddresses\": [\r\n \"40.118.163.16\"\ ,\r\n \"10.168.0.5\"\r\n ]\r\n }\r\n ]\r\n\ \ },\r\n \"vpnGatewayScaleUnit\": 1,\r\n \"packetCaptureDiagnosticState\"\ : \"None\",\r\n \"ipConfigurations\": [\r\n {\r\n \"id\": \"\ - Instance0\",\r\n \"publicIpAddress\": \"52.155.35.156\",\r\n \ - \ \"privateIpAddress\": \"10.168.0.4\"\r\n },\r\n {\r\n \ - \ \"id\": \"Instance1\",\r\n \"publicIpAddress\": \"52.155.35.155\"\ + Instance0\",\r\n \"publicIpAddress\": \"40.118.162.195\",\r\n \ + \ \"privateIpAddress\": \"10.168.0.4\"\r\n },\r\n {\r\n \ + \ \"id\": \"Instance1\",\r\n \"publicIpAddress\": \"40.118.163.16\"\ ,\r\n \"privateIpAddress\": \"10.168.0.5\"\r\n }\r\n ],\r\n\ \ \"natRules\": [],\r\n \"enableBgpRouteTranslationForNat\": false,\r\ \n \"isRoutingPreferenceInternet\": false\r\n }\r\n}" @@ -2121,11 +2214,11 @@ interactions: cache-control: - no-cache content-length: - - '5317' + - '5372' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:13 GMT + - Tue, 26 Jan 2021 09:27:49 GMT expires: - '-1' pragma: @@ -2142,7 +2235,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6deb3606-89cf-49dd-bb6a-fd75c9d10641 + - f0fc1e17-e062-40f0-9f2f-e41f6d5cde23 status: code: 200 message: OK @@ -2156,13 +2249,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"d16fef98-d1b1-4190-9ba1-1bf401e36a7e\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"73eeaa58-f114-4e25-bbd7-40bb33ea939d\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"disableVpnEncryption\"\ @@ -2180,9 +2273,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:13 GMT + - Tue, 26 Jan 2021 09:27:49 GMT etag: - - W/"d16fef98-d1b1-4190-9ba1-1bf401e36a7e" + - W/"73eeaa58-f114-4e25-bbd7-40bb33ea939d" expires: - '-1' pragma: @@ -2199,7 +2292,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3c077997-6029-4be7-9a52-a5a1c851736e + - 75a5af65-a21d-43f5-b9ee-478a060b5d0d status: code: 200 message: OK @@ -2213,13 +2306,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vpnSiteLink1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ - ,\r\n \"etag\": \"W/\\\"19efea61-be19-47c0-82e8-2045bb5c13df\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5e1312cb-df62-4bd1-8ed6-52338292e69e\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ ipAddress\": \"50.50.50.56\",\r\n \"bgpProperties\": {\r\n \"asn\"\ : 1234,\r\n \"bgpPeeringAddress\": \"192.168.0.0\"\r\n },\r\n \"\ @@ -2234,9 +2327,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:13 GMT + - Tue, 26 Jan 2021 09:27:50 GMT etag: - - W/"19efea61-be19-47c0-82e8-2045bb5c13df" + - W/"5e1312cb-df62-4bd1-8ed6-52338292e69e" expires: - '-1' pragma: @@ -2253,7 +2346,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - be859a3a-34e3-401d-8fa9-94f6604c367d + - b321d833-79ec-4ec3-9863-9229520be183 status: code: 200 message: OK @@ -2267,14 +2360,14 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"mySecurityPartnerProvider76dc116f\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"9605587c-fcec-494a-8793-1d1d7ab2a6bf\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e1e4f18a-ad03-439e-a34c-abd18af9b9dd\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/securityPartnerProviders\",\r\n \"location\"\ : \"westus\",\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"\ properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"securityProviderName\"\ @@ -2288,7 +2381,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:14 GMT + - Tue, 26 Jan 2021 09:27:50 GMT expires: - '-1' pragma: @@ -2305,7 +2398,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cc9a9970-4632-405e-8af6-dbde76806962 + - 9788a0aa-e68b-4115-8bee-a42ac581259b status: code: 200 message: OK @@ -2321,25 +2414,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnGateways/vpngateway76dc116f/reset?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f/reset?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:00:14 GMT + - Tue, 26 Jan 2021 09:27:50 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 pragma: - no-cache server: @@ -2350,7 +2443,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 965616ff-a2fc-4a54-892e-e4d3a4aaed20 + - f3bd1203-aef9-4835-96ec-a76dbd19ea54 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -2366,9 +2459,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2380,7 +2473,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:24 GMT + - Tue, 26 Jan 2021 09:28:01 GMT expires: - '-1' pragma: @@ -2397,7 +2490,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ee03d89d-fbdb-4e04-84aa-6f71efc0705d + - 1c4f3084-83dc-43b6-8fbd-276ba14742f4 status: code: 200 message: OK @@ -2411,9 +2504,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2425,7 +2518,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:36 GMT + - Tue, 26 Jan 2021 09:28:11 GMT expires: - '-1' pragma: @@ -2442,7 +2535,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0e24c043-d654-4a0a-a178-dd782e3ea2d4 + - 2318c3d4-4ce2-48e2-8f12-28dd690ebedd status: code: 200 message: OK @@ -2456,9 +2549,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2470,7 +2563,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:00:56 GMT + - Tue, 26 Jan 2021 09:28:31 GMT expires: - '-1' pragma: @@ -2487,7 +2580,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b9b2de71-e2b4-4a98-995e-b7d0b3d9e5f6 + - d7d8190d-3e67-4c2f-8f13-86616d4b5b09 status: code: 200 message: OK @@ -2501,9 +2594,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2515,7 +2608,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:01:36 GMT + - Tue, 26 Jan 2021 09:29:11 GMT expires: - '-1' pragma: @@ -2532,7 +2625,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ce214e8b-2bcb-4d8d-8719-8e693ba202c0 + - 95a25c53-2a2e-4244-8b47-6bf48304cae2 status: code: 200 message: OK @@ -2546,9 +2639,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2560,7 +2653,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:02:56 GMT + - Tue, 26 Jan 2021 09:30:32 GMT expires: - '-1' pragma: @@ -2577,7 +2670,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2b13b201-e464-4282-9593-30168348f5cc + - 5f9221ed-e6b7-472a-8560-71bec71fdb2d status: code: 200 message: OK @@ -2591,9 +2684,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2605,7 +2698,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:05:38 GMT + - Tue, 26 Jan 2021 09:33:13 GMT expires: - '-1' pragma: @@ -2622,7 +2715,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 21cb2fa6-133f-455e-be81-cd076bb04676 + - 7901248c-b91c-4620-bf62-0d69b85a416f status: code: 200 message: OK @@ -2636,9 +2729,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2650,7 +2743,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:07:19 GMT + - Tue, 26 Jan 2021 09:34:53 GMT expires: - '-1' pragma: @@ -2667,7 +2760,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 37a226ef-3407-4f8d-8cc4-f18e48dea637 + - fe90406d-de33-4584-a459-d007f7f37b88 status: code: 200 message: OK @@ -2681,9 +2774,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2695,7 +2788,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:09:00 GMT + - Tue, 26 Jan 2021 09:36:33 GMT expires: - '-1' pragma: @@ -2712,7 +2805,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bace1022-6c61-4a25-8893-20df56aa1f9e + - 927cd3e2-7f0f-429b-ba77-a025d2d374c1 status: code: 200 message: OK @@ -2726,9 +2819,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2740,7 +2833,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:10:41 GMT + - Tue, 26 Jan 2021 09:38:14 GMT expires: - '-1' pragma: @@ -2757,7 +2850,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - eb8d860f-b0d4-4ef6-90da-073524e6347a + - e47e5846-0835-48d3-8812-4b148ac443a7 status: code: 200 message: OK @@ -2771,9 +2864,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2785,7 +2878,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:12:22 GMT + - Tue, 26 Jan 2021 09:39:55 GMT expires: - '-1' pragma: @@ -2802,7 +2895,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 23692437-abf3-4033-9a67-7c21f273e9d7 + - 9d9522e0-2be6-4551-9852-6567be867601 status: code: 200 message: OK @@ -2816,9 +2909,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -2830,7 +2923,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:14:03 GMT + - Tue, 26 Jan 2021 09:41:34 GMT expires: - '-1' pragma: @@ -2847,7 +2940,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2c1c886b-1c3e-4d47-a1e8-fb2cca9397b6 + - c3a41f4d-6db8-44af-a3c1-201e76389718 status: code: 200 message: OK @@ -2861,54 +2954,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 07:15:44 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - bf0477f6-e2ca-4915-a7af-36eaf779b15f - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -2920,7 +2968,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:25 GMT + - Tue, 26 Jan 2021 09:43:15 GMT expires: - '-1' pragma: @@ -2937,7 +2985,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 77d415c0-dc33-440a-abae-c9b171be2d06 + - 111837e2-14cb-4ec0-bc4a-9fd714ce58a7 status: code: 200 message: OK @@ -2951,15 +2999,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operationResults/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -2967,11 +3015,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:25 GMT + - Tue, 26 Jan 2021 09:43:16 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/47a87d94-f9c5-4e3d-9616-65f9472e904e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/f17d10d8-eeee-4d7c-9918-ecba8882947d?api-version=2020-08-01 pragma: - no-cache server: @@ -2986,7 +3034,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 965616ff-a2fc-4a54-892e-e4d3a4aaed20 + - f3bd1203-aef9-4835-96ec-a76dbd19ea54 status: code: 200 message: OK @@ -3004,36 +3052,36 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhubx76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"4c896349-025d-4176-93f5-c3da54254f29\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e7cf32d8-01b4-4540-bb50-91850911d079\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\",\r\n \"key2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"virtualHubRouteTableV2s\": [],\r\n \"addressPrefix\": \"10.168.0.0/24\"\ ,\r\n \"virtualRouterAsn\": 65515,\r\n \"virtualRouterIps\": [\r\n \ - \ \"10.168.0.100\",\r\n \"10.168.0.101\"\r\n ],\r\n \"routeTable\"\ + \ \"10.168.0.68\",\r\n \"10.168.0.69\"\r\n ],\r\n \"routeTable\"\ : {\r\n \"routes\": []\r\n },\r\n \"securityProviderName\": \"\ zscaler\",\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ \r\n },\r\n \"vpnGateway\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f\"\ \r\n },\r\n \"securityPartnerProvider\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioned\"\ - \r\n }\r\n}" + ,\r\n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled cache-control: - no-cache content-length: - - '1616' + - '1656' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:30 GMT + - Tue, 26 Jan 2021 09:43:21 GMT expires: - '-1' pragma: @@ -3050,9 +3098,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6c67dd11-0e4e-4970-bda7-d19e365abf1b + - b5cf796f-c125-4e74-a8b0-45b7eef7af36 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1195' status: code: 200 message: OK @@ -3070,13 +3118,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"f672f443-1269-42cb-a711-fa1932528ca7\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"f6ed19a2-e651-4441-87db-77b87a40d420\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\",\r\n \"key2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ @@ -3096,7 +3144,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:33 GMT + - Tue, 26 Jan 2021 09:43:23 GMT expires: - '-1' pragma: @@ -3113,9 +3161,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9211f1da-d720-4ba8-b36a-e20c17067e79 + - 8f5cd96d-d657-4a73-b36f-04009cae495a x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1194' status: code: 200 message: OK @@ -3133,13 +3181,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnSites/vnpsite76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"vnpsite76dc116f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"802d90f9-1678-465c-b661-d763ee88c3bc\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"65d263ec-e2d1-430a-bd84-01ec07617f8f\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/vpnSites\",\r\n \"location\": \"westus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\",\r\n \"key2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ @@ -3152,7 +3200,7 @@ interactions: \ \"allow\": false,\r\n \"default\": false\r\n }\r\n },\r\ \n \"vpnSiteLinks\": [\r\n {\r\n \"name\": \"vpnSiteLink1\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f/vpnSiteLinks/vpnSiteLink1\"\ - ,\r\n \"etag\": \"W/\\\"802d90f9-1678-465c-b661-d763ee88c3bc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"65d263ec-e2d1-430a-bd84-01ec07617f8f\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipAddress\": \"50.50.50.56\",\r\n \"bgpProperties\"\ : {\r\n \"asn\": 1234,\r\n \"bgpPeeringAddress\": \"\ @@ -3170,7 +3218,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:35 GMT + - Tue, 26 Jan 2021 09:43:26 GMT expires: - '-1' pragma: @@ -3187,9 +3235,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c45bddc1-0bde-4fc8-bc7e-0e4a953179d5 + - ce890ee9-7046-4cf5-b042-eb0665de6f85 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1193' status: code: 200 message: OK @@ -3207,14 +3255,14 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"mySecurityPartnerProvider76dc116f\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f\"\ - ,\r\n \"etag\": \"W/\\\"829d5d3b-eb9d-4231-a29d-a8a1987329bc\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7b997c8d-2ae2-466c-89b4-f8397caaaf37\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/securityPartnerProviders\",\r\n \"location\"\ : \"westus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ @@ -3231,7 +3279,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:37 GMT + - Tue, 26 Jan 2021 09:43:28 GMT expires: - '-1' pragma: @@ -3248,9 +3296,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6b5b2770-ab5c-411c-b0a8-82d8c53a2da1 + - 06e991d1-ac6d-458f-b696-a11eb668a395 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1192' status: code: 200 message: OK @@ -3266,9 +3314,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/securityPartnerProviders/mySecurityPartnerProvider76dc116f?api-version=2020-08-01 response: body: string: '' @@ -3276,17 +3324,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/7d5dada8-6304-4fdb-9cdb-609abc20784b?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/2ff992f5-8f51-4ac0-abe0-904a4533d23e?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:17:38 GMT + - Tue, 26 Jan 2021 09:43:29 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/7d5dada8-6304-4fdb-9cdb-609abc20784b?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/2ff992f5-8f51-4ac0-abe0-904a4533d23e?api-version=2020-08-01 pragma: - no-cache server: @@ -3297,9 +3345,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e339a43f-8319-44f2-afa6-ef03d51799ea + - 7d13332f-d167-4b01-b359-89cb7f05d289 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14997' status: code: 202 message: Accepted @@ -3313,9 +3361,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/7d5dada8-6304-4fdb-9cdb-609abc20784b?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/2ff992f5-8f51-4ac0-abe0-904a4533d23e?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -3327,7 +3375,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:17:48 GMT + - Tue, 26 Jan 2021 09:43:39 GMT expires: - '-1' pragma: @@ -3344,7 +3392,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 96bf3dea-763c-4148-9146-be23ef5bcb84 + - 92c26ac3-7d4a-4dc2-9d58-2069cef525aa status: code: 200 message: OK @@ -3360,9 +3408,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnGateways/vpngateway76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnGateways/vpngateway76dc116f?api-version=2020-08-01 response: body: string: '' @@ -3370,17 +3418,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:17:49 GMT + - Tue, 26 Jan 2021 09:43:40 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 pragma: - no-cache server: @@ -3391,9 +3439,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 67299957-da51-44cb-9340-e9ea6f5a353e + - 83647ecf-912e-4544-91c6-8a72c05381df x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14996' status: code: 202 message: Accepted @@ -3407,9 +3455,54 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 09:43:51 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 5483e1d1-88df-4749-8c6a-f4539cdf3e94 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3421,7 +3514,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:18:00 GMT + - Tue, 26 Jan 2021 09:44:01 GMT expires: - '-1' pragma: @@ -3438,7 +3531,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 28db550e-7618-4b14-9ec5-ee37c04a8bc1 + - 95ec82c0-b0dc-4fff-84a1-86dd851405cd status: code: 200 message: OK @@ -3452,9 +3545,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3466,7 +3559,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:18:10 GMT + - Tue, 26 Jan 2021 09:44:21 GMT expires: - '-1' pragma: @@ -3483,7 +3576,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bad5b024-6c3a-41de-b673-4c0055e2377d + - fe755e15-3302-409d-a8fa-69d051b6672c status: code: 200 message: OK @@ -3497,9 +3590,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3511,7 +3604,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:18:30 GMT + - Tue, 26 Jan 2021 09:44:41 GMT expires: - '-1' pragma: @@ -3528,7 +3621,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7c7bed54-b322-4cef-a0c4-c5e867c6ffe5 + - 121422ac-b17d-4924-b1c2-2bcf94ea268b status: code: 200 message: OK @@ -3542,9 +3635,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3556,7 +3649,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:18:50 GMT + - Tue, 26 Jan 2021 09:45:22 GMT expires: - '-1' pragma: @@ -3573,7 +3666,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1588be25-daa9-408c-8326-40749766d28f + - bc11eb64-594e-4f14-b97d-d966efc1810b status: code: 200 message: OK @@ -3587,9 +3680,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3601,7 +3694,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:19:31 GMT + - Tue, 26 Jan 2021 09:46:02 GMT expires: - '-1' pragma: @@ -3618,7 +3711,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d4604737-e7fc-4a3b-b95f-634c15d5720b + - 6bd67236-1de3-44aa-9847-6e7701d54af5 status: code: 200 message: OK @@ -3632,9 +3725,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3646,7 +3739,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:20:12 GMT + - Tue, 26 Jan 2021 09:47:22 GMT expires: - '-1' pragma: @@ -3663,7 +3756,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5b161cbe-d28d-40ba-b975-8e0686d9f1f5 + - 5b13bab2-4c8a-4a37-aef8-501a52cf1267 status: code: 200 message: OK @@ -3677,9 +3770,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3691,7 +3784,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:21:32 GMT + - Tue, 26 Jan 2021 09:50:04 GMT expires: - '-1' pragma: @@ -3708,7 +3801,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 75d22346-2fe2-4a68-ad08-d75c42b1bb21 + - f972e720-4c95-4e24-96ec-d3d920eec7bd status: code: 200 message: OK @@ -3722,9 +3815,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3736,7 +3829,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:24:14 GMT + - Tue, 26 Jan 2021 09:51:44 GMT expires: - '-1' pragma: @@ -3753,7 +3846,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5fc77b5b-2501-4757-b3d4-22c193b360d0 + - 66f81b08-1b38-446a-9c15-ea1ff043661f status: code: 200 message: OK @@ -3767,9 +3860,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3781,7 +3874,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:25:54 GMT + - Tue, 26 Jan 2021 09:53:25 GMT expires: - '-1' pragma: @@ -3798,7 +3891,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 13b95736-cd64-425b-92d3-6ddb43f5f4fa + - 3a78de6a-d3bc-416d-a7f2-9b977799d446 status: code: 200 message: OK @@ -3812,9 +3905,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3826,7 +3919,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:27:36 GMT + - Tue, 26 Jan 2021 09:55:05 GMT expires: - '-1' pragma: @@ -3843,7 +3936,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 34f8df32-6a04-464a-8dc0-b724fccd210c + - bbab2ac3-ee95-4cad-9dbb-1dfc9fa095b0 status: code: 200 message: OK @@ -3857,9 +3950,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -3871,7 +3964,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:29:16 GMT + - Tue, 26 Jan 2021 09:56:45 GMT expires: - '-1' pragma: @@ -3888,7 +3981,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ec92de81-7bd1-473a-a429-b55d262eac11 + - 972ccaa9-181f-470d-a9d6-8cde8e32c6ab status: code: 200 message: OK @@ -3902,9 +3995,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/6e9962d5-5502-425c-af1a-d4a0867854bb?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/95084c60-8463-4083-a5d0-efdf7892e9a7?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -3916,7 +4009,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:30:58 GMT + - Tue, 26 Jan 2021 09:58:25 GMT expires: - '-1' pragma: @@ -3933,7 +4026,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 180fb715-d008-4bbd-b0a6-8a240d7e487c + - f287fcd9-d862-4679-90cc-06c72d36fe7c status: code: 200 message: OK @@ -3949,9 +4042,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhubx76dc116f?api-version=2020-08-01 response: body: string: '' @@ -3959,17 +4052,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:30:59 GMT + - Tue, 26 Jan 2021 09:58:26 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 pragma: - no-cache server: @@ -3980,7 +4073,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1939be7d-bc4c-45ca-8f44-8fbe127dc3d3 + - b84c1434-7ca7-4630-a392-e81be2068f16 x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -3996,9 +4089,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4010,7 +4103,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:31:09 GMT + - Tue, 26 Jan 2021 09:58:36 GMT expires: - '-1' pragma: @@ -4027,7 +4120,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 24d748e9-b796-4245-b1f9-39221b2d4d44 + - 1c40de79-1a27-4135-a9d7-0d16c945b9be status: code: 200 message: OK @@ -4041,9 +4134,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4055,7 +4148,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:31:19 GMT + - Tue, 26 Jan 2021 09:58:47 GMT expires: - '-1' pragma: @@ -4072,7 +4165,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6c8ee931-f541-4ff9-9021-0966a592f699 + - 94bc0be9-6c0a-46ff-8bb3-f1a07ee7355d status: code: 200 message: OK @@ -4086,9 +4179,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4100,7 +4193,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:31:39 GMT + - Tue, 26 Jan 2021 09:59:07 GMT expires: - '-1' pragma: @@ -4117,7 +4210,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c72c0ac9-853e-4c45-b1d4-d898dfbafc18 + - 23e87035-aa49-486c-a7ec-eda960432b7f status: code: 200 message: OK @@ -4131,9 +4224,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4145,7 +4238,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:32:00 GMT + - Tue, 26 Jan 2021 09:59:28 GMT expires: - '-1' pragma: @@ -4162,7 +4255,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3ed3ece4-90f9-477c-bb39-c8c61db4f38a + - c4007863-b674-4402-a197-85a35901eecc status: code: 200 message: OK @@ -4176,9 +4269,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4190,7 +4283,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:32:40 GMT + - Tue, 26 Jan 2021 10:00:08 GMT expires: - '-1' pragma: @@ -4207,7 +4300,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4d48c4a3-c04f-4d6e-bf26-a03b1c35a168 + - 5ae74b13-6a4d-4f17-834c-6e86bcd2a538 status: code: 200 message: OK @@ -4221,9 +4314,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4235,7 +4328,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:33:20 GMT + - Tue, 26 Jan 2021 10:00:48 GMT expires: - '-1' pragma: @@ -4252,7 +4345,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b66b709a-788d-4008-bb32-a91429452578 + - f5b1816c-7ca6-465c-abda-a4f9d4199370 status: code: 200 message: OK @@ -4266,9 +4359,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4280,7 +4373,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:34:42 GMT + - Tue, 26 Jan 2021 10:02:08 GMT expires: - '-1' pragma: @@ -4297,7 +4390,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f53c5f4b-4d2a-46e6-b7bb-0e6e9692d2d0 + - cf65729f-6605-465d-a6cd-05afeffad28e status: code: 200 message: OK @@ -4311,9 +4404,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -4325,7 +4418,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:37:24 GMT + - Tue, 26 Jan 2021 10:04:50 GMT expires: - '-1' pragma: @@ -4342,7 +4435,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ae2ea7a3-6669-48ac-ac3d-6a29cfb3cf4e + - 20e54d07-9f82-464a-92b1-220d251f9bef status: code: 200 message: OK @@ -4356,9 +4449,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/3febcb8c-669e-4447-9ce3-c671fd95854a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a6548b67-9fb1-4c00-a4ca-996b51a28908?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -4370,7 +4463,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:39:05 GMT + - Tue, 26 Jan 2021 10:06:30 GMT expires: - '-1' pragma: @@ -4387,7 +4480,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ff16b196-b6cf-4116-b38d-4ef919eea7b7 + - ffc8f035-25ad-44b4-9b43-8c40275d52ac status: code: 200 message: OK @@ -4403,9 +4496,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/vpnSites/vnpsite76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/vpnSites/vnpsite76dc116f?api-version=2020-08-01 response: body: string: '' @@ -4413,17 +4506,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/bfc3506e-9627-4eb9-87e0-6e1cb5aeb075?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/c6d1614d-4d56-4f6e-800a-a7df3b9cd45d?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:39:06 GMT + - Tue, 26 Jan 2021 10:06:31 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/bfc3506e-9627-4eb9-87e0-6e1cb5aeb075?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/c6d1614d-4d56-4f6e-800a-a7df3b9cd45d?api-version=2020-08-01 pragma: - no-cache server: @@ -4434,7 +4527,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4a46d7c6-6ad3-436f-b21a-614c1952d658 + - 2e14daf7-37b5-422d-be7e-55a66d46b4f7 x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -4450,9 +4543,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/bfc3506e-9627-4eb9-87e0-6e1cb5aeb075?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/c6d1614d-4d56-4f6e-800a-a7df3b9cd45d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -4464,7 +4557,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:39:16 GMT + - Tue, 26 Jan 2021 10:06:42 GMT expires: - '-1' pragma: @@ -4481,7 +4574,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 57be7f26-641f-4fde-b41c-5d05e9011269 + - 11f5033d-e599-4bf6-a2de-6e11e3235550 status: code: 200 message: OK @@ -4497,9 +4590,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan76dc116f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan76dc116f?api-version=2020-08-01 response: body: string: '' @@ -4507,17 +4600,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/db1ecbcf-ecb0-4eae-bf12-31df24ef9a5a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8814e449-93a8-4249-883e-cacc566b70c3?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 07:39:17 GMT + - Tue, 26 Jan 2021 10:06:43 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/db1ecbcf-ecb0-4eae-bf12-31df24ef9a5a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/8814e449-93a8-4249-883e-cacc566b70c3?api-version=2020-08-01 pragma: - no-cache server: @@ -4528,7 +4621,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 846e30eb-ec9b-4f79-bfe0-76c64a95f00d + - f8e4e878-32ca-430a-ac2f-3db792622ae2 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -4544,9 +4637,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/db1ecbcf-ecb0-4eae-bf12-31df24ef9a5a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/8814e449-93a8-4249-883e-cacc566b70c3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -4558,7 +4651,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 07:39:27 GMT + - Tue, 26 Jan 2021 10:06:53 GMT expires: - '-1' pragma: @@ -4575,7 +4668,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1d5a7130-6201-499f-bf46-d2f809a69685 + - bc927cfb-a4e8-4b18-8d23-81408521a4af status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network.yaml index 09cae71bc36f..9f593c5cd99b 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network.yaml @@ -14,13 +14,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179\"\ - ,\r\n \"etag\": \"W/\\\"1eed0a85-1b06-4f79-b148-5346938f429e\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"02a5cc23-5a0b-4366-9e9c-2aec2de6ffe2\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"disableVpnEncryption\"\ @@ -30,7 +30,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8695d90d-e8bb-4cce-9efb-e8548ea2da71?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b151d02e-9ee3-4770-aa8f-962e42fb43f6?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -38,7 +38,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:16:41 GMT + - Tue, 26 Jan 2021 10:07:17 GMT expires: - '-1' pragma: @@ -51,7 +51,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c1893dfa-5493-4507-90e8-596fece99b4d + - b81fbc6a-3738-4de7-abbf-b76961cc86ba x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -67,9 +67,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/8695d90d-e8bb-4cce-9efb-e8548ea2da71?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b151d02e-9ee3-4770-aa8f-962e42fb43f6?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -81,7 +81,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:16:52 GMT + - Tue, 26 Jan 2021 10:07:27 GMT expires: - '-1' pragma: @@ -98,7 +98,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6316aa27-0507-4614-9f7e-5101cc386a18 + - 651d8976-cc7b-40a5-b8a8-b3a33f9c7bc9 status: code: 200 message: OK @@ -112,13 +112,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualWans/virtualwan777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualwan777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179\"\ - ,\r\n \"etag\": \"W/\\\"5862c7a7-010c-4613-96b0-9eaf13f0ed26\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"12c70b53-d90b-45d5-98d4-926f6ae963dd\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualWans\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"disableVpnEncryption\"\ @@ -132,9 +132,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:16:53 GMT + - Tue, 26 Jan 2021 10:07:27 GMT etag: - - W/"5862c7a7-010c-4613-96b0-9eaf13f0ed26" + - W/"12c70b53-d90b-45d5-98d4-926f6ae963dd" expires: - '-1' pragma: @@ -151,7 +151,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 510a5f31-9f79-4a25-8ee6-03f82d46dbe2 + - 6270722d-bc66-424b-8322-2464128a654c status: code: 200 message: OK @@ -171,34 +171,34 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhub777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhub777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhub777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhub777c1179\"\ - ,\r\n \"etag\": \"W/\\\"9e108a95-6fd0-49f9-b3e2-c4ee5783a58c\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7a98ce9d-6c1b-44a0-8b83-e567361d720a\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Updating\",\r\n \"virtualHubRouteTableV2s\"\ : [],\r\n \"addressPrefix\": \"10.168.0.0/24\",\r\n \"virtualRouterAsn\"\ : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179\"\ - \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\"\r\n\ - \ }\r\n}" + \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"None\",\r\ + \n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 cache-control: - no-cache content-length: - - '956' + - '998' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:16:57 GMT + - Tue, 26 Jan 2021 10:07:33 GMT expires: - '-1' pragma: @@ -211,7 +211,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c02b5ab6-cc61-41e8-9123-818dc259940e + - 4eee8deb-b4f7-4988-92d3-e8da0eaa6360 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -227,9 +227,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -241,7 +241,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:17:08 GMT + - Tue, 26 Jan 2021 10:07:44 GMT expires: - '-1' pragma: @@ -258,7 +258,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 864f4127-80b2-48f4-9663-314690c157a0 + - 3e7b5dd7-70d2-4fb2-bd49-6229c62ab5b2 status: code: 200 message: OK @@ -272,9 +272,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -286,7 +286,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:17:18 GMT + - Tue, 26 Jan 2021 10:07:55 GMT expires: - '-1' pragma: @@ -303,7 +303,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 43b45354-75ab-4c71-b06b-b28cc1277945 + - 30af9118-98ea-4cfa-9552-7140226469fb status: code: 200 message: OK @@ -317,9 +317,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -331,7 +331,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:17:38 GMT + - Tue, 26 Jan 2021 10:08:16 GMT expires: - '-1' pragma: @@ -348,7 +348,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e3df6872-529b-4c2b-8496-6e4752fdbb4a + - 8625cb4c-9a34-46d6-a260-f9c0177eee74 status: code: 200 message: OK @@ -362,9 +362,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -376,7 +376,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:17:59 GMT + - Tue, 26 Jan 2021 10:08:38 GMT expires: - '-1' pragma: @@ -393,7 +393,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7e6b7401-fd43-42f7-a1bf-35ff7fbdf231 + - fe15f642-ffdb-4466-84af-166a4eb6d377 status: code: 200 message: OK @@ -407,9 +407,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -421,7 +421,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:18:40 GMT + - Tue, 26 Jan 2021 10:09:19 GMT expires: - '-1' pragma: @@ -438,7 +438,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6060c01c-07d5-49da-90e9-493b4afddf03 + - 3d02a9d9-55fa-49b8-8a16-4529b6e1d4a1 status: code: 200 message: OK @@ -452,9 +452,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -466,7 +466,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:19:20 GMT + - Tue, 26 Jan 2021 10:09:59 GMT expires: - '-1' pragma: @@ -483,7 +483,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 18b2b772-799c-440c-a633-64447657710e + - 1d70f797-3e67-4009-876a-48f4662a19f9 status: code: 200 message: OK @@ -497,9 +497,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87f737fc-5f1d-428c-afe2-ca6d644dd1b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3c371bed-4b51-4d37-a7db-4659b32f01cb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -511,7 +511,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:20:40 GMT + - Tue, 26 Jan 2021 10:11:20 GMT expires: - '-1' pragma: @@ -528,7 +528,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a9eb32bc-c515-4312-ba27-996304eadbbc + - 373b5d35-cea2-44e5-9b2a-7ec094a60c15 status: code: 200 message: OK @@ -542,13 +542,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualHubs/virtualhub777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhub777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualhub777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualHubs/virtualhub777c1179\"\ - ,\r\n \"etag\": \"W/\\\"446269a1-6aa9-4579-a23f-74e679ef96d2\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"02037d79-3467-4c0a-ab5a-18435623c5cf\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualHubs\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"key1\": \"value1\"\r\n },\r\n \"properties\"\ : {\r\n \"provisioningState\": \"Succeeded\",\r\n \"virtualHubRouteTableV2s\"\ @@ -556,16 +556,16 @@ interactions: : 0,\r\n \"virtualRouterIps\": [],\r\n \"routeTable\": {\r\n \"\ routes\": []\r\n },\r\n \"virtualWan\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualWans/virtualwan777c1179\"\ \r\n },\r\n \"sku\": \"Basic\",\r\n \"routingState\": \"Provisioning\"\ - \r\n }\r\n}" + ,\r\n \"allowBranchToBranchTraffic\": false\r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '965' + - '1007' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:20:40 GMT + - Tue, 26 Jan 2021 10:11:20 GMT expires: - '-1' pragma: @@ -582,7 +582,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4c53d34f-a83b-46fb-b14a-42f3c255f1a4 + - 5211c81b-7989-48b6-9ee4-07cd2f040713 status: code: 200 message: OK @@ -601,11 +601,11 @@ interactions: - 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename777c1179?api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename777c1179?api-version=2019-06-01 response: body: string: '' @@ -617,11 +617,11 @@ interactions: content-type: - text/plain; charset=utf-8 date: - - Mon, 30 Nov 2020 08:20:48 GMT + - Tue, 26 Jan 2021 10:11:28 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/c935a2b7-595c-44f6-890c-c3cc6926cedd?monitor=true&api-version=2019-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/073cd6bb-c655-4547-81d7-b8bdd61ec43a?monitor=true&api-version=2019-06-01 pragma: - no-cache server: @@ -646,21 +646,21 @@ interactions: - keep-alive 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/c935a2b7-595c-44f6-890c-c3cc6926cedd?monitor=true&api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/073cd6bb-c655-4547-81d7-b8bdd61ec43a?monitor=true&api-version=2019-06-01 response: body: - string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename777c1179","name":"storagename777c1179","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"enabled":true,"lastEnabledTime":"2020-11-30T08:20:47.8345666Z"},"blob":{"enabled":true,"lastEnabledTime":"2020-11-30T08:20:47.8345666Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2020-11-30T08:20:47.7408168Z","primaryEndpoints":{"blob":"https://storagename777c1179.blob.core.windows.net/","queue":"https://storagename777c1179.queue.core.windows.net/","table":"https://storagename777c1179.table.core.windows.net/","file":"https://storagename777c1179.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' + string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename777c1179","name":"storagename777c1179","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"privateEndpointConnections":[],"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:11:27.7810294Z"},"blob":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:11:27.7810294Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2021-01-26T10:11:27.6716607Z","primaryEndpoints":{"blob":"https://storagename777c1179.blob.core.windows.net/","queue":"https://storagename777c1179.queue.core.windows.net/","table":"https://storagename777c1179.table.core.windows.net/","file":"https://storagename777c1179.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' headers: cache-control: - no-cache content-length: - - '1138' + - '1210' content-type: - application/json date: - - Mon, 30 Nov 2020 08:21:06 GMT + - Tue, 26 Jan 2021 10:11:45 GMT expires: - '-1' pragma: @@ -693,16 +693,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179\"\ - ,\r\n \"etag\": \"W/\\\"c0b465f4-d6ce-4ac1-86cf-68958a73e276\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"a8706bf2-7c1c-4529-bd20-16f173a1efc7\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"c5ab013a-7228-4c13-9a61-d228c92508a3\",\r\n \"\ + \ \"resourceGuid\": \"412293e9-f032-4ab3-a16f-e781e28e5f74\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -711,7 +711,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/9ff390a2-2876-4108-9f21-2b211514f0cf?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0e536663-5876-4021-a24d-1f67be634ac9?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -719,7 +719,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:12 GMT + - Tue, 26 Jan 2021 10:11:52 GMT expires: - '-1' pragma: @@ -732,7 +732,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 99a94589-7752-491c-b6cf-504bc7e57f98 + - 7e62136f-7773-4512-8c18-b04d23dc24f6 x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -748,9 +748,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/9ff390a2-2876-4108-9f21-2b211514f0cf?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0e536663-5876-4021-a24d-1f67be634ac9?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -762,7 +762,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:16 GMT + - Tue, 26 Jan 2021 10:11:55 GMT expires: - '-1' pragma: @@ -779,7 +779,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ef12e5d0-a7c6-4479-8008-87e59842cef0 + - 4b25a160-ecc5-4cc4-85ef-63d8e751bc7e status: code: 200 message: OK @@ -793,16 +793,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179\"\ - ,\r\n \"etag\": \"W/\\\"d4b300ac-2440-43d7-af9a-8eac4a84ca2f\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"f74425ff-ff2c-4f0e-9ad4-86aec1fac214\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"c5ab013a-7228-4c13-9a61-d228c92508a3\",\r\n \"\ + \ \"resourceGuid\": \"412293e9-f032-4ab3-a16f-e781e28e5f74\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -815,9 +815,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:16 GMT + - Tue, 26 Jan 2021 10:11:56 GMT etag: - - W/"d4b300ac-2440-43d7-af9a-8eac4a84ca2f" + - W/"f74425ff-ff2c-4f0e-9ad4-86aec1fac214" expires: - '-1' pragma: @@ -834,7 +834,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6523b405-c7ba-4ee5-8bdb-a154dda87b90 + - 20525f07-c594-48f4-ac8e-912012ff445a status: code: 200 message: OK @@ -852,20 +852,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179\"\ - ,\r\n \"etag\": \"W/\\\"df3d3e1f-09a6-4fb8-99f7-da9d49b3d089\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"05270933-ccb0-4ccf-a295-53c351f8e866\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/914a3840-0d85-4054-8929-51572156b64f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d9c67f4a-32ed-4102-84a4-ce91a887eb58?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -873,7 +873,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:18 GMT + - Tue, 26 Jan 2021 10:11:56 GMT expires: - '-1' pragma: @@ -886,7 +886,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 650c0216-ce30-48b5-a767-280db2a6b99d + - 977d7ff6-7a00-4356-93f6-18d9d0762ad0 x-ms-ratelimit-remaining-subscription-writes: - '1196' status: @@ -902,9 +902,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/914a3840-0d85-4054-8929-51572156b64f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d9c67f4a-32ed-4102-84a4-ce91a887eb58?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -916,7 +916,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:22 GMT + - Tue, 26 Jan 2021 10:12:00 GMT expires: - '-1' pragma: @@ -933,7 +933,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 18a2bab1-9c10-4355-85ed-74c0739d1fdd + - adaa7cc3-02bb-4f1a-b501-83bee6f88649 status: code: 200 message: OK @@ -947,13 +947,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork777c1179/subnets/subnet777c1179\"\ - ,\r\n \"etag\": \"W/\\\"d37c2152-1598-42a9-beab-f9e9939c82f8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"2cfbbc24-d00b-42f0-a9ff-0197918ec036\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -966,9 +966,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:22 GMT + - Tue, 26 Jan 2021 10:12:00 GMT etag: - - W/"d37c2152-1598-42a9-beab-f9e9939c82f8" + - W/"2cfbbc24-d00b-42f0-a9ff-0197918ec036" expires: - '-1' pragma: @@ -985,7 +985,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ecc1154d-551e-425a-9df5-0a05a421dbb5 + - 2cb22933-bb2a-42da-aa81-59ddd6e7959b status: code: 200 message: OK @@ -1004,16 +1004,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork2777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork2777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179\"\ - ,\r\n \"etag\": \"W/\\\"9d7dfdc3-a639-4ffe-8b7a-050535b29094\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5b852da7-c4fe-4c67-bf83-683f9b4d94e8\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"f60fd1f5-720f-4a15-bf41-ba3f8c36b621\",\r\n \"\ + \ \"resourceGuid\": \"609d8ce3-0d76-4062-b9c1-a7ce31c469ed\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -1022,7 +1022,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3478a3fa-e094-448a-b2d5-14d111dc7194?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1f60bc27-efaf-4a02-afd2-3926f2bfbbeb?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1030,7 +1030,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:26 GMT + - Tue, 26 Jan 2021 10:12:04 GMT expires: - '-1' pragma: @@ -1043,7 +1043,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b0530107-f6cf-42a8-a149-aafeb8561d71 + - 75181905-5eb1-4c61-836a-95fd93262468 x-ms-ratelimit-remaining-subscription-writes: - '1195' status: @@ -1059,9 +1059,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3478a3fa-e094-448a-b2d5-14d111dc7194?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1f60bc27-efaf-4a02-afd2-3926f2bfbbeb?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1073,7 +1073,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:29 GMT + - Tue, 26 Jan 2021 10:12:08 GMT expires: - '-1' pragma: @@ -1090,7 +1090,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 976b7ccc-1cb0-486d-834f-ed259e765e71 + - 1cc80043-be92-4814-a663-34399a57b4f4 status: code: 200 message: OK @@ -1104,16 +1104,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork2777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork2777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179\"\ - ,\r\n \"etag\": \"W/\\\"ac8687f0-be30-4cb6-adc9-0b13a954dc20\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"041b5b17-6053-428b-852e-c4e219868463\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"f60fd1f5-720f-4a15-bf41-ba3f8c36b621\",\r\n \"\ + \ \"resourceGuid\": \"609d8ce3-0d76-4062-b9c1-a7ce31c469ed\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -1126,9 +1126,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:30 GMT + - Tue, 26 Jan 2021 10:12:08 GMT etag: - - W/"ac8687f0-be30-4cb6-adc9-0b13a954dc20" + - W/"041b5b17-6053-428b-852e-c4e219868463" expires: - '-1' pragma: @@ -1145,7 +1145,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 30e4fefd-6a8c-4fc6-a2ca-4ebbd6253d41 + - eafcf96b-d6e9-4119-b49a-df125b8ae35a status: code: 200 message: OK @@ -1163,20 +1163,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet2777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179\"\ - ,\r\n \"etag\": \"W/\\\"f77a6a7d-f4e7-4f0b-b449-16b5fb615cb3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e2085fe7-96b7-4a75-b630-e9b6677924e9\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c680cc16-262a-4c39-ae01-cda006942736?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71dabcab-6b3a-475a-8787-0c649ae7b31f?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1184,7 +1184,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:31 GMT + - Tue, 26 Jan 2021 10:12:09 GMT expires: - '-1' pragma: @@ -1197,7 +1197,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 45041238-2b39-457f-a85e-09b85c36891f + - 633f87d0-beef-4d32-a673-142b76122f37 x-ms-ratelimit-remaining-subscription-writes: - '1194' status: @@ -1213,9 +1213,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/c680cc16-262a-4c39-ae01-cda006942736?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/71dabcab-6b3a-475a-8787-0c649ae7b31f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1227,7 +1227,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:34 GMT + - Tue, 26 Jan 2021 10:12:12 GMT expires: - '-1' pragma: @@ -1244,7 +1244,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4861cf3e-e79d-4dab-afd3-c813993e00a9 + - 794732c7-6ed5-4511-be87-1aab2999451f status: code: 200 message: OK @@ -1258,13 +1258,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet2777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork2777c1179/subnets/subnet2777c1179\"\ - ,\r\n \"etag\": \"W/\\\"2484cf7d-c0dc-4ab7-b7cd-e2f282159ace\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d4ef2ed5-dc8e-41c0-9d1d-31194ab7f70f\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -1277,9 +1277,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:34 GMT + - Tue, 26 Jan 2021 10:12:12 GMT etag: - - W/"2484cf7d-c0dc-4ab7-b7cd-e2f282159ace" + - W/"d4ef2ed5-dc8e-41c0-9d1d-31194ab7f70f" expires: - '-1' pragma: @@ -1296,7 +1296,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cf4fb119-4d67-49ed-a966-a824bb312cf5 + - 9254d2ec-8f3e-42e5-867f-57daf3d252d8 status: code: 200 message: OK @@ -1316,23 +1316,23 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkProfiles/networkprofile777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkprofile777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkProfiles\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"3069d08d-da34-40ac-90fd-57491dda9031\",\r\n \"\ + \ \"resourceGuid\": \"82ac301a-feed-4314-ac52-d2548d36dd50\",\r\n \"\ containerNetworkInterfaceConfigurations\": [\r\n {\r\n \"name\"\ : \"eth1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\"\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"\ name\": \"ipconfig1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1/ipConfigurations/ipconfig1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\ \"\",\r\n \"type\": \"Microsoft.Network/networkProfiles/containerNetworkInterfaceConfigurations/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"subnet\": {\r\n \"\ @@ -1345,7 +1345,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8f4126db-21df-4258-9602-a72c81c0ee9f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/63b22a76-7d29-46e4-9e86-771b164f5990?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1353,7 +1353,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:39 GMT + - Tue, 26 Jan 2021 10:12:16 GMT expires: - '-1' pragma: @@ -1366,7 +1366,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - aa545f64-8624-4664-bcbd-a6137217d4f3 + - 9b9d61fe-3d0d-403d-82fe-6ff202d5f536 x-ms-ratelimit-remaining-subscription-writes: - '1193' status: @@ -1386,20 +1386,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroup777c1179\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"5dad9b17-4bc9-4afd-965a-dddb00897e14\",\r\n \ + ,\r\n \"resourceGuid\": \"c0e5ad90-04c7-4eda-bff3-784c59829125\",\r\n \ \ \"securityRules\": [],\r\n \"defaultSecurityRules\": [\r\n {\r\ \n \"name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -1412,7 +1412,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -1425,7 +1425,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -1437,7 +1437,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -1450,7 +1450,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -1463,7 +1463,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"952b24e7-f39c-4cb5-99e6-4c07d87c02fc\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5d8d735f-4a43-4f4a-a136-117e83f4bba0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -1478,7 +1478,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3894b1ae-7083-4ae0-8363-0c722f2229d6?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5674a350-c6b8-45fe-8254-15041378961a?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1486,7 +1486,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:42 GMT + - Tue, 26 Jan 2021 10:12:19 GMT expires: - '-1' pragma: @@ -1499,7 +1499,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6ead5a94-c807-4a8a-a28b-c6602b52ec32 + - f50abc1d-d72f-423e-8e50-efb46c404e59 x-ms-ratelimit-remaining-subscription-writes: - '1192' status: @@ -1515,9 +1515,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3894b1ae-7083-4ae0-8363-0c722f2229d6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5674a350-c6b8-45fe-8254-15041378961a?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1529,7 +1529,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:46 GMT + - Tue, 26 Jan 2021 10:12:22 GMT expires: - '-1' pragma: @@ -1546,7 +1546,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ccd379b5-f056-443e-aff6-b6fe9ba7835c + - 64fe6abb-efaa-4439-b12a-b135b3e2570e status: code: 200 message: OK @@ -1560,20 +1560,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroup777c1179\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"5dad9b17-4bc9-4afd-965a-dddb00897e14\",\r\n \ + ,\r\n \"resourceGuid\": \"c0e5ad90-04c7-4eda-bff3-784c59829125\",\r\n \ \ \"securityRules\": [],\r\n \"defaultSecurityRules\": [\r\n {\r\ \n \"name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -1586,7 +1586,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -1599,7 +1599,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -1611,7 +1611,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -1624,7 +1624,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -1637,7 +1637,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"e361c590-d572-4436-a686-58ab49d5c1ab\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3a5e95ef-74c7-4442-8ad2-5a030059e3e4\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -1656,9 +1656,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:46 GMT + - Tue, 26 Jan 2021 10:12:23 GMT etag: - - W/"e361c590-d572-4436-a686-58ab49d5c1ab" + - W/"3a5e95ef-74c7-4442-8ad2-5a030059e3e4" expires: - '-1' pragma: @@ -1675,7 +1675,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c0f6d81f-cbe9-4639-b5bf-286522ac2f3d + - e8a6ebc8-7ffa-47e1-806f-d922b62ac5d7 status: code: 200 message: OK @@ -1695,13 +1695,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"securityrule777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179\"\ - ,\r\n \"etag\": \"W/\\\"a9d7cc16-e93d-4691-bb68-93d1e77dfb95\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9b18ef10-a822-4fc4-8a17-b4843b143559\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups/securityRules\",\r\n\ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ protocol\": \"*\",\r\n \"sourcePortRange\": \"*\",\r\n \"destinationPortRange\"\ @@ -1712,7 +1712,7 @@ interactions: \ \"destinationAddressPrefixes\": []\r\n }\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/86c96f3c-9be5-4f96-864a-eec67601b7c2?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5e1e62a3-6ec2-4d7d-9d70-fd87d21dcd40?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1720,7 +1720,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:47 GMT + - Tue, 26 Jan 2021 10:12:24 GMT expires: - '-1' pragma: @@ -1733,7 +1733,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6ebd7286-db37-4c94-938b-602e3742be2b + - a190492e-3cd0-4d30-a53e-2104c6550080 x-ms-ratelimit-remaining-subscription-writes: - '1191' status: @@ -1749,9 +1749,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/86c96f3c-9be5-4f96-864a-eec67601b7c2?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5e1e62a3-6ec2-4d7d-9d70-fd87d21dcd40?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1763,7 +1763,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:58 GMT + - Tue, 26 Jan 2021 10:12:35 GMT expires: - '-1' pragma: @@ -1780,7 +1780,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6ae75589-6fbd-4ee0-9270-524dca84c81e + - a6f82cdf-76c6-412e-a6ce-371d3cd4fac2 status: code: 200 message: OK @@ -1794,13 +1794,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"securityrule777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups/securityRules\",\r\n\ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ protocol\": \"*\",\r\n \"sourcePortRange\": \"*\",\r\n \"destinationPortRange\"\ @@ -1817,9 +1817,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:59 GMT + - Tue, 26 Jan 2021 10:12:35 GMT etag: - - W/"699065ac-31cc-4c72-973f-7de519685af9" + - W/"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9" expires: - '-1' pragma: @@ -1836,7 +1836,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 42ecdd51-783f-4c00-afd5-a3f239116166 + - 1885b4b6-f47a-42a2-b772-f9e245c8d6c9 status: code: 200 message: OK @@ -1850,13 +1850,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"description\": \"Allow inbound traffic from all VMs in VNET\",\r\n\ @@ -1874,9 +1874,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:21:59 GMT + - Tue, 26 Jan 2021 10:12:36 GMT etag: - - W/"699065ac-31cc-4c72-973f-7de519685af9" + - W/"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9" expires: - '-1' pragma: @@ -1893,7 +1893,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4182dfe3-dd1a-45ec-8857-53e7372a6d4a + - 445f9de8-08ce-4adb-9606-865a431e1f50 status: code: 200 message: OK @@ -1907,13 +1907,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"securityrule777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups/securityRules\",\r\n\ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ protocol\": \"*\",\r\n \"sourcePortRange\": \"*\",\r\n \"destinationPortRange\"\ @@ -1930,9 +1930,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:00 GMT + - Tue, 26 Jan 2021 10:12:36 GMT etag: - - W/"699065ac-31cc-4c72-973f-7de519685af9" + - W/"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9" expires: - '-1' pragma: @@ -1949,7 +1949,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d8e58c98-1ae5-43de-afbc-1606278424b1 + - 23d86d74-55a7-4157-bfb9-889f55529d9c status: code: 200 message: OK @@ -1963,20 +1963,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroup777c1179\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"5dad9b17-4bc9-4afd-965a-dddb00897e14\",\r\n \ + ,\r\n \"resourceGuid\": \"c0e5ad90-04c7-4eda-bff3-784c59829125\",\r\n \ \ \"securityRules\": [\r\n {\r\n \"name\": \"securityrule777c1179\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/securityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"protocol\": \"*\",\r\n \"sourcePortRange\": \"*\"\ @@ -1988,7 +1988,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ }\r\n ],\r\n \"defaultSecurityRules\": [\r\n {\r\n \"\ name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -2001,7 +2001,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -2014,7 +2014,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -2026,7 +2026,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -2039,7 +2039,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -2052,7 +2052,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"699065ac-31cc-4c72-973f-7de519685af9\\\"\"\ + ,\r\n \"etag\": \"W/\\\"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -2071,9 +2071,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:01 GMT + - Tue, 26 Jan 2021 10:12:36 GMT etag: - - W/"699065ac-31cc-4c72-973f-7de519685af9" + - W/"3642f1cb-2fd8-4785-b2a0-1cdb52b6afd9" expires: - '-1' pragma: @@ -2090,7 +2090,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5b963f1b-a702-496c-9e2b-8e8d1fff0237 + - e86d0b42-9711-461d-afcf-2d45cfbbe2d2 status: code: 200 message: OK @@ -2104,23 +2104,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkProfiles/networkprofile777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkprofile777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkProfiles\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"3069d08d-da34-40ac-90fd-57491dda9031\",\r\n \"\ + \ \"resourceGuid\": \"82ac301a-feed-4314-ac52-d2548d36dd50\",\r\n \"\ containerNetworkInterfaceConfigurations\": [\r\n {\r\n \"name\"\ : \"eth1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\"\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"\ name\": \"ipconfig1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1/ipConfigurations/ipconfig1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\ \"\",\r\n \"type\": \"Microsoft.Network/networkProfiles/containerNetworkInterfaceConfigurations/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"subnet\": {\r\n \"\ @@ -2137,9 +2137,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:02 GMT + - Tue, 26 Jan 2021 10:12:37 GMT etag: - - W/"df077bc9-348f-46cf-b385-64280a0dd16a" + - W/"bb1655b1-4a16-4a6c-b2f3-4213a243fe98" expires: - '-1' pragma: @@ -2156,7 +2156,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - de25fc61-4462-48f5-959b-8ef77485faf7 + - b6d7837a-aa50-4a6e-ac8b-c5283b22629f status: code: 200 message: OK @@ -2170,23 +2170,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkProfiles/networkprofile777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkprofile777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkProfiles\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"3069d08d-da34-40ac-90fd-57491dda9031\",\r\n \"\ + \ \"resourceGuid\": \"82ac301a-feed-4314-ac52-d2548d36dd50\",\r\n \"\ containerNetworkInterfaceConfigurations\": [\r\n {\r\n \"name\"\ : \"eth1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\"\"\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"\ name\": \"ipconfig1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1/ipConfigurations/ipconfig1\"\ - ,\r\n \"etag\": \"W/\\\"df077bc9-348f-46cf-b385-64280a0dd16a\\\ + ,\r\n \"etag\": \"W/\\\"bb1655b1-4a16-4a6c-b2f3-4213a243fe98\\\ \"\",\r\n \"type\": \"Microsoft.Network/networkProfiles/containerNetworkInterfaceConfigurations/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"subnet\": {\r\n \"\ @@ -2203,9 +2203,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:02 GMT + - Tue, 26 Jan 2021 10:12:37 GMT etag: - - W/"df077bc9-348f-46cf-b385-64280a0dd16a" + - W/"bb1655b1-4a16-4a6c-b2f3-4213a243fe98" expires: - '-1' pragma: @@ -2222,7 +2222,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e0594d53-a34b-4274-a660-4cc9d4b9d8df + - 3f97007a-c267-453e-b342-62b2f282ede7 status: code: 200 message: OK @@ -2240,21 +2240,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroup777c1179\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\"\ : \"value2\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\":\ - \ \"Succeeded\",\r\n \"resourceGuid\": \"5dad9b17-4bc9-4afd-965a-dddb00897e14\"\ + \ \"Succeeded\",\r\n \"resourceGuid\": \"c0e5ad90-04c7-4eda-bff3-784c59829125\"\ ,\r\n \"securityRules\": [\r\n {\r\n \"name\": \"securityrule777c1179\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/securityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"protocol\": \"*\",\r\n \"sourcePortRange\": \"*\"\ @@ -2266,7 +2266,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ }\r\n ],\r\n \"defaultSecurityRules\": [\r\n {\r\n \"\ name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -2279,7 +2279,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -2292,7 +2292,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -2304,7 +2304,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -2317,7 +2317,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -2330,7 +2330,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"a7a8cd85-d925-429e-91b5-843a4c052710\\\"\"\ + ,\r\n \"etag\": \"W/\\\"baf796dc-2401-4fc1-b74b-a3c028fd0db0\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -2351,7 +2351,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:05 GMT + - Tue, 26 Jan 2021 10:12:40 GMT expires: - '-1' pragma: @@ -2368,7 +2368,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e7e82acd-1b27-48b6-8e8b-c4ff382f0bd1 + - e2f3b8f4-8e2b-4500-8bba-98b16dfdc1be x-ms-ratelimit-remaining-subscription-writes: - '1190' status: @@ -2388,24 +2388,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkProfiles/networkprofile777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkprofile777c1179\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179\"\ - ,\r\n \"etag\": \"W/\\\"58234a4d-b4e5-4e93-bc80-4ea61c76be58\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"ccde479c-bf7d-4961-8069-1f70fa75542c\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkProfiles\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"3069d08d-da34-40ac-90fd-57491dda9031\",\r\n \ + ,\r\n \"resourceGuid\": \"82ac301a-feed-4314-ac52-d2548d36dd50\",\r\n \ \ \"containerNetworkInterfaceConfigurations\": [\r\n {\r\n \"\ name\": \"eth1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1\"\ - ,\r\n \"etag\": \"W/\\\"58234a4d-b4e5-4e93-bc80-4ea61c76be58\\\"\"\ + ,\r\n \"etag\": \"W/\\\"ccde479c-bf7d-4961-8069-1f70fa75542c\\\"\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"\ name\": \"ipconfig1\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179/containerNetworkInterfaceConfigurations/eth1/ipConfigurations/ipconfig1\"\ - ,\r\n \"etag\": \"W/\\\"58234a4d-b4e5-4e93-bc80-4ea61c76be58\\\ + ,\r\n \"etag\": \"W/\\\"ccde479c-bf7d-4961-8069-1f70fa75542c\\\ \"\",\r\n \"type\": \"Microsoft.Network/networkProfiles/containerNetworkInterfaceConfigurations/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Succeeded\",\r\n \"subnet\": {\r\n \"\ @@ -2424,7 +2424,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:08 GMT + - Tue, 26 Jan 2021 10:12:42 GMT expires: - '-1' pragma: @@ -2441,7 +2441,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0a411344-98fd-4495-ae5e-2c117ae721b5 + - 9cc25f3b-d1f9-4dd4-8be5-8cfe8e9a4f7f x-ms-ratelimit-remaining-subscription-writes: - '1189' status: @@ -2459,25 +2459,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179/securityRules/securityrule777c1179?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1393630d-95cd-4a22-9540-439c8af588a7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b6d0bfee-77b7-4b5d-afdb-577d9d8c9232?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:22:09 GMT + - Tue, 26 Jan 2021 10:12:42 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1393630d-95cd-4a22-9540-439c8af588a7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b6d0bfee-77b7-4b5d-afdb-577d9d8c9232?api-version=2020-08-01 pragma: - no-cache server: @@ -2488,7 +2488,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d0b91c31-6d7a-4735-8d2c-6676996102da + - f4acc1a9-0f35-4630-a5db-b828cdd7d56a x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -2504,9 +2504,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/1393630d-95cd-4a22-9540-439c8af588a7?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b6d0bfee-77b7-4b5d-afdb-577d9d8c9232?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2518,7 +2518,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:20 GMT + - Tue, 26 Jan 2021 10:12:52 GMT expires: - '-1' pragma: @@ -2535,7 +2535,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7c80f4cc-9409-4238-9f75-613061f21a73 + - ad14475c-a785-4820-9cd7-e5215596f017 status: code: 200 message: OK @@ -2551,9 +2551,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroup777c1179?api-version=2020-08-01 response: body: string: '' @@ -2561,17 +2561,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0910c794-c58c-42df-8617-5000a41521b6?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d0d1d48b-0501-48f0-87b8-d9b6dbb18632?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:22:21 GMT + - Tue, 26 Jan 2021 10:12:53 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0910c794-c58c-42df-8617-5000a41521b6?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/d0d1d48b-0501-48f0-87b8-d9b6dbb18632?api-version=2020-08-01 pragma: - no-cache server: @@ -2582,7 +2582,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9b2cdbcd-5ce5-4125-ba91-89f1f2a84e3f + - 9db42a9a-f06f-41b1-8f74-a8b424bc2782 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -2598,9 +2598,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0910c794-c58c-42df-8617-5000a41521b6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d0d1d48b-0501-48f0-87b8-d9b6dbb18632?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2612,7 +2612,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:31 GMT + - Tue, 26 Jan 2021 10:13:03 GMT expires: - '-1' pragma: @@ -2629,7 +2629,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2cb50cac-495e-4233-8fa8-13767d966845 + - 3e3fa65f-f3d0-46b6-9d48-8934f986099e status: code: 200 message: OK @@ -2645,9 +2645,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkProfiles/networkprofile777c1179?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkProfiles/networkprofile777c1179?api-version=2020-08-01 response: body: string: '' @@ -2655,17 +2655,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f3bac74b-2d71-4c52-b55f-7da315bab4f3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/413522bc-c142-465a-aaf5-afac6fa89e40?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:22:32 GMT + - Tue, 26 Jan 2021 10:13:04 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f3bac74b-2d71-4c52-b55f-7da315bab4f3?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/413522bc-c142-465a-aaf5-afac6fa89e40?api-version=2020-08-01 pragma: - no-cache server: @@ -2676,7 +2676,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 99336fdf-60af-4310-80fd-55b5e50d4d8c + - 64df76b8-fea1-4815-ad8e-4a79d7e5adf0 x-ms-ratelimit-remaining-subscription-deletes: - '14997' status: @@ -2692,9 +2692,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f3bac74b-2d71-4c52-b55f-7da315bab4f3?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/413522bc-c142-465a-aaf5-afac6fa89e40?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2706,7 +2706,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:22:42 GMT + - Tue, 26 Jan 2021 10:13:15 GMT expires: - '-1' pragma: @@ -2723,7 +2723,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2056bc1e-a76e-4f1f-a1b0-96875c90a7ab + - 6cf86342-661a-4524-b5b5-1fb2ed235496 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher.yaml index cb3db2c32d41..f9a8ba1bd390 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher.yaml @@ -14,16 +14,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6\"\ - ,\r\n \"etag\": \"W/\\\"e120e5bd-43a4-4d0c-aaf2-9942b8e7f144\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7c77be59-0da4-41b5-a68f-a6d0300436fb\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"62a36eda-8494-41bd-a5d7-d083f4f402b0\",\r\n \"\ + \ \"resourceGuid\": \"76cac404-cb09-4757-b74c-eba63576a6fe\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -32,7 +32,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/bea7d13c-2dee-43f1-aa49-17476b116e7c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5aa5805c-128a-4c3a-bd97-30102004343b?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -40,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:03 GMT + - Tue, 26 Jan 2021 10:13:35 GMT expires: - '-1' pragma: @@ -53,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c3d2509a-cdbb-41d2-8c5e-c721f9bc04a6 + - e62a7029-e093-4699-8baa-e368adaf5a83 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 201 message: Created @@ -69,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/bea7d13c-2dee-43f1-aa49-17476b116e7c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5aa5805c-128a-4c3a-bd97-30102004343b?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -83,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:07 GMT + - Tue, 26 Jan 2021 10:13:39 GMT expires: - '-1' pragma: @@ -100,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 4af6fda3-e3d6-41d0-a372-dda9847850dd + - 05ba6031-3dc1-4718-9764-d647a607c915 status: code: 200 message: OK @@ -114,16 +114,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6\"\ - ,\r\n \"etag\": \"W/\\\"92202033-a07b-464c-ba3a-aa5f33b874cb\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"4622a746-51bc-4bbc-a136-0946eacd5dd1\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"62a36eda-8494-41bd-a5d7-d083f4f402b0\",\r\n \"\ + \ \"resourceGuid\": \"76cac404-cb09-4757-b74c-eba63576a6fe\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -136,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:07 GMT + - Tue, 26 Jan 2021 10:13:39 GMT etag: - - W/"92202033-a07b-464c-ba3a-aa5f33b874cb" + - W/"4622a746-51bc-4bbc-a136-0946eacd5dd1" expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ee00dea0-d401-45c4-b5f5-95a849a3db6b + - 628ab44e-057f-4305-ae4d-2ac4bcc235ad status: code: 200 message: OK @@ -173,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6\"\ - ,\r\n \"etag\": \"W/\\\"480680d2-7b96-42ba-be8a-6dc6d91f55f1\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"31bc44e5-f511-4cef-ac9f-2268012e59dc\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f11b1619-df98-40e7-9776-260bf8e6b090?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/35258739-21a8-467d-979f-28a483f933a4?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -194,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:08 GMT + - Tue, 26 Jan 2021 10:13:40 GMT expires: - '-1' pragma: @@ -207,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fa2e115f-bd6a-4455-9a9a-7b78343092e8 + - 3a30c5db-d314-4aa8-a38e-7da531d80c07 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -223,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f11b1619-df98-40e7-9776-260bf8e6b090?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/35258739-21a8-467d-979f-28a483f933a4?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -237,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:12 GMT + - Tue, 26 Jan 2021 10:13:43 GMT expires: - '-1' pragma: @@ -254,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 28bacf6b-d9e9-4951-a5d1-c4169c600fdb + - 2820086d-e13e-4aec-a57f-a1194495295a status: code: 200 message: OK @@ -268,13 +268,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork121614c6/subnets/subnet121614c6\"\ - ,\r\n \"etag\": \"W/\\\"77700ec3-69e6-4f5b-bf7a-67287a15650c\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"72cc5052-22b5-42e4-a7ef-6b3d1ca2b2d8\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -287,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:12 GMT + - Tue, 26 Jan 2021 10:13:43 GMT etag: - - W/"77700ec3-69e6-4f5b-bf7a-67287a15650c" + - W/"72cc5052-22b5-42e4-a7ef-6b3d1ca2b2d8" expires: - '-1' pragma: @@ -306,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f0cf8064-ec13-4d6a-b406-036d464ede61 + - 765e0366-b93a-4978-a27d-1fcd4084778d status: code: 200 message: OK @@ -325,18 +325,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interface121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6\"\ - ,\r\n \"etag\": \"W/\\\"9f9c3411-449f-4e15-aaf8-1018db5d2f08\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5525e92c-9b7b-4b4a-8ba3-5f43807b0db6\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"ec045b13-7eeb-458a-a73a-f691163973a6\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"caf68f4e-381d-40d7-9f63-4af9759712a6\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"9f9c3411-449f-4e15-aaf8-1018db5d2f08\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5525e92c-9b7b-4b4a-8ba3-5f43807b0db6\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -344,7 +344,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"1jxkgyuuqs4udjox0cb5j3acwa.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"atcmu3qjznlupn0m3otdk3vg5g.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -353,7 +353,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/da9b8733-6553-453b-b50f-7a35f6e64a98?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/810ac700-46de-49bb-876f-931b8d221e67?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -361,7 +361,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:17 GMT + - Tue, 26 Jan 2021 10:13:47 GMT expires: - '-1' pragma: @@ -374,9 +374,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c9791e25-d431-4e7d-9402-cddb7ba429bb + - 9a3a2f55-4048-4abc-a413-911d44dac64e x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: code: 201 message: Created @@ -390,9 +390,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/da9b8733-6553-453b-b50f-7a35f6e64a98?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/810ac700-46de-49bb-876f-931b8d221e67?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -404,7 +404,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:48 GMT + - Tue, 26 Jan 2021 10:14:18 GMT expires: - '-1' pragma: @@ -421,7 +421,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3f6cecaa-19ef-4591-ad8b-d36beff0d73a + - 83d91b84-5e40-41e7-b139-0e010cb2afd4 status: code: 200 message: OK @@ -435,18 +435,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interface121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6\"\ - ,\r\n \"etag\": \"W/\\\"9f9c3411-449f-4e15-aaf8-1018db5d2f08\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5525e92c-9b7b-4b4a-8ba3-5f43807b0db6\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"ec045b13-7eeb-458a-a73a-f691163973a6\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"caf68f4e-381d-40d7-9f63-4af9759712a6\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"9f9c3411-449f-4e15-aaf8-1018db5d2f08\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5525e92c-9b7b-4b4a-8ba3-5f43807b0db6\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -454,7 +454,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"1jxkgyuuqs4udjox0cb5j3acwa.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"atcmu3qjznlupn0m3otdk3vg5g.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -467,9 +467,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:48 GMT + - Tue, 26 Jan 2021 10:14:18 GMT etag: - - W/"9f9c3411-449f-4e15-aaf8-1018db5d2f08" + - W/"5525e92c-9b7b-4b4a-8ba3-5f43807b0db6" expires: - '-1' pragma: @@ -486,7 +486,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0c45a22e-54eb-4e20-82cd-d5497c643576 + - a9d8dc32-b19f-4fd4-82c7-1e2685afe8a0 status: code: 200 message: OK @@ -514,21 +514,22 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachine121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"7d251647-daeb-4046-b051-1b263e811076\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"e0048192-9aa2-4137-91e6-e9345ec7a062\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ @@ -545,7 +546,8 @@ interactions: \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ - : true\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ + : true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\ + \r\n }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ @@ -554,15 +556,15 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5499bc1e-3275-43bb-8751-5267c057ec3b?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5bca2840-2788-4398-bd46-4300b482a597?api-version=2020-06-01 cache-control: - no-cache content-length: - - '2234' + - '2421' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:23:56 GMT + - Tue, 26 Jan 2021 10:14:27 GMT expires: - '-1' pragma: @@ -592,13 +594,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5499bc1e-3275-43bb-8751-5267c057ec3b?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5bca2840-2788-4398-bd46-4300b482a597?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:23:54.6562957+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"5499bc1e-3275-43bb-8751-5267c057ec3b\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:14:25.0122222+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"5bca2840-2788-4398-bd46-4300b482a597\"\ \r\n}" headers: cache-control: @@ -608,7 +610,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:24:07 GMT + - Tue, 26 Jan 2021 10:14:38 GMT expires: - '-1' pragma: @@ -640,13 +642,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5499bc1e-3275-43bb-8751-5267c057ec3b?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5bca2840-2788-4398-bd46-4300b482a597?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:23:54.6562957+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"5499bc1e-3275-43bb-8751-5267c057ec3b\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:14:25.0122222+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"5bca2840-2788-4398-bd46-4300b482a597\"\ \r\n}" headers: cache-control: @@ -656,7 +658,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:24:58 GMT + - Tue, 26 Jan 2021 10:15:28 GMT expires: - '-1' pragma: @@ -688,23 +690,23 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5499bc1e-3275-43bb-8751-5267c057ec3b?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5bca2840-2788-4398-bd46-4300b482a597?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:23:54.6562957+00:00\",\r\n \"\ - endTime\": \"2020-11-30T08:25:19.546859+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"5499bc1e-3275-43bb-8751-5267c057ec3b\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T10:14:25.0122222+00:00\",\r\n \"\ + endTime\": \"2021-01-26T10:15:53.3408895+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"5bca2840-2788-4398-bd46-4300b482a597\"\r\n}" headers: cache-control: - no-cache content-length: - - '183' + - '184' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:25:29 GMT + - Tue, 26 Jan 2021 10:15:58 GMT expires: - '-1' pragma: @@ -736,54 +738,56 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachine121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"7d251647-daeb-4046-b051-1b263e811076\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"e0048192-9aa2-4137-91e6-e9345ec7a062\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ - : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine121614c6_disk2_98186357ecae40718ece21f38b27c5ad\"\ + : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine121614c6_disk2_56211e72be884e17a868625d4d9a9be8\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine121614c6_disk2_98186357ecae40718ece21f38b27c5ad\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine121614c6_disk2_56211e72be884e17a868625d4d9a9be8\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ - name\": \"virtualmachine121614c6_disk3_89c45b0147184a6589026e71582c4cc4\"\ + name\": \"virtualmachine121614c6_disk3_67f7c99d252f44d1ac66c3568738b372\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine121614c6_disk3_89c45b0147184a6589026e71582c4cc4\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine121614c6_disk3_67f7c99d252f44d1ac66c3568738b372\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ - \n \"enableAutomaticUpdates\": true\r\n },\r\n \"secrets\"\ - : [],\r\n \"allowExtensionOperations\": true,\r\n \"requireGuestProvisionSignal\"\ - : true\r\n },\r\n \"networkProfile\": {\"networkInterfaces\":[{\"id\"\ - :\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6\"\ + \n \"enableAutomaticUpdates\": true,\r\n \"patchSettings\":\ + \ {\r\n \"patchMode\": \"AutomaticByOS\"\r\n }\r\n },\r\ + \n \"secrets\": [],\r\n \"allowExtensionOperations\": true,\r\n\ + \ \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\"\ + : {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface121614c6\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '3133' + - '3320' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:25:29 GMT + - Tue, 26 Jan 2021 10:15:58 GMT expires: - '-1' pragma: @@ -800,7 +804,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3998,Microsoft.Compute/LowCostGet30Min;31998 + - Microsoft.Compute/LowCostGet3Min;3998,Microsoft.Compute/LowCostGet30Min;31994 status: code: 200 message: OK @@ -821,11 +825,11 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6/extensions/virtualmachineextension121614c6?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6/extensions/virtualmachineextension121614c6?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextension121614c6\",\r\n \"id\":\ @@ -839,7 +843,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d6ac3e7-8e6c-433f-9099-500f545336c1?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb?api-version=2020-06-01 cache-control: - no-cache content-length: @@ -847,7 +851,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:25:35 GMT + - Tue, 26 Jan 2021 10:16:05 GMT expires: - '-1' pragma: @@ -877,13 +881,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d6ac3e7-8e6c-433f-9099-500f545336c1?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:25:34.9842962+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"5d6ac3e7-8e6c-433f-9099-500f545336c1\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:16:04.2471514+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb\"\ \r\n}" headers: cache-control: @@ -893,7 +897,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:26:06 GMT + - Tue, 26 Jan 2021 10:16:36 GMT expires: - '-1' pragma: @@ -925,13 +929,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d6ac3e7-8e6c-433f-9099-500f545336c1?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:25:34.9842962+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"5d6ac3e7-8e6c-433f-9099-500f545336c1\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:16:04.2471514+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb\"\ \r\n}" headers: cache-control: @@ -941,7 +945,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:26:36 GMT + - Tue, 26 Jan 2021 10:17:06 GMT expires: - '-1' pragma: @@ -973,13 +977,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d6ac3e7-8e6c-433f-9099-500f545336c1?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:25:34.9842962+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"5d6ac3e7-8e6c-433f-9099-500f545336c1\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:16:04.2471514+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb\"\ \r\n}" headers: cache-control: @@ -989,7 +993,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:27:07 GMT + - Tue, 26 Jan 2021 10:17:36 GMT expires: - '-1' pragma: @@ -1021,14 +1025,14 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/5d6ac3e7-8e6c-433f-9099-500f545336c1?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T08:25:34.9842962+00:00\",\r\n \"\ - endTime\": \"2020-11-30T08:27:29.3591891+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"5d6ac3e7-8e6c-433f-9099-500f545336c1\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T10:16:04.2471514+00:00\",\r\n \"\ + endTime\": \"2021-01-26T10:17:38.0911557+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"09bd2e92-1ac2-43b5-8d44-1f4c1988d6eb\"\r\n}" headers: cache-control: - no-cache @@ -1037,7 +1041,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:27:39 GMT + - Tue, 26 Jan 2021 10:18:07 GMT expires: - '-1' pragma: @@ -1069,9 +1073,9 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6/extensions/virtualmachineextension121614c6?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6/extensions/virtualmachineextension121614c6?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextension121614c6\",\r\n \"id\":\ @@ -1089,7 +1093,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:27:39 GMT + - Tue, 26 Jan 2021 10:18:07 GMT expires: - '-1' pragma: @@ -1106,7 +1110,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3995,Microsoft.Compute/LowCostGet30Min;31995 + - Microsoft.Compute/LowCostGet3Min;3996,Microsoft.Compute/LowCostGet30Min;31992 status: code: 200 message: OK @@ -1125,11 +1129,11 @@ interactions: - 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename121614c6?api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename121614c6?api-version=2019-06-01 response: body: string: '' @@ -1141,11 +1145,11 @@ interactions: content-type: - text/plain; charset=utf-8 date: - - Mon, 30 Nov 2020 08:27:45 GMT + - Tue, 26 Jan 2021 10:18:14 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/83538836-1374-4baa-b10b-16dd62cece8b?monitor=true&api-version=2019-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/187e1271-6646-4868-bf84-65045d712d71?monitor=true&api-version=2019-06-01 pragma: - no-cache server: @@ -1155,7 +1159,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 202 message: Accepted @@ -1170,21 +1174,21 @@ interactions: - keep-alive 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/83538836-1374-4baa-b10b-16dd62cece8b?monitor=true&api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/187e1271-6646-4868-bf84-65045d712d71?monitor=true&api-version=2019-06-01 response: body: - string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename121614c6","name":"storagename121614c6","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"enabled":true,"lastEnabledTime":"2020-11-30T08:27:45.2593813Z"},"blob":{"enabled":true,"lastEnabledTime":"2020-11-30T08:27:45.2593813Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2020-11-30T08:27:45.1499780Z","primaryEndpoints":{"blob":"https://storagename121614c6.blob.core.windows.net/","queue":"https://storagename121614c6.queue.core.windows.net/","table":"https://storagename121614c6.table.core.windows.net/","file":"https://storagename121614c6.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' + string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename121614c6","name":"storagename121614c6","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"privateEndpointConnections":[],"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:18:14.0785283Z"},"blob":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:18:14.0785283Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2021-01-26T10:18:13.9691648Z","primaryEndpoints":{"blob":"https://storagename121614c6.blob.core.windows.net/","queue":"https://storagename121614c6.queue.core.windows.net/","table":"https://storagename121614c6.table.core.windows.net/","file":"https://storagename121614c6.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' headers: cache-control: - no-cache content-length: - - '1138' + - '1210' content-type: - application/json date: - - Mon, 30 Nov 2020 08:28:03 GMT + - Tue, 26 Jan 2021 10:18:32 GMT expires: - '-1' pragma: @@ -1216,13 +1220,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcher121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6\"\ - ,\r\n \"etag\": \"W/\\\"f407ebdb-6b3b-40d1-842a-5d42202d227f\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"78549c7e-be5f-4f93-a525-8f2443219608\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1230,7 +1234,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8b2ba76f-77df-4ee1-8154-48404fac2b96?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/34f22590-1770-4e5c-aab0-ac34f8498965?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1238,7 +1242,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:11 GMT + - Tue, 26 Jan 2021 10:18:39 GMT expires: - '-1' pragma: @@ -1251,9 +1255,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7c525d5b-809c-45b6-91ff-e244660a6506 + - a137b84e-e891-432c-afa4-e0eaf0c3c782 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1197' status: code: 201 message: Created @@ -1267,13 +1271,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcher121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6\"\ - ,\r\n \"etag\": \"W/\\\"80852e15-7ede-4517-896b-87b4b9262a5c\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"15a5d8fa-aca8-4406-8c96-a4a4ae4e2f8d\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1285,9 +1289,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:11 GMT + - Tue, 26 Jan 2021 10:18:40 GMT etag: - - W/"80852e15-7ede-4517-896b-87b4b9262a5c" + - W/"15a5d8fa-aca8-4406-8c96-a4a4ae4e2f8d" expires: - '-1' pragma: @@ -1304,7 +1308,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 41346a87-6786-4c90-a666-f3d3d7ae1bfa + - 4e3ae651-9669-4992-87a7-532f2ea1c5c0 status: code: 200 message: OK @@ -1324,9 +1328,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6/networkConfigurationDiagnostic?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6/networkConfigurationDiagnostic?api-version=2020-08-01 response: body: string: 'null' @@ -1338,11 +1342,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:11 GMT + - Tue, 26 Jan 2021 10:18:40 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/767628fe-5721-4f69-b396-741786c63182?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2c598092-17b9-41cf-9ec2-fa4c4f7c42de?api-version=2020-08-01 pragma: - no-cache server: @@ -1353,7 +1357,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6fc4190f-642f-4ab1-a374-90470cdb027f + - 42068dc1-98b8-4bd2-a305-a7e908d4cd31 status: code: 202 message: Accepted @@ -1367,9 +1371,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/767628fe-5721-4f69-b396-741786c63182?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2c598092-17b9-41cf-9ec2-fa4c4f7c42de?api-version=2020-08-01 response: body: string: "{\r\n \"results\": []\r\n}" @@ -1381,11 +1385,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:23 GMT + - Tue, 26 Jan 2021 10:18:51 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/767628fe-5721-4f69-b396-741786c63182?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/2c598092-17b9-41cf-9ec2-fa4c4f7c42de?api-version=2020-08-01 pragma: - no-cache server: @@ -1400,7 +1404,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6fc4190f-642f-4ab1-a374-90470cdb027f + - 42068dc1-98b8-4bd2-a305-a7e908d4cd31 status: code: 200 message: OK @@ -1418,9 +1422,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6/securityGroupView?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6/securityGroupView?api-version=2020-08-01 response: body: string: 'null' @@ -1432,11 +1436,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:24 GMT + - Tue, 26 Jan 2021 10:18:51 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0cae413c-373b-4699-9d52-83ca57675544?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bb7bca33-5a52-4ad5-8c56-7aa588300cbf?api-version=2020-08-01 pragma: - no-cache server: @@ -1447,7 +1451,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0f612973-22d9-451d-86e2-9c2b41480065 + - e8d6dbac-637b-4900-8f70-2a5d0763c803 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -1463,9 +1467,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0cae413c-373b-4699-9d52-83ca57675544?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bb7bca33-5a52-4ad5-8c56-7aa588300cbf?api-version=2020-08-01 response: body: string: "{\r\n \"networkInterfaces\": []\r\n}" @@ -1477,11 +1481,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:34 GMT + - Tue, 26 Jan 2021 10:19:02 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0cae413c-373b-4699-9d52-83ca57675544?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bb7bca33-5a52-4ad5-8c56-7aa588300cbf?api-version=2020-08-01 pragma: - no-cache server: @@ -1496,7 +1500,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0f612973-22d9-451d-86e2-9c2b41480065 + - e8d6dbac-637b-4900-8f70-2a5d0763c803 status: code: 200 message: OK @@ -1515,9 +1519,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6/connectivityCheck?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6/connectivityCheck?api-version=2020-08-01 response: body: string: 'null' @@ -1529,11 +1533,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:34 GMT + - Tue, 26 Jan 2021 10:19:03 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1544,7 +1548,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1558,9 +1562,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1572,11 +1576,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:45 GMT + - Tue, 26 Jan 2021 10:19:14 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1587,7 +1591,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1601,9 +1605,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1615,11 +1619,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:28:55 GMT + - Tue, 26 Jan 2021 10:19:25 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1630,7 +1634,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1644,9 +1648,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1658,11 +1662,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:05 GMT + - Tue, 26 Jan 2021 10:19:35 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1673,7 +1677,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1687,9 +1691,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1701,11 +1705,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:16 GMT + - Tue, 26 Jan 2021 10:19:46 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1716,7 +1720,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1730,9 +1734,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1744,11 +1748,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:26 GMT + - Tue, 26 Jan 2021 10:19:57 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1759,7 +1763,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1773,9 +1777,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1787,11 +1791,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:36 GMT + - Tue, 26 Jan 2021 10:20:07 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1802,7 +1806,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1816,9 +1820,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1830,11 +1834,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:47 GMT + - Tue, 26 Jan 2021 10:20:17 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1845,7 +1849,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1859,9 +1863,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1873,11 +1877,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:29:57 GMT + - Tue, 26 Jan 2021 10:20:27 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1888,7 +1892,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1902,9 +1906,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1916,11 +1920,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:07 GMT + - Tue, 26 Jan 2021 10:20:38 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1931,7 +1935,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1945,9 +1949,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -1959,11 +1963,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:17 GMT + - Tue, 26 Jan 2021 10:20:48 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -1974,7 +1978,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -1988,9 +1992,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: 'null' @@ -2002,11 +2006,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:28 GMT + - Tue, 26 Jan 2021 10:20:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -2017,7 +2021,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 202 message: Accepted @@ -2031,17 +2035,17 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 response: body: string: "{\r\n \"hops\": [\r\n {\r\n \"type\": \"Source\",\r\n \ - \ \"id\": \"e63687ea-5937-4d62-bc76-14b142dc2a37\",\r\n \"address\"\ + \ \"id\": \"9187d940-3ac3-4f4c-966e-b0008cdcf911\",\r\n \"address\"\ : \"10.0.0.4\",\r\n \"resourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6\"\ - ,\r\n \"nextHopIds\": [\r\n \"0861cd92-a6cc-4156-85fc-53bc29c03158\"\ + ,\r\n \"nextHopIds\": [\r\n \"9f755163-8bca-4a77-89a8-a3b4e0c2943d\"\ \r\n ],\r\n \"links\": [\r\n {\r\n \"nextHopId\"\ - : \"0861cd92-a6cc-4156-85fc-53bc29c03158\",\r\n \"linkType\": \"\ + : \"9f755163-8bca-4a77-89a8-a3b4e0c2943d\",\r\n \"linkType\": \"\ VirtualNetwork\",\r\n \"properties\": {},\r\n \"context\"\ : {},\r\n \"issues\": [],\r\n \"resourceId\": \"\"\r\n \ \ }\r\n ],\r\n \"previousHopIds\": [],\r\n \"previousLinks\"\ @@ -2052,11 +2056,11 @@ interactions: \ \"type\": \"UserDefinedRoute\",\r\n \"context\": [\r\n \ \ {\r\n \"key\": \"RouteType\",\r\n \"value\"\ : \"Default\"\r\n }\r\n ]\r\n }\r\n ]\r\n\ - \ },\r\n {\r\n \"type\": \"Destination\",\r\n \"id\": \"0861cd92-a6cc-4156-85fc-53bc29c03158\"\ + \ },\r\n {\r\n \"type\": \"Destination\",\r\n \"id\": \"9f755163-8bca-4a77-89a8-a3b4e0c2943d\"\ ,\r\n \"address\": \"192.168.100.4\",\r\n \"nextHopIds\": [],\r\n\ - \ \"links\": [],\r\n \"previousHopIds\": [\r\n \"e63687ea-5937-4d62-bc76-14b142dc2a37\"\ + \ \"links\": [],\r\n \"previousHopIds\": [\r\n \"9187d940-3ac3-4f4c-966e-b0008cdcf911\"\ \r\n ],\r\n \"previousLinks\": [\r\n {\r\n \"nextHopId\"\ - : \"e63687ea-5937-4d62-bc76-14b142dc2a37\",\r\n \"linkType\": \"\ + : \"9187d940-3ac3-4f4c-966e-b0008cdcf911\",\r\n \"linkType\": \"\ VirtualNetwork\",\r\n \"properties\": {},\r\n \"context\"\ : {},\r\n \"issues\": [],\r\n \"resourceId\": \"\"\r\n \ \ }\r\n ],\r\n \"issues\": []\r\n }\r\n ],\r\n \"connectionStatus\"\ @@ -2069,11 +2073,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:38 GMT + - Tue, 26 Jan 2021 10:21:09 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0309bea8-1ba3-4010-8400-bff40537f9b9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/74c8d25a-c9f5-431f-af15-6db31cd27bf0?api-version=2020-08-01 pragma: - no-cache server: @@ -2088,7 +2092,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9a3a5162-8e85-4c76-b773-b6f8240e559a + - ef1d9181-8af5-4036-a6be-df507a9bfc31 status: code: 200 message: OK @@ -2106,13 +2110,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6/topology?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6/topology?api-version=2020-08-01 response: body: - string: "{\r\n \"id\": \"121cbb4f-89ca-4f59-a265-60e343ead873\",\r\n \"createdDateTime\"\ - : \"2020-11-30T08:30:39.77168Z\",\r\n \"lastModified\": \"2020-11-30T08:25:36.2860625Z\"\ + string: "{\r\n \"id\": \"e7e07fd6-2737-4036-a39a-50ea48e54e50\",\r\n \"createdDateTime\"\ + : \"2021-01-26T10:21:10.7953801Z\",\r\n \"lastModified\": \"2021-01-26T10:16:23.8576548Z\"\ ,\r\n \"resources\": [\r\n {\r\n \"name\": \"virtualmachine121614c6\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine121614c6\"\ ,\r\n \"location\": \"eastus\",\r\n \"associations\": [\r\n \ @@ -2140,19 +2144,19 @@ interactions: \ \"properties\": {}\r\n }\r\n ]\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/343f446e-46c9-479f-934e-36cf0107bbf7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/50a708b6-97d0-4878-89a6-75f21e4093d7?api-version=2020-08-01 cache-control: - no-cache content-length: - - '3068' + - '3070' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:39 GMT + - Tue, 26 Jan 2021 10:21:10 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/343f446e-46c9-479f-934e-36cf0107bbf7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/50a708b6-97d0-4878-89a6-75f21e4093d7?api-version=2020-08-01 pragma: - no-cache server: @@ -2167,7 +2171,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 687b2fcb-de04-40f9-bc79-9547a075728b + - 670a9577-af9d-463c-a535-5eb9db504e70 status: code: 200 message: OK @@ -2185,13 +2189,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcher121614c6\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6\"\ - ,\r\n \"etag\": \"W/\\\"fc0d9dc9-3d40-4e27-9a71-14379dd719ea\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"c9255217-2303-4c3c-8aea-f451951e0210\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"tags\": {\r\n \"tag1\": \"value1\",\r\n \"tag2\": \"value2\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ @@ -2206,7 +2210,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:44 GMT + - Tue, 26 Jan 2021 10:21:15 GMT expires: - '-1' pragma: @@ -2223,9 +2227,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c289c3e2-0133-4f7f-836a-bc592aa2a92d + - 7131ac69-8ba3-4c2c-8516-e44ca349acf9 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1196' status: code: 200 message: OK @@ -2241,9 +2245,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher121614c6?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher121614c6?api-version=2020-08-01 response: body: string: '' @@ -2251,17 +2255,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d48bbb7d-6dcd-44fd-87c7-131703ea6646?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/47cf3857-538d-4ddf-aa71-f3c00e9650bc?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:30:44 GMT + - Tue, 26 Jan 2021 10:21:17 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/d48bbb7d-6dcd-44fd-87c7-131703ea6646?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/47cf3857-538d-4ddf-aa71-f3c00e9650bc?api-version=2020-08-01 pragma: - no-cache server: @@ -2272,7 +2276,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c5c0701e-cd56-4aa6-a7f0-90b8d2d22114 + - 5df9cfb0-cf1f-4aad-bcd2-2d5458525ff3 x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -2288,9 +2292,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d48bbb7d-6dcd-44fd-87c7-131703ea6646?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/47cf3857-538d-4ddf-aa71-f3c00e9650bc?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2302,7 +2306,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:30:55 GMT + - Tue, 26 Jan 2021 10:21:27 GMT expires: - '-1' pragma: @@ -2319,7 +2323,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 73220179-d9ce-44ee-9102-12f38cdaedea + - 06e6fc9d-ebe8-4be9-8534-0dea48a4b8b1 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_flow_log.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_flow_log.yaml index 007e47f0d317..4e6ee5f3533f 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_flow_log.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_flow_log.yaml @@ -14,16 +14,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachinedf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualmachinedf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e\"\ - ,\r\n \"etag\": \"W/\\\"53145c38-76f4-4e05-8ddd-b7ea28ec0575\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"83eecd38-9c8d-49b6-b8af-4b3864f7711a\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"87ee2950-a9c3-46ae-a14c-432362e873c9\",\r\n \"\ + \ \"resourceGuid\": \"b3a2dd4d-d5e4-45af-b432-e996a5616983\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -32,7 +32,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d0910d36-287c-44b9-8647-23f3efbf01c8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c9041ef0-83a8-49c4-9691-9c861ea04a02?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -40,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:17 GMT + - Tue, 26 Jan 2021 10:21:47 GMT expires: - '-1' pragma: @@ -53,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ff3861e1-f8b7-417e-9c72-4efee4b3c58a + - 5be7fe99-0c98-40f1-9e37-10c679902b83 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1188' status: code: 201 message: Created @@ -69,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d0910d36-287c-44b9-8647-23f3efbf01c8?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/c9041ef0-83a8-49c4-9691-9c861ea04a02?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -83,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:21 GMT + - Tue, 26 Jan 2021 10:21:50 GMT expires: - '-1' pragma: @@ -100,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 25be0f4a-62cf-4321-b8e8-b841b3784079 + - 85991856-a996-4b14-be06-160b10f70ac6 status: code: 200 message: OK @@ -114,16 +114,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachinedf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualmachinedf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e\"\ - ,\r\n \"etag\": \"W/\\\"5dab8f48-137e-4f57-97a7-c045fdd50c51\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"96337757-37e3-4038-abf2-935c7c2b42e7\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"87ee2950-a9c3-46ae-a14c-432362e873c9\",\r\n \"\ + \ \"resourceGuid\": \"b3a2dd4d-d5e4-45af-b432-e996a5616983\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -136,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:21 GMT + - Tue, 26 Jan 2021 10:21:51 GMT etag: - - W/"5dab8f48-137e-4f57-97a7-c045fdd50c51" + - W/"96337757-37e3-4038-abf2-935c7c2b42e7" expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0a3c80a3-d413-4b57-afd7-6534ec4b19a0 + - 9e0c241b-c950-4564-a3b3-15bfc0f8b274 status: code: 200 message: OK @@ -173,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"2baa9066-93fd-42b0-a928-d5341711dca8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"ee78e61f-6383-4688-bd7c-f434a49e8903\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1b39db59-3031-45f2-a596-85a950e90e76?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/05771c27-5cf4-451e-ac50-36e426216098?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -194,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:22 GMT + - Tue, 26 Jan 2021 10:21:51 GMT expires: - '-1' pragma: @@ -207,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b802d031-e9cd-49fa-92d1-bbe7444deef1 + - 6a4baca1-5c78-412b-9b3d-58abd6109d05 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1187' status: code: 201 message: Created @@ -223,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/1b39db59-3031-45f2-a596-85a950e90e76?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/05771c27-5cf4-451e-ac50-36e426216098?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -237,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:26 GMT + - Tue, 26 Jan 2021 10:21:54 GMT expires: - '-1' pragma: @@ -254,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 08478cb7-fab7-4ba1-8137-965897044490 + - 51c8bff5-bb12-49b9-a30c-747bc0ff8db6 status: code: 200 message: OK @@ -268,13 +268,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachinedf79187e/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"93536adb-ff2a-44a7-ba6b-9de8674b3d7d\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"55c61277-1d9a-489b-a1f4-f30475aaf699\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -287,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:26 GMT + - Tue, 26 Jan 2021 10:21:55 GMT etag: - - W/"93536adb-ff2a-44a7-ba6b-9de8674b3d7d" + - W/"55c61277-1d9a-489b-a1f4-f30475aaf699" expires: - '-1' pragma: @@ -306,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a0b6c73c-e445-4072-9ec7-53c480b10b84 + - 2865a333-fec4-4290-843e-6212c0c5f0a1 status: code: 200 message: OK @@ -325,15 +325,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipaddressdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"226569eb-241b-4c16-8776-e06a5d364fe8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1f2fb345-03dc-4e08-a4ca-7a35752c22f7\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Updating\",\r\n \"resourceGuid\": \"1c83d8d2-4f54-433a-8e01-f770783898c3\"\ + : \"Updating\",\r\n \"resourceGuid\": \"d82c1a1f-c486-41ef-b230-d2370ac14e3b\"\ ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ : \"Static\",\r\n \"idleTimeoutInMinutes\": 10,\r\n \"ipTags\": []\r\ \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ @@ -343,7 +343,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/49f8d64e-e980-4552-8960-b7d06b88c9bc?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4f2257a7-6ce7-4f3f-a2d1-60ffd7ea8202?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -351,7 +351,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:30 GMT + - Tue, 26 Jan 2021 10:21:59 GMT expires: - '-1' pragma: @@ -364,9 +364,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 52cac016-166e-4235-a905-864f5b4bb10c + - 9c74fbc5-540e-42ce-bf9a-b6ac2f42de45 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1186' status: code: 201 message: Created @@ -380,9 +380,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/49f8d64e-e980-4552-8960-b7d06b88c9bc?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/4f2257a7-6ce7-4f3f-a2d1-60ffd7ea8202?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -394,7 +394,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:31 GMT + - Tue, 26 Jan 2021 10:22:00 GMT expires: - '-1' pragma: @@ -411,7 +411,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ad7ea675-86be-4821-90dc-5bd331984286 + - fd9a87c5-1ca3-44e8-b844-ce1dc22aa087 status: code: 200 message: OK @@ -425,16 +425,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddressdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipaddressdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddressdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"772215b2-4250-4582-8fe8-c6aee323bb85\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"275ddfad-37bf-444c-ac87-90c0ce6a0a0d\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"1c83d8d2-4f54-433a-8e01-f770783898c3\"\ - ,\r\n \"ipAddress\": \"52.149.201.87\",\r\n \"publicIPAddressVersion\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"d82c1a1f-c486-41ef-b230-d2370ac14e3b\"\ + ,\r\n \"ipAddress\": \"52.152.139.209\",\r\n \"publicIPAddressVersion\"\ : \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\"\ : 10,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\"\ ,\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ @@ -443,13 +443,13 @@ interactions: cache-control: - no-cache content-length: - - '758' + - '759' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:31 GMT + - Tue, 26 Jan 2021 10:22:01 GMT etag: - - W/"772215b2-4250-4582-8fe8-c6aee323bb85" + - W/"275ddfad-37bf-444c-ac87-90c0ce6a0a0d" expires: - '-1' pragma: @@ -466,7 +466,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d12653fd-9fed-44e0-a3a9-a357592f1a99 + - f18ea759-a716-4bb5-803a-e27e34de6928 status: code: 200 message: OK @@ -490,21 +490,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewaydf79187e\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e\"\ - ,\r\n \"etag\": \"W/\\\"e0c6aa67-3b68-458f-a0e6-a214338e5da1\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"5ae4d13c-3d18-48d3-8cd2-90bdd11a935a\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"1d195c80-300c-47b6-8253-8bdab7eb0dd9\",\r\n \ + ,\r\n \"resourceGuid\": \"aeaecafe-d877-4fb6-9f3f-baa4749b8051\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfigdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e/ipConfigurations/ipconfigdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"e0c6aa67-3b68-458f-a0e6-a214338e5da1\\\"\"\ + ,\r\n \"etag\": \"W/\\\"5ae4d13c-3d18-48d3-8cd2-90bdd11a935a\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -530,7 +530,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -538,7 +538,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:36 GMT + - Tue, 26 Jan 2021 10:22:05 GMT expires: - '-1' pragma: @@ -551,9 +551,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 37aae9ca-3b4a-49e3-a831-90f3dcb121af + - 27bb9a1c-47ab-4d9b-96fc-88d968c1421b x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1185' status: code: 201 message: Created @@ -567,9 +567,54 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 + response: + body: + string: "{\r\n \"status\": \"InProgress\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '30' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:22:15 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-arm-service-request-id: + - 86abf53c-072c-460d-9be9-c81720b6a738 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -581,7 +626,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:46 GMT + - Tue, 26 Jan 2021 10:22:26 GMT expires: - '-1' pragma: @@ -598,7 +643,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3be25420-0d57-42e7-8a60-0c60ad515950 + - 6b32cfb8-38f5-4fc7-9822-d421e9647802 status: code: 200 message: OK @@ -612,9 +657,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -626,7 +671,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:31:56 GMT + - Tue, 26 Jan 2021 10:22:46 GMT expires: - '-1' pragma: @@ -643,7 +688,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 62084cff-9d3b-4749-be05-053328c2d1ae + - f6d69450-f458-4d80-96f3-4ed17a406b38 status: code: 200 message: OK @@ -657,9 +702,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -671,7 +716,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:32:17 GMT + - Tue, 26 Jan 2021 10:23:07 GMT expires: - '-1' pragma: @@ -688,7 +733,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ff47e472-726c-44e1-8367-3f44e7fac806 + - 964b54ea-107a-4445-a059-29acd1dbb19b status: code: 200 message: OK @@ -702,9 +747,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -716,7 +761,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:32:39 GMT + - Tue, 26 Jan 2021 10:23:47 GMT expires: - '-1' pragma: @@ -733,7 +778,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 811f45b6-1cce-449a-8c81-260dcebc778e + - a53d53c3-9d2e-4f6b-8c32-166cb63bb495 status: code: 200 message: OK @@ -747,9 +792,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -761,7 +806,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:33:20 GMT + - Tue, 26 Jan 2021 10:24:27 GMT expires: - '-1' pragma: @@ -778,7 +823,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a083be20-1b9a-4421-88a5-5190746b9709 + - d7e6cd8f-1198-4991-b458-2f1780df8b82 status: code: 200 message: OK @@ -792,9 +837,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -806,7 +851,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:34:00 GMT + - Tue, 26 Jan 2021 10:25:48 GMT expires: - '-1' pragma: @@ -823,7 +868,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 82481fe4-0cb7-4c8b-ad8b-a019bcc9aeee + - a1f151fc-6b80-460a-a4d1-aa764786db28 status: code: 200 message: OK @@ -837,9 +882,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -851,7 +896,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:35:20 GMT + - Tue, 26 Jan 2021 10:28:29 GMT expires: - '-1' pragma: @@ -868,7 +913,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a0e140fe-bc44-4def-acff-292b05158e20 + - eb02c166-a306-4c0e-a68e-f6578395bb02 status: code: 200 message: OK @@ -882,9 +927,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -896,7 +941,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:38:02 GMT + - Tue, 26 Jan 2021 10:30:09 GMT expires: - '-1' pragma: @@ -913,7 +958,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - c38ab617-d51a-4365-91bd-d3ef3a048d1b + - e877bfa3-fb4c-4579-ba61-49c1b57948d8 status: code: 200 message: OK @@ -927,9 +972,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -941,7 +986,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:39:43 GMT + - Tue, 26 Jan 2021 10:31:50 GMT expires: - '-1' pragma: @@ -958,7 +1003,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 88ab0032-7231-4d00-98e7-c26c46845b01 + - a565d8e5-241d-4817-b438-81028b0db587 status: code: 200 message: OK @@ -972,9 +1017,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -986,7 +1031,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:41:24 GMT + - Tue, 26 Jan 2021 10:33:30 GMT expires: - '-1' pragma: @@ -1003,7 +1048,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6b1fcc63-c508-4526-bdac-3e1de9061645 + - fd56a942-814a-4b7f-a4e2-1ae6962f6f2c status: code: 200 message: OK @@ -1017,9 +1062,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1031,7 +1076,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:43:05 GMT + - Tue, 26 Jan 2021 10:35:11 GMT expires: - '-1' pragma: @@ -1048,7 +1093,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f9a2284f-1b0b-4682-b367-4744685e2624 + - caf161e9-ee07-48c4-8de0-e0325cc0944a status: code: 200 message: OK @@ -1062,9 +1107,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1076,7 +1121,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:44:46 GMT + - Tue, 26 Jan 2021 10:36:51 GMT expires: - '-1' pragma: @@ -1093,7 +1138,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 59be4f5a-d462-4b77-9f1a-1362480fbd9c + - 0d07ad55-ff11-4cb7-89fd-e42e15843ce3 status: code: 200 message: OK @@ -1107,9 +1152,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1121,7 +1166,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:46:26 GMT + - Tue, 26 Jan 2021 10:38:31 GMT expires: - '-1' pragma: @@ -1138,7 +1183,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 331aae29-51ea-4d29-bee9-ac7c625ec471 + - 92a29f8c-2318-47c6-969d-3cc35a92e84e status: code: 200 message: OK @@ -1152,9 +1197,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1166,7 +1211,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:48:08 GMT + - Tue, 26 Jan 2021 10:40:12 GMT expires: - '-1' pragma: @@ -1183,7 +1228,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d2c054a9-4e9f-4678-b47f-46b4eb2b4a14 + - 2b65705a-0113-4b14-a753-b33a1ca5315a status: code: 200 message: OK @@ -1197,9 +1242,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1211,7 +1256,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:49:49 GMT + - Tue, 26 Jan 2021 10:41:52 GMT expires: - '-1' pragma: @@ -1228,7 +1273,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b74252ea-e5cd-4b01-bb12-1ea157c89ff6 + - 3efdc13d-27f7-4640-a6bb-41d746a6c6a1 status: code: 200 message: OK @@ -1242,9 +1287,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1256,7 +1301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:51:30 GMT + - Tue, 26 Jan 2021 10:43:33 GMT expires: - '-1' pragma: @@ -1273,7 +1318,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b38630a3-2f59-4415-a359-d2f0f7862439 + - b75cb1a9-4867-475a-b732-7452e5076c26 status: code: 200 message: OK @@ -1287,9 +1332,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/74bf8649-e2cf-4e47-b0af-f7aafcea1685?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1c945f95-f3be-4cde-8b3c-0ff3e4b68be3?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1301,7 +1346,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:12 GMT + - Tue, 26 Jan 2021 10:45:14 GMT expires: - '-1' pragma: @@ -1318,7 +1363,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 702b0504-5ca6-4160-b0d3-e91cb9535827 + - 470527fd-1211-469e-bcac-b59d22a29a67 status: code: 200 message: OK @@ -1332,21 +1377,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgatewaydf79187e\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e\"\ - ,\r\n \"etag\": \"W/\\\"fd6a5d3a-0a72-4517-a80c-558754e302c8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"a6fc1043-deb2-42be-be5e-61e7699ae2ba\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"1d195c80-300c-47b6-8253-8bdab7eb0dd9\",\r\n \ + ,\r\n \"resourceGuid\": \"aeaecafe-d877-4fb6-9f3f-baa4749b8051\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfigdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e/ipConfigurations/ipconfigdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"fd6a5d3a-0a72-4517-a80c-558754e302c8\\\"\"\ + ,\r\n \"etag\": \"W/\\\"a6fc1043-deb2-42be-be5e-61e7699ae2ba\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -1361,7 +1406,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgatewaydf79187e/ipConfigurations/ipconfigdf79187e\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"52.149.201.87\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"52.152.139.209\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -1369,11 +1414,11 @@ interactions: cache-control: - no-cache content-length: - - '2875' + - '2876' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:12 GMT + - Tue, 26 Jan 2021 10:45:15 GMT expires: - '-1' pragma: @@ -1390,7 +1435,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1978fdbf-5636-46e4-98ba-10677eec2950 + - 534c6687-0579-4fdd-b63b-fd0ff12df898 status: code: 200 message: OK @@ -1409,11 +1454,11 @@ interactions: - 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e?api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e?api-version=2019-06-01 response: body: string: '' @@ -1425,11 +1470,11 @@ interactions: content-type: - text/plain; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:20 GMT + - Tue, 26 Jan 2021 10:45:21 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/83098d90-6721-43d7-a84a-87e602d0d886?monitor=true&api-version=2019-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/49e02f7f-6b1e-4aa6-b84a-47c9fc53f2b5?monitor=true&api-version=2019-06-01 pragma: - no-cache server: @@ -1439,7 +1484,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1197' status: code: 202 message: Accepted @@ -1454,21 +1499,21 @@ interactions: - keep-alive 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/83098d90-6721-43d7-a84a-87e602d0d886?monitor=true&api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/49e02f7f-6b1e-4aa6-b84a-47c9fc53f2b5?monitor=true&api-version=2019-06-01 response: body: - string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e","name":"storagenamedf79187e","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"enabled":true,"lastEnabledTime":"2020-11-30T08:53:20.1267896Z"},"blob":{"enabled":true,"lastEnabledTime":"2020-11-30T08:53:20.1267896Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2020-11-30T08:53:19.8768107Z","primaryEndpoints":{"blob":"https://storagenamedf79187e.blob.core.windows.net/","queue":"https://storagenamedf79187e.queue.core.windows.net/","table":"https://storagenamedf79187e.table.core.windows.net/","file":"https://storagenamedf79187e.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' + string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e","name":"storagenamedf79187e","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"privateEndpointConnections":[],"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:45:21.7648040Z"},"blob":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T10:45:21.7648040Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2021-01-26T10:45:21.6866954Z","primaryEndpoints":{"blob":"https://storagenamedf79187e.blob.core.windows.net/","queue":"https://storagenamedf79187e.queue.core.windows.net/","table":"https://storagenamedf79187e.table.core.windows.net/","file":"https://storagenamedf79187e.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' headers: cache-control: - no-cache content-length: - - '1138' + - '1210' content-type: - application/json date: - - Mon, 30 Nov 2020 08:53:38 GMT + - Tue, 26 Jan 2021 10:45:39 GMT expires: - '-1' pragma: @@ -1500,13 +1545,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcherdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"6b0ba1e0-db6d-4949-86b9-73b3131ed708\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"035730a2-39c3-4946-a3dc-e1fdf35e5fc0\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1514,7 +1559,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/21fd4a80-f44b-429d-b7dd-3915c641880d?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a7fe3456-04e0-4e99-a5df-43d74cd2ccf7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1522,7 +1567,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:45 GMT + - Tue, 26 Jan 2021 10:45:46 GMT expires: - '-1' pragma: @@ -1535,7 +1580,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 38a0bc0b-20d5-40d4-9bcd-852a20831829 + - 0ae46de6-5e64-4c4b-a34d-2c15d11d9f65 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -1555,20 +1600,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroupdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroupdf79187e\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"9ca383d9-52b1-40ad-8ea0-1433f9b56634\",\r\n \ + ,\r\n \"resourceGuid\": \"17a53ade-1298-44f1-9ab3-2ba548333bf2\",\r\n \ \ \"securityRules\": [],\r\n \"defaultSecurityRules\": [\r\n {\r\ \n \"name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -1581,7 +1626,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -1594,7 +1639,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -1606,7 +1651,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -1619,7 +1664,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -1632,7 +1677,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"59a51178-dc74-4630-a459-5e6845ab6c78\\\"\"\ + ,\r\n \"etag\": \"W/\\\"e464c3b1-afde-495b-bfe7-24f1fbd5ecf9\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -1647,7 +1692,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d6451460-b9cf-432a-9c82-ae83f548fb05?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca3b7bda-7d06-4534-91d2-0ababaa7a3db?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1655,7 +1700,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:48 GMT + - Tue, 26 Jan 2021 10:45:52 GMT expires: - '-1' pragma: @@ -1668,7 +1713,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 062c6de1-b0d7-4b03-890f-df72b5d5685e + - fc2e1f23-07ba-4e82-93c0-6b8e493ef2ad x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -1684,9 +1729,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/d6451460-b9cf-432a-9c82-ae83f548fb05?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca3b7bda-7d06-4534-91d2-0ababaa7a3db?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1698,7 +1743,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:52 GMT + - Tue, 26 Jan 2021 10:45:55 GMT expires: - '-1' pragma: @@ -1715,7 +1760,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 366292b0-18b1-4223-b716-8f888425064f + - b4c9f039-3d4b-410f-a73c-0074357f3ecf status: code: 200 message: OK @@ -1729,20 +1774,20 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkSecurityGroups/networksecuritygroupdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networksecuritygroupdf79187e\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkSecurityGroups\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"9ca383d9-52b1-40ad-8ea0-1433f9b56634\",\r\n \ + ,\r\n \"resourceGuid\": \"17a53ade-1298-44f1-9ab3-2ba548333bf2\",\r\n \ \ \"securityRules\": [],\r\n \"defaultSecurityRules\": [\r\n {\r\ \n \"name\": \"AllowVnetInBound\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowVnetInBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from all VMs in VNET\"\ @@ -1755,7 +1800,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowAzureLoadBalancerInBound\",\r\ \n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowAzureLoadBalancerInBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow inbound traffic from azure load balancer\"\ @@ -1768,7 +1813,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllInBound\",\r\n \"id\"\ : \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/DenyAllInBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all inbound traffic\",\r\n \ @@ -1780,7 +1825,7 @@ interactions: : [],\r\n \"sourceAddressPrefixes\": [],\r\n \"destinationAddressPrefixes\"\ : []\r\n }\r\n },\r\n {\r\n \"name\": \"AllowVnetOutBound\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowVnetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to all\ @@ -1793,7 +1838,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"AllowInternetOutBound\",\r\n \ \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/AllowInternetOutBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Allow outbound traffic from all VMs to Internet\"\ @@ -1806,7 +1851,7 @@ interactions: : [],\r\n \"destinationAddressPrefixes\": []\r\n }\r\n \ \ },\r\n {\r\n \"name\": \"DenyAllOutBound\",\r\n \"\ id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e/defaultSecurityRules/DenyAllOutBound\"\ - ,\r\n \"etag\": \"W/\\\"ac5af298-881f-4585-8b9f-75269b6966f5\\\"\"\ + ,\r\n \"etag\": \"W/\\\"02bd6a85-9ad3-44d0-855f-f5635faea811\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkSecurityGroups/defaultSecurityRules\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"description\": \"Deny all outbound traffic\",\r\n \ @@ -1825,9 +1870,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:52 GMT + - Tue, 26 Jan 2021 10:45:55 GMT etag: - - W/"ac5af298-881f-4585-8b9f-75269b6966f5" + - W/"02bd6a85-9ad3-44d0-855f-f5635faea811" expires: - '-1' pragma: @@ -1844,7 +1889,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d3d2b57e-0571-4cc3-976b-01749274d2fe + - 33845c63-2467-424b-b9d7-a225a5fdc2c6 status: code: 200 message: OK @@ -1864,16 +1909,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"floglogdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"12916f0e-2b79-4409-bd56-2465f0ab0728\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"d9ee7e99-a047-4ab3-bb16-65fc6a9320d8\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ targetResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ - ,\r\n \"targetResourceGuid\": \"9ca383d9-52b1-40ad-8ea0-1433f9b56634\"\ + ,\r\n \"targetResourceGuid\": \"17a53ade-1298-44f1-9ab3-2ba548333bf2\"\ ,\r\n \"storageId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e\"\ ,\r\n \"enabled\": true,\r\n \"flowAnalyticsConfiguration\": {},\r\n\ \ \"retentionPolicy\": {\r\n \"days\": 0,\r\n \"enabled\": false\r\ @@ -1884,7 +1929,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e8c7ea24-5732-4ccc-95e6-9be29ee76af8?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b7e9ab28-ca17-4791-b1fb-bc6d7c9eed62?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1892,7 +1937,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:53:56 GMT + - Tue, 26 Jan 2021 10:45:59 GMT expires: - '-1' pragma: @@ -1905,7 +1950,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 1c40e0b1-fb7e-497d-826a-73d00fd83313 + - c83dc9b2-c935-4c64-bd26-c90a9716f50e x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -1921,9 +1966,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/e8c7ea24-5732-4ccc-95e6-9be29ee76af8?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b7e9ab28-ca17-4791-b1fb-bc6d7c9eed62?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1935,7 +1980,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:06 GMT + - Tue, 26 Jan 2021 10:46:10 GMT expires: - '-1' pragma: @@ -1952,7 +1997,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bfb6ca56-16e1-4d77-bbc8-c3cb3578395b + - 530f28e4-c641-46c4-8e60-a4ad3eb0e5a4 status: code: 200 message: OK @@ -1966,16 +2011,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"floglogdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"10172749-89c3-4065-8641-a6be69a6953e\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7e602ba7-c047-417e-b7a4-ac1293e4dc3a\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ targetResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ - ,\r\n \"targetResourceGuid\": \"9ca383d9-52b1-40ad-8ea0-1433f9b56634\"\ + ,\r\n \"targetResourceGuid\": \"17a53ade-1298-44f1-9ab3-2ba548333bf2\"\ ,\r\n \"storageId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e\"\ ,\r\n \"enabled\": true,\r\n \"flowAnalyticsConfiguration\": {},\r\n\ \ \"retentionPolicy\": {\r\n \"days\": 0,\r\n \"enabled\": false\r\ @@ -1990,7 +2035,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:06 GMT + - Tue, 26 Jan 2021 10:46:10 GMT expires: - '-1' pragma: @@ -2007,7 +2052,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 168e1cfe-a88a-48be-a7f6-00401f5a1383 + - 1836eb00-a528-4d6e-b0eb-f1419577a47e status: code: 200 message: OK @@ -2021,16 +2066,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"floglogdf79187e\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e\"\ - ,\r\n \"etag\": \"W/\\\"10172749-89c3-4065-8641-a6be69a6953e\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"7e602ba7-c047-417e-b7a4-ac1293e4dc3a\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ targetResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ - ,\r\n \"targetResourceGuid\": \"9ca383d9-52b1-40ad-8ea0-1433f9b56634\"\ + ,\r\n \"targetResourceGuid\": \"17a53ade-1298-44f1-9ab3-2ba548333bf2\"\ ,\r\n \"storageId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagenamedf79187e\"\ ,\r\n \"enabled\": true,\r\n \"flowAnalyticsConfiguration\": {},\r\n\ \ \"retentionPolicy\": {\r\n \"days\": 0,\r\n \"enabled\": false\r\ @@ -2045,7 +2090,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:07 GMT + - Tue, 26 Jan 2021 10:46:10 GMT expires: - '-1' pragma: @@ -2062,7 +2107,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 072f9d42-0d91-453a-a3fd-17d2fdd87eed + - 853e8fb3-4263-46bb-aa54-d0f330473e51 status: code: 200 message: OK @@ -2080,9 +2125,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/queryFlowLogStatus?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/queryFlowLogStatus?api-version=2020-08-01 response: body: string: "{\r\n \"targetResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ @@ -2099,7 +2144,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:07 GMT + - Tue, 26 Jan 2021 10:46:11 GMT expires: - '-1' pragma: @@ -2116,7 +2161,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 8e059ed2-69a5-49e3-95d2-bcf3ed6f2cbe + - 66526316-62a6-4b97-8666-0a320f4ac7de status: code: 200 message: OK @@ -2136,9 +2181,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/configureFlowLog?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/configureFlowLog?api-version=2020-08-01 response: body: string: 'null' @@ -2150,11 +2195,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:08 GMT + - Tue, 26 Jan 2021 10:46:12 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/e34de830-2d04-41c5-a911-5d37f7b5911f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/553c6263-aea1-4a80-a722-b23955a28fa7?api-version=2020-08-01 pragma: - no-cache server: @@ -2165,9 +2210,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0fc3389a-db0e-4abb-84ff-a1b528f1a452 + - f74027c1-3842-40eb-abe1-b38f2355ee28 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 202 message: Accepted @@ -2181,9 +2226,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/e34de830-2d04-41c5-a911-5d37f7b5911f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/553c6263-aea1-4a80-a722-b23955a28fa7?api-version=2020-08-01 response: body: string: "{\r\n \"targetResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkSecurityGroups/networksecuritygroupdf79187e\"\ @@ -2192,7 +2237,7 @@ interactions: ,\r\n \"version\": 1\r\n }\r\n }\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/e34de830-2d04-41c5-a911-5d37f7b5911f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/553c6263-aea1-4a80-a722-b23955a28fa7?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -2200,11 +2245,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:18 GMT + - Tue, 26 Jan 2021 10:46:22 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/e34de830-2d04-41c5-a911-5d37f7b5911f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/553c6263-aea1-4a80-a722-b23955a28fa7?api-version=2020-08-01 pragma: - no-cache server: @@ -2219,7 +2264,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0fc3389a-db0e-4abb-84ff-a1b528f1a452 + - f74027c1-3842-40eb-abe1-b38f2355ee28 status: code: 200 message: OK @@ -2235,9 +2280,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e/flowLogs/floglogdf79187e?api-version=2020-08-01 response: body: string: '' @@ -2245,17 +2290,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/23c2d910-546a-4e85-8fe4-e880c1170c55?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1378a4ab-3280-4ae4-8e03-dca0a492acb2?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:54:19 GMT + - Tue, 26 Jan 2021 10:46:23 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/23c2d910-546a-4e85-8fe4-e880c1170c55?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/1378a4ab-3280-4ae4-8e03-dca0a492acb2?api-version=2020-08-01 pragma: - no-cache server: @@ -2266,7 +2311,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 03bc29f9-8fe6-4a50-ad54-b0372bdf86d3 + - 84e649b1-8a2a-4d15-b79d-1c464e0bbabb x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -2282,9 +2327,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/23c2d910-546a-4e85-8fe4-e880c1170c55?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1378a4ab-3280-4ae4-8e03-dca0a492acb2?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2296,7 +2341,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:29 GMT + - Tue, 26 Jan 2021 10:46:33 GMT expires: - '-1' pragma: @@ -2313,7 +2358,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 01d8322d-6aab-437f-85ac-a2254d0001ca + - 3968844a-b7b6-433f-ac57-06fc37e5c5a0 status: code: 200 message: OK @@ -2329,9 +2374,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherdf79187e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherdf79187e?api-version=2020-08-01 response: body: string: '' @@ -2339,17 +2384,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5f0f4bc0-84b5-4ead-b88f-3e97a8e8a0e4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0d744420-1ea2-4a0f-9883-88f6f26a03a8?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 08:54:30 GMT + - Tue, 26 Jan 2021 10:46:34 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/5f0f4bc0-84b5-4ead-b88f-3e97a8e8a0e4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/0d744420-1ea2-4a0f-9883-88f6f26a03a8?api-version=2020-08-01 pragma: - no-cache server: @@ -2360,7 +2405,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ec90bcac-51c7-4d6e-955e-e74299120b20 + - 47ccf25d-3528-41be-aa72-556eacdb6bed x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -2376,9 +2421,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/5f0f4bc0-84b5-4ead-b88f-3e97a8e8a0e4?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0d744420-1ea2-4a0f-9883-88f6f26a03a8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2390,7 +2435,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:54:40 GMT + - Tue, 26 Jan 2021 10:46:45 GMT expires: - '-1' pragma: @@ -2407,7 +2452,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0918b3f9-c7bd-411b-88f7-2219987eaf7a + - e402fb91-db06-48c4-9381-605062c078b6 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_ip_flow.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_ip_flow.yaml deleted file mode 100644 index 5abc53fd82df..000000000000 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_ip_flow.yaml +++ /dev/null @@ -1,1383 +0,0 @@ -interactions: -- request: - body: '{"location": "eastus", "properties": {"addressSpace": {"addressPrefixes": - ["10.0.0.0/16"]}}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '92' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/virtualNetworks/virtualnetworkc6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualnetworkc6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815\"\ - ,\r\n \"etag\": \"W/\\\"aa444fff-a963-4ddb-8da6-2fe34406fe5e\\\"\",\r\n \ - \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"1307f699-f47e-44dd-87c8-564795f17f6f\",\r\n \"\ - addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ - \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ - : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ - : false\r\n }\r\n}" - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/748ba09b-5906-40e6-8789-aabcb6701e62?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '731' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:34 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 3a28ebbb-fe3f-47b2-9ee4-86e0748c2984 - x-ms-ratelimit-remaining-subscription-writes: - - '1199' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/748ba09b-5906-40e6-8789-aabcb6701e62?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '29' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:38 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - e782e51d-2e13-44e7-9817-a5370b0d241c - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/virtualNetworks/virtualnetworkc6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualnetworkc6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815\"\ - ,\r\n \"etag\": \"W/\\\"6e065591-a6f8-476a-970d-c59b15bc28dd\\\"\",\r\n \ - \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"1307f699-f47e-44dd-87c8-564795f17f6f\",\r\n \"\ - addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ - \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ - : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ - : false\r\n }\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '732' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:38 GMT - etag: - - W/"6e065591-a6f8-476a-970d-c59b15bc28dd" - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 9c677178-0fd6-4186-9e4d-9f1e3dfee716 - status: - code: 200 - message: OK -- request: - body: '{"properties": {"addressPrefix": "10.0.0.0/24"}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '48' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"subnetc6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815\"\ - ,\r\n \"etag\": \"W/\\\"799970c1-2991-4a81-abb2-354c2b76a336\\\"\",\r\n \ - \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ - addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ - : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ - \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" - headers: - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/acf9d630-302b-4c18-afd6-ee3a09f22326?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '616' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:39 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 9ab674e8-ecec-4fda-b2d8-a9976bdfee3f - x-ms-ratelimit-remaining-subscription-writes: - - '1198' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/acf9d630-302b-4c18-afd6-ee3a09f22326?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '29' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:42 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - c86cde83-c6b5-4f73-be6a-c92df93ba1ae - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"subnetc6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815\"\ - ,\r\n \"etag\": \"W/\\\"3d545245-1036-47ee-9efe-f5e21a50c567\\\"\",\r\n \ - \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ - : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ - \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '617' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:43 GMT - etag: - - W/"3d545245-1036-47ee-9efe-f5e21a50c567" - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 9b63c4cd-f3e4-44ea-9aaf-25aabcdbc587 - status: - code: 200 - message: OK -- request: - body: '{"location": "eastus", "properties": {"ipConfigurations": [{"name": "MyIpConfig", - "properties": {"subnet": {"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815"}}}]}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '354' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/networkInterfaces/interfacec6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"interfacec6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815\"\ - ,\r\n \"etag\": \"W/\\\"cab7125d-e148-4dab-be24-0abeed0f2c3c\\\"\",\r\n \ - \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"f4c5b743-f529-45a9-817f-d51fea53f85d\"\ - ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ - ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"cab7125d-e148-4dab-be24-0abeed0f2c3c\\\"\"\ - ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ - : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815\"\ - \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ - : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ - \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"th1aoe144toujb4ikzdzl2l5nh.bx.internal.cloudapp.net\"\ - \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ - : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ - \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ - \r\n}" - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/7968a159-60a1-4755-83ce-a7c252b67943?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '1861' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:49:48 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 6b490ead-81cd-41c5-858b-cb6a44f3321f - x-ms-ratelimit-remaining-subscription-writes: - - '1197' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/7968a159-60a1-4755-83ce-a7c252b67943?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"Succeeded\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '29' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:50:18 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 3988056c-6d32-4a29-a67d-c9e48d0c4879 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/networkInterfaces/interfacec6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"interfacec6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815\"\ - ,\r\n \"etag\": \"W/\\\"cab7125d-e148-4dab-be24-0abeed0f2c3c\\\"\",\r\n \ - \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"f4c5b743-f529-45a9-817f-d51fea53f85d\"\ - ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ - ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"cab7125d-e148-4dab-be24-0abeed0f2c3c\\\"\"\ - ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ - : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815\"\ - \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ - : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ - \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"th1aoe144toujb4ikzdzl2l5nh.bx.internal.cloudapp.net\"\ - \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ - : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ - \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '1861' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:50:19 GMT - etag: - - W/"cab7125d-e148-4dab-be24-0abeed0f2c3c" - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 5ef3521d-1597-45a9-962e-30a1d42a4979 - status: - code: 200 - message: OK -- request: - body: '{"location": "eastus", "properties": {"hardwareProfile": {"vmSize": "Standard_D2_v2"}, - "storageProfile": {"imageReference": {"publisher": "MicrosoftWindowsServer", - "offer": "WindowsServer", "sku": "2016-Datacenter", "version": "latest"}, "osDisk": - {"name": "myVMosdisk", "caching": "ReadWrite", "createOption": "FromImage", - "managedDisk": {"storageAccountType": "Standard_LRS"}}, "dataDisks": [{"lun": - 0, "createOption": "Empty", "diskSizeGB": 1023}, {"lun": 1, "createOption": - "Empty", "diskSizeGB": 1023}]}, "osProfile": {"computerName": "myVM", "adminUsername": - "testuser", "adminPassword": "Aa1!zyx_", "windowsConfiguration": {"enableAutomaticUpdates": - true}}, "networkProfile": {"networkInterfaces": [{"id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815", - "properties": {"primary": true}}]}}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '959' - 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-compute/10.0.0 Azure-SDK-For-Python - accept-language: - - en-US - method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815?api-version=2019-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualmachinec6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815\"\ - ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"c4f94603-b485-4d56-8ad1-d2840df17c16\"\ - ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ - \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ - \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ - WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ - \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ - \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ - ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ - \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ - \ \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\": [\r\n \ - \ {\r\n \"lun\": 0,\r\n \"createOption\": \"Empty\",\r\n\ - \ \"caching\": \"None\",\r\n \"managedDisk\": {\r\n \ - \ \"storageAccountType\": \"Standard_LRS\"\r\n },\r\n \ - \ \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n \ - \ },\r\n {\r\n \"lun\": 1,\r\n \"createOption\"\ - : \"Empty\",\r\n \"caching\": \"None\",\r\n \"managedDisk\"\ - : {\r\n \"storageAccountType\": \"Standard_LRS\"\r\n },\r\ - \n \"diskSizeGB\": 1023,\r\n \"toBeDetached\": false\r\n\ - \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ - : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ - : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ - : true\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ - : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ - networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815\"\ - ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ - \r\n }\r\n}" - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - cache-control: - - no-cache - content-length: - - '2234' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:50:27 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1199 - x-ms-ratelimit-remaining-subscription-writes: - - '1198' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:50:25.8489421+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"fd6f2c36-8b27-4190-bf9a-89e0e468b493\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:50:38 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14999,Microsoft.Compute/GetOperation30Min;29999 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:50:25.8489421+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"fd6f2c36-8b27-4190-bf9a-89e0e468b493\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:51:28 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14998,Microsoft.Compute/GetOperation30Min;29998 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:50:25.8489421+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"fd6f2c36-8b27-4190-bf9a-89e0e468b493\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:51:59 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14997,Microsoft.Compute/GetOperation30Min;29997 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:50:25.8489421+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"fd6f2c36-8b27-4190-bf9a-89e0e468b493\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:52:30 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14995,Microsoft.Compute/GetOperation30Min;29995 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/fd6f2c36-8b27-4190-bf9a-89e0e468b493?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:50:25.8489421+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:52:38.3644162+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"fd6f2c36-8b27-4190-bf9a-89e0e468b493\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '184' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:53:00 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29993 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815?api-version=2019-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualmachinec6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815\"\ - ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"c4f94603-b485-4d56-8ad1-d2840df17c16\"\ - ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ - \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ - \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ - WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ - \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ - \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ - ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ - \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ - \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ - \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ - : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachinec6c91815_disk2_9ad139c2c43d404f96c5bbba705639b2\"\ - ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ - ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec6c91815_disk2_9ad139c2c43d404f96c5bbba705639b2\"\ - \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ - : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ - name\": \"virtualmachinec6c91815_disk3_956388aec698475781968f4ca11426af\"\ - ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ - ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec6c91815_disk3_956388aec698475781968f4ca11426af\"\ - \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ - : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ - \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ - \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ - \n \"enableAutomaticUpdates\": true\r\n },\r\n \"secrets\"\ - : [],\r\n \"allowExtensionOperations\": true,\r\n \"requireGuestProvisionSignal\"\ - : true\r\n },\r\n \"networkProfile\": {\"networkInterfaces\":[{\"id\"\ - :\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815\"\ - ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ - \r\n }\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '3133' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:53:00 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3997,Microsoft.Compute/LowCostGet30Min;31992 - status: - code: 200 - message: OK -- request: - body: '{"location": "eastus", "properties": {"publisher": "Microsoft.Azure.NetworkWatcher", - "type": "NetworkWatcherAgentWindows", "typeHandlerVersion": "1.4", "autoUpgradeMinorVersion": - true}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '185' - 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-compute/10.0.0 Azure-SDK-For-Python - accept-language: - - en-US - method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815/extensions/virtualmachineextensionc6c91815?api-version=2019-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualmachineextensionc6c91815\",\r\n \"id\":\ - \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815/extensions/virtualmachineextensionc6c91815\"\ - ,\r\n \"type\": \"Microsoft.Compute/virtualMachines/extensions\",\r\n \"\ - location\": \"eastus\",\r\n \"properties\": {\r\n \"autoUpgradeMinorVersion\"\ - : true,\r\n \"provisioningState\": \"Creating\",\r\n \"publisher\":\ - \ \"Microsoft.Azure.NetworkWatcher\",\r\n \"type\": \"NetworkWatcherAgentWindows\"\ - ,\r\n \"typeHandlerVersion\": \"1.4\"\r\n }\r\n}" - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/ca808de1-a188-4c54-a363-f4b582ad1b0b?api-version=2019-07-01 - cache-control: - - no-cache - content-length: - - '627' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:53:08 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/UpdateVM3Min;239,Microsoft.Compute/UpdateVM30Min;1199 - x-ms-ratelimit-remaining-subscription-writes: - - '1197' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/ca808de1-a188-4c54-a363-f4b582ad1b0b?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:53:07.2394147+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"ca808de1-a188-4c54-a363-f4b582ad1b0b\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:53:39 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29992 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/ca808de1-a188-4c54-a363-f4b582ad1b0b?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:53:07.2394147+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"ca808de1-a188-4c54-a363-f4b582ad1b0b\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:54:10 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29991 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/ca808de1-a188-4c54-a363-f4b582ad1b0b?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:53:07.2394147+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"ca808de1-a188-4c54-a363-f4b582ad1b0b\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:54:40 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29990 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/ca808de1-a188-4c54-a363-f4b582ad1b0b?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:53:07.2394147+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:54:44.3486754+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"ca808de1-a188-4c54-a363-f4b582ad1b0b\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '184' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:55:10 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29988 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815/extensions/virtualmachineextensionc6c91815?api-version=2019-07-01 - response: - body: - string: "{\r\n \"name\": \"virtualmachineextensionc6c91815\",\r\n \"id\":\ - \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815/extensions/virtualmachineextensionc6c91815\"\ - ,\r\n \"type\": \"Microsoft.Compute/virtualMachines/extensions\",\r\n \"\ - location\": \"eastus\",\r\n \"properties\": {\r\n \"autoUpgradeMinorVersion\"\ - : true,\r\n \"provisioningState\": \"Succeeded\",\r\n \"publisher\"\ - : \"Microsoft.Azure.NetworkWatcher\",\r\n \"type\": \"NetworkWatcherAgentWindows\"\ - ,\r\n \"typeHandlerVersion\": \"1.4\"\r\n }\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '628' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:55:11 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3995,Microsoft.Compute/LowCostGet30Min;31991 - 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-network/17.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.Network/networkInterfaces/interfacec6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"interfacec6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815\"\ - ,\r\n \"etag\": \"W/\\\"0a3e30e9-c4be-46cf-8b21-3c793b3e7519\\\"\",\r\n \ - \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"f4c5b743-f529-45a9-817f-d51fea53f85d\"\ - ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ - ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"0a3e30e9-c4be-46cf-8b21-3c793b3e7519\\\"\"\ - ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ - : \"Dynamic\",\r\n \"subnet\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc6c91815/subnets/subnetc6c91815\"\ - \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ - : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ - \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"th1aoe144toujb4ikzdzl2l5nh.bx.internal.cloudapp.net\"\ - \r\n },\r\n \"macAddress\": \"00-0D-3A-8B-46-50\",\r\n \"enableAcceleratedNetworking\"\ - : false,\r\n \"enableIPForwarding\": false,\r\n \"primary\": true,\r\ - \n \"virtualMachine\": {\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815\"\ - \r\n },\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ - \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '2181' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:55:13 GMT - etag: - - W/"0a3e30e9-c4be-46cf-8b21-3c793b3e7519" - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 9b9afd30-68a5-4cd4-8361-8e5285775355 - status: - code: 200 - message: OK -- request: - body: '{"location": "eastus"}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '22' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/networkWatchers/networkwatcherc6c91815?api-version=2020-07-01 - response: - body: - string: "{\r\n \"name\": \"networkwatcherc6c91815\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc6c91815\"\ - ,\r\n \"etag\": \"W/\\\"b40558d0-8f1a-4867-8a4a-4dc830d29084\\\"\",\r\n \ - \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ - ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"runningOperationIds\": []\r\n }\r\n}" - headers: - azure-asyncnotification: - - Enabled - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/97bc1ead-21b4-4e0a-884c-e8015fa7ee6b?api-version=2020-07-01 - cache-control: - - no-cache - content-length: - - '487' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:55:21 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 8a04d2f3-659b-4cc4-8204-d67a671f8a68 - x-ms-ratelimit-remaining-subscription-writes: - - '1194' - status: - code: 201 - message: Created -- request: - body: '{"targetResourceId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec6c91815", - "direction": "Outbound", "protocol": "TCP", "localPort": "80", "remotePort": - "80", "localIPAddress": "10.0.0.4", "remoteIPAddress": "121.10.1.1"}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '379' - Content-Type: - - application/json - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/networkWatchers/networkwatcherc6c91815/ipFlowVerify?api-version=2020-07-01 - response: - body: - string: "{\r\n \"error\": {\r\n \"code\": \"NsgsNotAppliedOnNic\",\r\n \ - \ \"message\": \"No NSG applied on nic to allow or block traffic, nic id\ - \ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec6c91815.\"\ - ,\r\n \"details\": []\r\n }\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '361' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:55:21 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 8b5f7234-4ae6-4b7c-abed-0b40d839889b - x-ms-ratelimit-remaining-subscription-writes: - - '1197' - status: - code: 400 - message: Bad Request -version: 1 diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_monitor.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_monitor.yaml index 93d8443446f6..5f967943e5ff 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_monitor.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_monitor.yaml @@ -14,16 +14,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d\"\ - ,\r\n \"etag\": \"W/\\\"c6c66ae5-9491-43fa-9d6e-262a529f7ab8\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"e081215d-f98e-4131-a625-2facf529df53\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"e022387e-f166-45ca-ada3-b9e8fded7da2\",\r\n \"\ + \ \"resourceGuid\": \"2449556b-5952-4369-a518-0bfa8ef78ec7\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -32,7 +32,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/edbb239c-6081-47e4-adfe-e306819b6b99?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/23278698-9466-4b8f-b4db-40d52cc0c16d?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -40,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:31 GMT + - Tue, 26 Jan 2021 10:47:05 GMT expires: - '-1' pragma: @@ -53,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ebfedbc2-87b4-4c17-b89d-a72c09e54fbb + - d49ae0d6-eab3-4b8f-9407-8fd332876d58 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 201 message: Created @@ -69,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/edbb239c-6081-47e4-adfe-e306819b6b99?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/23278698-9466-4b8f-b4db-40d52cc0c16d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -83,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:35 GMT + - Tue, 26 Jan 2021 10:47:08 GMT expires: - '-1' pragma: @@ -100,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ff07d087-1b6f-4703-b8fe-600769b33253 + - 21194f1b-91d6-453e-8159-ef09fc8902ee status: code: 200 message: OK @@ -114,16 +114,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d\"\ - ,\r\n \"etag\": \"W/\\\"ca6ebfad-7391-4c52-b3c4-846fc850afac\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"ed306832-39fb-408b-ba19-d609797f67cd\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"e022387e-f166-45ca-ada3-b9e8fded7da2\",\r\n \"\ + \ \"resourceGuid\": \"2449556b-5952-4369-a518-0bfa8ef78ec7\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -136,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:35 GMT + - Tue, 26 Jan 2021 10:47:08 GMT etag: - - W/"ca6ebfad-7391-4c52-b3c4-846fc850afac" + - W/"ed306832-39fb-408b-ba19-d609797f67cd" expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 056678ee-6a5f-440b-80d0-6bfcf566e89b + - 31b37eb5-0700-47ff-b898-2235e46fd9ab status: code: 200 message: OK @@ -173,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnetc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d\"\ - ,\r\n \"etag\": \"W/\\\"98a492e1-ed89-4690-8adc-047be8a36a15\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"eaf48455-ac3b-4850-a530-d7b3ef8ec7bd\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/653844e1-1d52-4bd6-9f22-469869b05886?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0bb041e9-f1cc-4d1a-acc1-fcb762bfa3b8?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -194,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:36 GMT + - Tue, 26 Jan 2021 10:47:09 GMT expires: - '-1' pragma: @@ -207,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e1718630-e5cf-4011-8ca9-bf4ad2007921 + - 94fdc86d-4abb-4715-a664-75720014976a x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -223,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/653844e1-1d52-4bd6-9f22-469869b05886?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0bb041e9-f1cc-4d1a-acc1-fcb762bfa3b8?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -237,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:39 GMT + - Tue, 26 Jan 2021 10:47:12 GMT expires: - '-1' pragma: @@ -254,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ee038c73-f2b8-4ad4-b683-f3e68b8ee98b + - bd0eed44-1c4f-4762-b159-962552122766 status: code: 200 message: OK @@ -268,13 +268,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnetc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetworkc749182d/subnets/subnetc749182d\"\ - ,\r\n \"etag\": \"W/\\\"fc57f8e7-8e9b-40c0-a38d-adbb8a27640d\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"dd42e406-7c29-419c-aace-1a1d9fec688e\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -287,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:40 GMT + - Tue, 26 Jan 2021 10:47:13 GMT etag: - - W/"fc57f8e7-8e9b-40c0-a38d-adbb8a27640d" + - W/"dd42e406-7c29-419c-aace-1a1d9fec688e" expires: - '-1' pragma: @@ -306,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5409734f-6221-4928-8a52-905df7d9e9eb + - 20a0c6e3-31e2-4d12-af33-4a75602b4875 status: code: 200 message: OK @@ -325,18 +325,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interfacec749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interfacec749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d\"\ - ,\r\n \"etag\": \"W/\\\"59afd46f-e3dd-4aea-9cae-9d607e20e265\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"104f4136-e045-4bdd-9ea1-3053212bb151\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"a94cc9bf-e761-4bf9-aadd-b157db4dd5c3\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"28ecb499-32c9-46c4-ae5a-589f79699cf9\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"59afd46f-e3dd-4aea-9cae-9d607e20e265\\\"\"\ + ,\r\n \"etag\": \"W/\\\"104f4136-e045-4bdd-9ea1-3053212bb151\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -344,7 +344,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"py2cfydg4hfellndxhup11l3uc.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"nnkusjcslfuuhjiybp3i332oyh.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -353,7 +353,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/0567fa90-0448-4864-9440-d2fd7401ff5a?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/28d2cb06-4a89-4fa2-9f40-37264ba2da51?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -361,7 +361,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 08:59:43 GMT + - Tue, 26 Jan 2021 10:47:17 GMT expires: - '-1' pragma: @@ -374,9 +374,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 584bcc3c-5fe3-4a52-aa94-86568ca986de + - 21cb02b4-2fc2-4f12-b415-568a4f16a60b x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: code: 201 message: Created @@ -390,9 +390,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/0567fa90-0448-4864-9440-d2fd7401ff5a?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/28d2cb06-4a89-4fa2-9f40-37264ba2da51?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -404,7 +404,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:00:14 GMT + - Tue, 26 Jan 2021 10:47:47 GMT expires: - '-1' pragma: @@ -421,7 +421,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a44c5c60-bfe9-47ee-87b3-01601e34c0cb + - 2f367519-bdf9-4a4f-8048-afaa386e9205 status: code: 200 message: OK @@ -435,18 +435,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interfacec749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interfacec749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d\"\ - ,\r\n \"etag\": \"W/\\\"59afd46f-e3dd-4aea-9cae-9d607e20e265\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"104f4136-e045-4bdd-9ea1-3053212bb151\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"a94cc9bf-e761-4bf9-aadd-b157db4dd5c3\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"28ecb499-32c9-46c4-ae5a-589f79699cf9\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"59afd46f-e3dd-4aea-9cae-9d607e20e265\\\"\"\ + ,\r\n \"etag\": \"W/\\\"104f4136-e045-4bdd-9ea1-3053212bb151\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -454,7 +454,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"py2cfydg4hfellndxhup11l3uc.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"nnkusjcslfuuhjiybp3i332oyh.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -467,9 +467,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:00:14 GMT + - Tue, 26 Jan 2021 10:47:47 GMT etag: - - W/"59afd46f-e3dd-4aea-9cae-9d607e20e265" + - W/"104f4136-e045-4bdd-9ea1-3053212bb151" expires: - '-1' pragma: @@ -486,7 +486,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 71799b1e-5c56-4db8-a7f2-9f597743c016 + - 9c4fe61b-1ffc-4266-bdd6-a7c7a0793caa status: code: 200 message: OK @@ -514,21 +514,22 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachinec749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"5bbf0a94-9e02-46d0-a745-68c95cd1d64f\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"6cc7f0f0-8de5-4d6e-b5e1-3bc17fee8a7b\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ @@ -545,7 +546,8 @@ interactions: \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ - : true\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ + : true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\ + \r\n }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ @@ -554,15 +556,15 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/d97d7baf-1f71-4791-9142-3d9139d30fc3?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 cache-control: - no-cache content-length: - - '2234' + - '2421' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:00:23 GMT + - Tue, 26 Jan 2021 10:47:56 GMT expires: - '-1' pragma: @@ -575,9 +577,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1198 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1199 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1198' status: code: 201 message: Created @@ -592,13 +594,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/d97d7baf-1f71-4791-9142-3d9139d30fc3?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:00:21.3862426+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"d97d7baf-1f71-4791-9142-3d9139d30fc3\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ \r\n}" headers: cache-control: @@ -608,7 +610,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:00:34 GMT + - Tue, 26 Jan 2021 10:48:07 GMT expires: - '-1' pragma: @@ -625,7 +627,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29990 + - Microsoft.Compute/GetOperation3Min;14999,Microsoft.Compute/GetOperation30Min;29996 status: code: 200 message: OK @@ -640,23 +642,263 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/d97d7baf-1f71-4791-9142-3d9139d30fc3?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:00:21.3862426+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:01:16.8392968+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"d97d7baf-1f71-4791-9142-3d9139d30fc3\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" headers: cache-control: - no-cache content-length: - - '184' + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:48:57 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14998,Microsoft.Compute/GetOperation30Min;29995 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:49:28 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14997,Microsoft.Compute/GetOperation30Min;29994 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:49:58 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14995,Microsoft.Compute/GetOperation30Min;29992 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:50:28 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29994 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:50:59 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29993 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:01:24 GMT + - Tue, 26 Jan 2021 10:51:29 GMT expires: - '-1' pragma: @@ -673,7 +915,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29987 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29992 status: code: 200 message: OK @@ -688,54 +930,248 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:52:00 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29990 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:52:31 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29989 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\ + \r\n}" + headers: + cache-control: + - no-cache + content-length: + - '134' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:53:01 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29988 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/236164c6-270e-44da-b1de-8cee9e163127?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T10:47:54.1629336+00:00\",\r\n \"\ + endTime\": \"2021-01-26T10:53:17.257611+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"236164c6-270e-44da-b1de-8cee9e163127\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '183' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 10:53:31 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29986 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachinec749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"5bbf0a94-9e02-46d0-a745-68c95cd1d64f\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"6cc7f0f0-8de5-4d6e-b5e1-3bc17fee8a7b\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ - : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachinec749182d_disk2_078336d205d548d2a4e428820f549dac\"\ + : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachinec749182d_disk2_5a687ac075e948d488d4c08e0ed24b76\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec749182d_disk2_078336d205d548d2a4e428820f549dac\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec749182d_disk2_5a687ac075e948d488d4c08e0ed24b76\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ - name\": \"virtualmachinec749182d_disk3_ca47dce273884abebabd82cf45cec4d0\"\ + name\": \"virtualmachinec749182d_disk3_825cd126bd314b6da432cc455df773a4\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec749182d_disk3_ca47dce273884abebabd82cf45cec4d0\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachinec749182d_disk3_825cd126bd314b6da432cc455df773a4\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ - \n \"enableAutomaticUpdates\": true\r\n },\r\n \"secrets\"\ - : [],\r\n \"allowExtensionOperations\": true,\r\n \"requireGuestProvisionSignal\"\ - : true\r\n },\r\n \"networkProfile\": {\"networkInterfaces\":[{\"id\"\ - :\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d\"\ + \n \"enableAutomaticUpdates\": true,\r\n \"patchSettings\":\ + \ {\r\n \"patchMode\": \"AutomaticByOS\"\r\n }\r\n },\r\ + \n \"secrets\": [],\r\n \"allowExtensionOperations\": true,\r\n\ + \ \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\"\ + : {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interfacec749182d\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '3133' + - '3320' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:01:24 GMT + - Tue, 26 Jan 2021 10:53:32 GMT expires: - '-1' pragma: @@ -752,7 +1188,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3995,Microsoft.Compute/LowCostGet30Min;31987 + - Microsoft.Compute/LowCostGet3Min;3998,Microsoft.Compute/LowCostGet30Min;31995 status: code: 200 message: OK @@ -773,11 +1209,11 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d/extensions/virtualmachineextensionc749182d?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d/extensions/virtualmachineextensionc749182d?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextensionc749182d\",\r\n \"id\":\ @@ -791,7 +1227,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f317b7ba-b9f3-4157-b378-91a6fa991f78?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6?api-version=2020-06-01 cache-control: - no-cache content-length: @@ -799,7 +1235,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:01:31 GMT + - Tue, 26 Jan 2021 10:53:40 GMT expires: - '-1' pragma: @@ -812,9 +1248,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/UpdateVM3Min;239,Microsoft.Compute/UpdateVM30Min;1198 + - Microsoft.Compute/UpdateVM3Min;239,Microsoft.Compute/UpdateVM30Min;1199 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1184' status: code: 201 message: Created @@ -829,13 +1265,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f317b7ba-b9f3-4157-b378-91a6fa991f78?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:01:30.5111772+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"f317b7ba-b9f3-4157-b378-91a6fa991f78\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:53:38.8827456+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6\"\ \r\n}" headers: cache-control: @@ -845,7 +1281,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:02:02 GMT + - Tue, 26 Jan 2021 10:54:10 GMT expires: - '-1' pragma: @@ -862,7 +1298,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14994,Microsoft.Compute/GetOperation30Min;29986 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29985 status: code: 200 message: OK @@ -877,13 +1313,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f317b7ba-b9f3-4157-b378-91a6fa991f78?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:01:30.5111772+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"f317b7ba-b9f3-4157-b378-91a6fa991f78\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:53:38.8827456+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6\"\ \r\n}" headers: cache-control: @@ -893,7 +1329,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:02:32 GMT + - Tue, 26 Jan 2021 10:54:41 GMT expires: - '-1' pragma: @@ -910,7 +1346,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29985 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29984 status: code: 200 message: OK @@ -925,13 +1361,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f317b7ba-b9f3-4157-b378-91a6fa991f78?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:01:30.5111772+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"f317b7ba-b9f3-4157-b378-91a6fa991f78\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:53:38.8827456+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6\"\ \r\n}" headers: cache-control: @@ -941,7 +1377,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:03:02 GMT + - Tue, 26 Jan 2021 10:55:11 GMT expires: - '-1' pragma: @@ -958,7 +1394,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29984 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29983 status: code: 200 message: OK @@ -973,14 +1409,14 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f317b7ba-b9f3-4157-b378-91a6fa991f78?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:01:30.5111772+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:03:05.4016725+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"f317b7ba-b9f3-4157-b378-91a6fa991f78\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T10:53:38.8827456+00:00\",\r\n \"\ + endTime\": \"2021-01-26T10:55:15.8988776+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"f8fb9ea5-ec38-4e8b-ae36-3d8dc7fbdde6\"\r\n}" headers: cache-control: - no-cache @@ -989,7 +1425,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:03:33 GMT + - Tue, 26 Jan 2021 10:55:42 GMT expires: - '-1' pragma: @@ -1006,7 +1442,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29982 + - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29981 status: code: 200 message: OK @@ -1021,9 +1457,9 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d/extensions/virtualmachineextensionc749182d?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d/extensions/virtualmachineextensionc749182d?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextensionc749182d\",\r\n \"id\":\ @@ -1041,7 +1477,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:03:33 GMT + - Tue, 26 Jan 2021 10:55:42 GMT expires: - '-1' pragma: @@ -1058,7 +1494,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3994,Microsoft.Compute/LowCostGet30Min;31983 + - Microsoft.Compute/LowCostGet3Min;3996,Microsoft.Compute/LowCostGet30Min;31996 status: code: 200 message: OK @@ -1076,13 +1512,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcherc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d\"\ - ,\r\n \"etag\": \"W/\\\"da4d19ca-4860-4af8-84c0-81dcf0042009\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"66abecb1-cbf7-42fa-b0d6-5b96701be590\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1090,7 +1526,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d2d20910-2165-4cfe-8cb6-1e08d3b8dd6f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8ccfadd8-d8f3-4e66-a91a-3486ef09ec31?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1098,7 +1534,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:03:41 GMT + - Tue, 26 Jan 2021 10:55:49 GMT expires: - '-1' pragma: @@ -1111,9 +1547,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0e4569fa-1eae-4dc9-82a9-64b225d35625 + - 1bd56b94-8ba3-4f4f-a3c8-41ce0608c632 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 201 message: Created @@ -1137,15 +1573,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionmonitorv2c749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d\"\ - ,\r\n \"etag\": \"W/\\\"4568fdf3-95e2-46e8-b6b9-afc580a92097\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"021d0a3d-5f95-411d-a807-7967c30fabd0\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ - resourceGuid\": \"a865f913-7126-4715-b1b7-b81ffba7c032\",\r\n \"endpoints\"\ + resourceGuid\": \"02ecc62b-e07d-4f72-a9f7-e78bf32076f3\",\r\n \"endpoints\"\ : [\r\n {\r\n \"name\": \"vm1\",\r\n \"resourceId\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ \r\n },\r\n {\r\n \"name\": \"bing\",\r\n \"address\"\ @@ -1166,7 +1602,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/40ab18ae-c99c-4110-aadd-010aa2727d35?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a7a4816c-a8fb-4532-aa43-61fd3a757df4?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1174,7 +1610,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:03:46 GMT + - Tue, 26 Jan 2021 10:55:55 GMT expires: - '-1' pragma: @@ -1187,9 +1623,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7ee1d2ff-010c-4198-8503-c85d93dab8b1 + - abb24511-ca4e-44e2-af31-18b363c0ac0e x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -1203,99 +1639,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/40ab18ae-c99c-4110-aadd-010aa2727d35?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:03:57 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - 84d5ac3a-aa8b-43fa-80cd-2a863529579b - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/40ab18ae-c99c-4110-aadd-010aa2727d35?api-version=2020-07-01 - response: - body: - string: "{\r\n \"status\": \"InProgress\"\r\n}" - headers: - cache-control: - - no-cache - content-length: - - '30' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:04:07 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-arm-service-request-id: - - b7bc5f73-913a-45b0-83d4-9dfd45bb81d2 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-network/17.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.Network/locations/eastus/operations/40ab18ae-c99c-4110-aadd-010aa2727d35?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a7a4816c-a8fb-4532-aa43-61fd3a757df4?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1307,7 +1653,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:27 GMT + - Tue, 26 Jan 2021 10:56:05 GMT expires: - '-1' pragma: @@ -1324,7 +1670,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bc4eabdb-a023-408d-bd51-c3fa8420d48c + - bab271c4-82db-433d-b8d6-1ea5e301c772 status: code: 200 message: OK @@ -1338,15 +1684,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionmonitorv2c749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d\"\ - ,\r\n \"etag\": \"W/\\\"f39e09c9-0064-458e-b22a-250e237a1298\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"1fa28ce9-3dd9-44bf-ad54-800d918108fb\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"a865f913-7126-4715-b1b7-b81ffba7c032\",\r\n \"endpoints\"\ + resourceGuid\": \"02ecc62b-e07d-4f72-a9f7-e78bf32076f3\",\r\n \"endpoints\"\ : [\r\n {\r\n \"name\": \"vm1\",\r\n \"resourceId\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ \r\n },\r\n {\r\n \"name\": \"bing\",\r\n \"address\"\ @@ -1362,7 +1708,7 @@ interactions: \ \"bing\",\r\n \"google\"\r\n ]\r\n }\r\n ],\r\ \n \"outputs\": [\r\n {\r\n \"type\": \"Workspace\",\r\n \ \ \"workspaceSettings\": {\r\n \"workspaceResourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/defaultresourcegroup-eus/providers/microsoft.operationalinsights/workspaces/defaultworkspace-00000000-0000-0000-0000-000000000000-eus\"\ - \r\n }\r\n }\r\n ],\r\n \"startTime\": \"2020-11-30T09:04:16.3294195Z\"\ + \r\n }\r\n }\r\n ],\r\n \"startTime\": \"2021-01-26T10:55:58.2221143Z\"\ ,\r\n \"connectionMonitorType\": \"MultiEndpoint\"\r\n },\r\n \"type\"\ : \"Microsoft.Network/networkWatchers/connectionMonitors\",\r\n \"location\"\ : \"eastus\"\r\n}" @@ -1374,9 +1720,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:28 GMT + - Tue, 26 Jan 2021 10:56:05 GMT etag: - - W/"f39e09c9-0064-458e-b22a-250e237a1298" + - W/"1fa28ce9-3dd9-44bf-ad54-800d918108fb" expires: - '-1' pragma: @@ -1393,7 +1739,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f9d212e3-121e-4079-a4c5-38173ff97a9e + - ccb8f293-de18-41f0-8689-33969a384002 status: code: 200 message: OK @@ -1413,15 +1759,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2019-06-01 response: body: string: "{\r\n \"name\": \"connectionmonitorc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d\"\ - ,\r\n \"etag\": \"W/\\\"66d892be-7c99-43b2-ae7e-090de6e52b75\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"01f6d781-a615-4439-b3a7-867222a5a8c0\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ - resourceGuid\": \"27cf8fea-8bbc-48a9-9aa8-5b0d6af867d7\",\r\n \"source\"\ + resourceGuid\": \"f6051cfa-5976-4d34-9579-288b6429c97f\",\r\n \"source\"\ : {\r\n \"resourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ ,\r\n \"port\": 0\r\n },\r\n \"destination\": {\r\n \"address\"\ : \"bing.com\",\r\n \"port\": 80\r\n },\r\n \"monitoringIntervalInSeconds\"\ @@ -1432,7 +1778,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/17b8b048-feaa-401c-bb48-94ced8529afa?api-version=2019-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/295f4ad3-588d-48f1-902e-35659783ff19?api-version=2019-06-01 cache-control: - no-cache content-length: @@ -1440,7 +1786,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:42 GMT + - Tue, 26 Jan 2021 10:56:17 GMT expires: - '-1' pragma: @@ -1453,9 +1799,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 09b0b3ef-03ff-4fb1-a1df-bd7a77f0f7b5 + - 2270fd6c-fcdb-4ce2-9134-60beb27bc774 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1199' status: code: 201 message: Created @@ -1469,9 +1815,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/17b8b048-feaa-401c-bb48-94ced8529afa?api-version=2019-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/295f4ad3-588d-48f1-902e-35659783ff19?api-version=2019-06-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1483,7 +1829,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:52 GMT + - Tue, 26 Jan 2021 10:56:28 GMT expires: - '-1' pragma: @@ -1500,7 +1846,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a72da5da-9fbf-4263-9e30-f7695c8f84e6 + - 107d7be9-8974-49b8-8b7b-82737b555be3 status: code: 200 message: OK @@ -1514,19 +1860,19 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2019-06-01 response: body: string: "{\r\n \"name\": \"connectionmonitorc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d\"\ - ,\r\n \"etag\": \"W/\\\"c3d511cc-db87-45c7-adf7-21265001d132\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"304758aa-60d0-4013-a498-25d7f0ff75e9\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"27cf8fea-8bbc-48a9-9aa8-5b0d6af867d7\",\r\n \"source\"\ + resourceGuid\": \"f6051cfa-5976-4d34-9579-288b6429c97f\",\r\n \"source\"\ : {\r\n \"resourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ ,\r\n \"port\": 0\r\n },\r\n \"destination\": {\r\n \"address\"\ : \"bing.com\",\r\n \"port\": 80\r\n },\r\n \"monitoringIntervalInSeconds\"\ - : 60,\r\n \"autoStart\": true,\r\n \"startTime\": \"2020-11-30T09:04:41.5950623Z\"\ + : 60,\r\n \"autoStart\": true,\r\n \"startTime\": \"2021-01-26T10:56:17.1596855Z\"\ ,\r\n \"monitoringStatus\": \"Running\"\r\n },\r\n \"type\": \"Microsoft.Network/networkWatchers/connectionMonitors\"\ ,\r\n \"location\": \"eastus\"\r\n}" headers: @@ -1537,9 +1883,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:53 GMT + - Tue, 26 Jan 2021 10:56:28 GMT etag: - - W/"c3d511cc-db87-45c7-adf7-21265001d132" + - W/"304758aa-60d0-4013-a498-25d7f0ff75e9" expires: - '-1' pragma: @@ -1556,7 +1902,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fa8c3c1c-7954-4e65-84bb-5c05e701f2d7 + - a3d2a064-48d9-4b98-a889-08b622c8065a status: code: 200 message: OK @@ -1570,15 +1916,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionmonitorc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d\"\ - ,\r\n \"etag\": \"W/\\\"c3d511cc-db87-45c7-adf7-21265001d132\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"304758aa-60d0-4013-a498-25d7f0ff75e9\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"27cf8fea-8bbc-48a9-9aa8-5b0d6af867d7\",\r\n \"endpoints\"\ + resourceGuid\": \"f6051cfa-5976-4d34-9579-288b6429c97f\",\r\n \"endpoints\"\ : [\r\n {\r\n \"name\": \"defaultSourceEndpoint\",\r\n \ \ \"type\": \"AzureVM\",\r\n \"resourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ \r\n },\r\n {\r\n \"name\": \"defaultDestinationEndpoint\"\ @@ -1593,7 +1939,7 @@ interactions: \r\n ],\r\n \"sources\": [\r\n \"defaultSourceEndpoint\"\ \r\n ],\r\n \"destinations\": [\r\n \"defaultDestinationEndpoint\"\ \r\n ]\r\n }\r\n ],\r\n \"outputs\": [],\r\n \"startTime\"\ - : \"2020-11-30T09:04:41.5950623Z\",\r\n \"monitoringStatus\": \"Running\"\ + : \"2021-01-26T10:56:17.1596855Z\",\r\n \"monitoringStatus\": \"Running\"\ ,\r\n \"connectionMonitorType\": \"SingleSourceDestination\"\r\n },\r\n\ \ \"type\": \"Microsoft.Network/networkWatchers/connectionMonitors\",\r\n\ \ \"location\": \"eastus\"\r\n}" @@ -1605,9 +1951,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:53 GMT + - Tue, 26 Jan 2021 10:56:28 GMT etag: - - W/"c3d511cc-db87-45c7-adf7-21265001d132" + - W/"304758aa-60d0-4013-a498-25d7f0ff75e9" expires: - '-1' pragma: @@ -1624,7 +1970,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b64ad8d5-3698-4cd9-bf80-6ac29790c959 + - 078cdc88-3fd2-4ab1-b6fc-ebbe53a894cc status: code: 200 message: OK @@ -1640,9 +1986,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/query?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/query?api-version=2020-08-01 response: body: string: 'null' @@ -1654,11 +2000,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:04:54 GMT + - Tue, 26 Jan 2021 10:56:29 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/7053603f-1db5-49a7-a373-d4b296d19bbd?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8d54ffb8-5d99-485c-8f74-10f874df831d?api-version=2020-08-01 pragma: - no-cache server: @@ -1669,7 +2015,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5bca4615-222c-4241-97ad-538d0edeb1f6 + - 606ae811-aa93-4b03-9c38-1d92db4c2974 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -1685,44 +2031,50 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/7053603f-1db5-49a7-a373-d4b296d19bbd?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8d54ffb8-5d99-485c-8f74-10f874df831d?api-version=2020-08-01 response: body: string: "{\r\n \"sourceStatus\": \"Active\",\r\n \"states\": [\r\n {\r\n\ - \ \"connectionState\": \"Reachable\",\r\n \"startTime\": \"2020-11-30T09:04:42.7744139Z\"\ - ,\r\n \"evaluationState\": \"InProgress\",\r\n \"avgLatencyInMs\"\ - : 1,\r\n \"minLatencyInMs\": 1,\r\n \"maxLatencyInMs\": 1,\r\n \ + \ \"connectionState\": \"Reachable\",\r\n \"startTime\": \"2021-01-26T10:56:18.2478322Z\"\ + ,\r\n \"evaluationState\": \"Completed\",\r\n \"avgLatencyInMs\"\ + : 1,\r\n \"minLatencyInMs\": 1,\r\n \"maxLatencyInMs\": 2,\r\n \ \ \"probesSent\": 3,\r\n \"probesFailed\": 0,\r\n \"hops\":\ \ [\r\n {\r\n \"type\": \"Source\",\r\n \"id\": \"\ - 9f88f852-9979-4fa1-8135-2922b17086a2\",\r\n \"address\": \"10.0.0.4\"\ + 01467fdd-2f90-4075-8c02-006ff8020b75\",\r\n \"address\": \"10.0.0.4\"\ ,\r\n \"resourceId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachinec749182d\"\ - ,\r\n \"nextHopIds\": [\r\n \"570c6cbc-797d-4802-a37f-f071d6b17093\"\ + ,\r\n \"nextHopIds\": [\r\n \"332be2c9-aa70-4bf4-8998-bb66ab37bce2\"\ \r\n ],\r\n \"links\": [\r\n {\r\n \ - \ \"nextHopId\": \"570c6cbc-797d-4802-a37f-f071d6b17093\",\r\n \ - \ \"properties\": {},\r\n \"context\": {},\r\n \ - \ \"issues\": [],\r\n \"resourceId\": \"\"\r\n \ - \ }\r\n ],\r\n \"previousHopIds\": [],\r\n \"\ - previousLinks\": [],\r\n \"issues\": []\r\n },\r\n \ - \ {\r\n \"type\": \"Destination\",\r\n \"id\": \"570c6cbc-797d-4802-a37f-f071d6b17093\"\ - ,\r\n \"address\": \"13.107.21.200\",\r\n \"nextHopIds\"\ - : [],\r\n \"links\": [],\r\n \"previousHopIds\": [],\r\n\ - \ \"previousLinks\": [],\r\n \"issues\": []\r\n }\r\ - \n ]\r\n }\r\n ]\r\n}" + \ \"nextHopId\": \"332be2c9-aa70-4bf4-8998-bb66ab37bce2\",\r\n \ + \ \"linkType\": \"Internet\",\r\n \"properties\": {},\r\n\ + \ \"context\": {},\r\n \"issues\": [],\r\n \ + \ \"resourceId\": \"\"\r\n }\r\n ],\r\n \ + \ \"previousHopIds\": [],\r\n \"previousLinks\": [],\r\n \ + \ \"issues\": []\r\n },\r\n {\r\n \"type\": \"\ + Internet\",\r\n \"id\": \"332be2c9-aa70-4bf4-8998-bb66ab37bce2\"\ + ,\r\n \"address\": \"204.79.197.200\",\r\n \"nextHopIds\"\ + : [],\r\n \"links\": [],\r\n \"previousHopIds\": [\r\n \ + \ \"01467fdd-2f90-4075-8c02-006ff8020b75\"\r\n ],\r\n \ + \ \"previousLinks\": [\r\n {\r\n \"nextHopId\"\ + : \"01467fdd-2f90-4075-8c02-006ff8020b75\",\r\n \"linkType\"\ + : \"Internet\",\r\n \"properties\": {},\r\n \"context\"\ + : {},\r\n \"issues\": [],\r\n \"resourceId\": \"\ + \"\r\n }\r\n ],\r\n \"issues\": []\r\n \ + \ }\r\n ]\r\n }\r\n ]\r\n}" headers: cache-control: - no-cache content-length: - - '1473' + - '1846' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:04 GMT + - Tue, 26 Jan 2021 10:56:39 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/7053603f-1db5-49a7-a373-d4b296d19bbd?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8d54ffb8-5d99-485c-8f74-10f874df831d?api-version=2020-08-01 pragma: - no-cache server: @@ -1737,7 +2089,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5bca4615-222c-4241-97ad-538d0edeb1f6 + - 606ae811-aa93-4b03-9c38-1d92db4c2974 status: code: 200 message: OK @@ -1753,25 +2105,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/start?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/start?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:05:05 GMT + - Tue, 26 Jan 2021 10:56:39 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 pragma: - no-cache server: @@ -1782,7 +2134,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 83dec8db-3c0b-4b4a-aa04-2fa5286e11f5 + - 4c9aa633-96ee-4da6-8de5-17e5e40a9f00 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -1798,9 +2150,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -1812,7 +2164,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:35 GMT + - Tue, 26 Jan 2021 10:57:10 GMT expires: - '-1' pragma: @@ -1829,7 +2181,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cb5da5cf-2592-47d1-8d4f-1f6b5794ccc1 + - f0fd812d-e5d4-44bd-aa2d-f4a11eba178f status: code: 200 message: OK @@ -1843,15 +2195,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1859,11 +2211,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:36 GMT + - Tue, 26 Jan 2021 10:57:11 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/20601340-c663-4b07-b6f4-08861b7d89f4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/fcf27bd8-07c6-4ff4-9a11-d0b0867e36b6?api-version=2020-08-01 pragma: - no-cache server: @@ -1874,7 +2226,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 83dec8db-3c0b-4b4a-aa04-2fa5286e11f5 + - 4c9aa633-96ee-4da6-8de5-17e5e40a9f00 status: code: 202 message: Accepted @@ -1890,25 +2242,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/stop?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d/stop?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:05:36 GMT + - Tue, 26 Jan 2021 10:57:11 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 pragma: - no-cache server: @@ -1919,7 +2271,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 79af1041-565f-49d6-b4b0-f1716390f5d9 + - 9ec01622-9e69-4c2f-a073-4f5dd5276a0f x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -1935,9 +2287,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -1949,7 +2301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:46 GMT + - Tue, 26 Jan 2021 10:57:23 GMT expires: - '-1' pragma: @@ -1966,7 +2318,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 01517e1f-d26c-4c56-aab9-eec962e4dcfe + - 491d6ce6-9b99-4b60-9795-c0a5a2541545 status: code: 200 message: OK @@ -1980,15 +2332,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1996,11 +2348,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:47 GMT + - Tue, 26 Jan 2021 10:57:23 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/7a0ca3b3-cb27-4cde-82f6-405a26b4e4de?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/07a96de5-2ba9-496b-9f58-61f8abe73988?api-version=2020-08-01 pragma: - no-cache server: @@ -2015,7 +2367,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 79af1041-565f-49d6-b4b0-f1716390f5d9 + - 9ec01622-9e69-4c2f-a073-4f5dd5276a0f status: code: 200 message: OK @@ -2033,17 +2385,17 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"connectionmonitorc749182d\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d\"\ - ,\r\n \"etag\": \"W/\\\"a9a38800-6ce5-4f2c-8482-4d627e31e17f\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"cbd4e409-1f18-4566-85e0-03e9a1002764\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ - resourceGuid\": \"27cf8fea-8bbc-48a9-9aa8-5b0d6af867d7\",\r\n \"endpoints\"\ + resourceGuid\": \"f6051cfa-5976-4d34-9579-288b6429c97f\",\r\n \"endpoints\"\ : [],\r\n \"testConfigurations\": [],\r\n \"testGroups\": [],\r\n \ - \ \"outputs\": [],\r\n \"startTime\": \"2020-11-30T09:04:41.5950623Z\"\ + \ \"outputs\": [],\r\n \"startTime\": \"2021-01-26T10:56:17.1596855Z\"\ ,\r\n \"monitoringStatus\": \"Stopped\",\r\n \"connectionMonitorType\"\ : \"SingleSourceDestination\"\r\n },\r\n \"type\": \"Microsoft.Network/networkWatchers/connectionMonitors\"\ ,\r\n \"location\": \"eastus\",\r\n \"tags\": {\r\n \"tag1\": \"value1\"\ @@ -2056,7 +2408,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:05:53 GMT + - Tue, 26 Jan 2021 10:57:28 GMT expires: - '-1' pragma: @@ -2073,9 +2425,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 836b2aab-103c-4d5f-b63f-76bfa04f02eb + - f9ea0d2e-829e-434f-be3e-874ad2d26375 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1197' status: code: 200 message: OK @@ -2091,9 +2443,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorc749182d?api-version=2020-08-01 response: body: string: '' @@ -2101,17 +2453,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/5f844c81-5d3d-48dc-bea7-aae0f025c8da?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8488a9d9-9ad4-4ad7-9601-ba5279749c2d?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:05:53 GMT + - Tue, 26 Jan 2021 10:57:29 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/5f844c81-5d3d-48dc-bea7-aae0f025c8da?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/8488a9d9-9ad4-4ad7-9601-ba5279749c2d?api-version=2020-08-01 pragma: - no-cache server: @@ -2122,9 +2474,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a9b87c2f-5e69-4855-9a56-175a23ebdd59 + - 1c8aa332-215a-4b16-bcb2-022a329f2ebd x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14998' status: code: 202 message: Accepted @@ -2138,9 +2490,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/5f844c81-5d3d-48dc-bea7-aae0f025c8da?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8488a9d9-9ad4-4ad7-9601-ba5279749c2d?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2152,7 +2504,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:04 GMT + - Tue, 26 Jan 2021 10:57:40 GMT expires: - '-1' pragma: @@ -2169,7 +2521,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 41b08618-dfe3-40ab-9703-72f022e9ecc3 + - 088ba889-2800-4c6d-aed8-33de812be2ac status: code: 200 message: OK @@ -2185,9 +2537,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d/connectionMonitors/connectionmonitorv2c749182d?api-version=2020-08-01 response: body: string: '' @@ -2195,17 +2547,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/614ed82a-e8f5-4821-8698-043eb9b889fe?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fda506e6-4586-4273-89a3-dff07b363bbd?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:06:05 GMT + - Tue, 26 Jan 2021 10:57:41 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/614ed82a-e8f5-4821-8698-043eb9b889fe?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/fda506e6-4586-4273-89a3-dff07b363bbd?api-version=2020-08-01 pragma: - no-cache server: @@ -2216,9 +2568,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 550e3062-29f1-4fa1-b748-aec7ac3270b5 + - f26140ab-04e9-47cb-938e-7394311a761c x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14997' status: code: 202 message: Accepted @@ -2232,9 +2584,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/614ed82a-e8f5-4821-8698-043eb9b889fe?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fda506e6-4586-4273-89a3-dff07b363bbd?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2246,7 +2598,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:15 GMT + - Tue, 26 Jan 2021 10:57:51 GMT expires: - '-1' pragma: @@ -2263,7 +2615,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2bf28a46-02ad-47bb-b5fc-3e4c90d7d105 + - 7baff7d3-214c-4011-89a9-711d487d3328 status: code: 200 message: OK @@ -2279,9 +2631,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcherc749182d?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcherc749182d?api-version=2020-08-01 response: body: string: '' @@ -2289,17 +2641,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/04ab90b6-f55a-4d7b-82e0-96aa4522c135?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3f58eade-6114-47c1-b7f5-ec7b2398e5cc?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:06:16 GMT + - Tue, 26 Jan 2021 10:57:51 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04ab90b6-f55a-4d7b-82e0-96aa4522c135?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/3f58eade-6114-47c1-b7f5-ec7b2398e5cc?api-version=2020-08-01 pragma: - no-cache server: @@ -2310,9 +2662,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 0f75a052-3b7d-40ef-b3cf-b8f7ba522cf9 + - fff7cdc9-189b-4bda-8a8e-12f4fc9b7d4c x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14996' status: code: 202 message: Accepted @@ -2326,9 +2678,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/04ab90b6-f55a-4d7b-82e0-96aa4522c135?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3f58eade-6114-47c1-b7f5-ec7b2398e5cc?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2340,7 +2692,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:26 GMT + - Tue, 26 Jan 2021 10:58:02 GMT expires: - '-1' pragma: @@ -2357,7 +2709,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e475e180-2a65-4cfe-aff1-e3077a8daf91 + - a3bf5afe-3484-4389-8796-f78a39062e46 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_packet_capture.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_packet_capture.yaml index 28141d6287fe..8100c412087a 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_packet_capture.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_packet_capture.yaml @@ -14,16 +14,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"7b2a3e67-0dc4-4297-8d26-00e8ab3a9ce9\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"89ca6a92-7211-443f-b038-b00f4663cfe4\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"fa7dafe9-3ede-40be-9e3c-699cdff9a22e\",\r\n \"\ + \ \"resourceGuid\": \"ec7a8732-fa28-4938-b52a-d3cb4ac5241c\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -32,7 +32,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a0648bd8-e525-4c6e-9dac-d64e3e90d8a9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f6038e4b-5615-4a11-b1ec-852648bbf829?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -40,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:46 GMT + - Tue, 26 Jan 2021 10:58:23 GMT expires: - '-1' pragma: @@ -53,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 07784dfe-b16b-46b3-b545-2179cbaa46e4 + - 70cf0041-22da-4712-b6a6-1f860f5c7de3 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 201 message: Created @@ -69,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a0648bd8-e525-4c6e-9dac-d64e3e90d8a9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f6038e4b-5615-4a11-b1ec-852648bbf829?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -83,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:50 GMT + - Tue, 26 Jan 2021 10:58:27 GMT expires: - '-1' pragma: @@ -100,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3f0587ac-abd9-4dde-b03d-035a4072c8d9 + - e2372ffd-72ec-4eda-afe6-dab036e56022 status: code: 200 message: OK @@ -114,16 +114,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetwork7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"a9ab0548-4a15-493f-a5bd-fb7a7854d2c5\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"6db0fe5d-85bf-4170-b980-c226e535b4fb\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"fa7dafe9-3ede-40be-9e3c-699cdff9a22e\",\r\n \"\ + \ \"resourceGuid\": \"ec7a8732-fa28-4938-b52a-d3cb4ac5241c\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -136,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:50 GMT + - Tue, 26 Jan 2021 10:58:27 GMT etag: - - W/"a9ab0548-4a15-493f-a5bd-fb7a7854d2c5" + - W/"6db0fe5d-85bf-4170-b980-c226e535b4fb" expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 7e9d1108-eacb-469f-96aa-1fad8fc20c6d + - 6820d394-7212-4a16-96bc-19e75f02cbe6 status: code: 200 message: OK @@ -173,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"6d7269e2-9970-4e86-9ab7-ff290047f57a\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"6fff7b8a-c2b3-4827-8865-80ecb445baf6\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/87c3e147-422c-4310-8aba-c518356885d4?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad8f8a2c-3e9f-4df2-9597-5a99e18306e9?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -194,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:51 GMT + - Tue, 26 Jan 2021 10:58:28 GMT expires: - '-1' pragma: @@ -207,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b644bc47-ce99-46cb-a869-e2a2397eb9f4 + - bce96d94-1e1e-4c5f-820a-bb9fb9636b30 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -223,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/87c3e147-422c-4310-8aba-c518356885d4?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ad8f8a2c-3e9f-4df2-9597-5a99e18306e9?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -237,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:55 GMT + - Tue, 26 Jan 2021 10:58:31 GMT expires: - '-1' pragma: @@ -254,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 34677229-2cba-402b-8608-04423442ef3e + - 1da116ee-a8ba-42bb-911b-30e41c472a9b status: code: 200 message: OK @@ -268,13 +268,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"subnet7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualnetwork7a3b1af0/subnets/subnet7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"36c853e0-3e3d-4fdd-aba4-69b839e1e259\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"0a97cb8d-847c-46fb-bb0d-28a6fffefd57\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -287,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:06:55 GMT + - Tue, 26 Jan 2021 10:58:31 GMT etag: - - W/"36c853e0-3e3d-4fdd-aba4-69b839e1e259" + - W/"0a97cb8d-847c-46fb-bb0d-28a6fffefd57" expires: - '-1' pragma: @@ -306,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 32f6328b-b09e-4982-89ed-1021db6e6982 + - 6944e940-464c-466b-bcda-b4c98bd0e38a status: code: 200 message: OK @@ -325,18 +325,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interface7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"8c2a7d73-bec4-4646-8672-242a420e3be4\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"82703d2a-3207-420d-9758-08b560784fcd\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"1bc027a9-2eed-47f4-8913-b400d70e9944\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"48de27bc-3f86-4dfb-9704-1fd340d2e4d1\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"8c2a7d73-bec4-4646-8672-242a420e3be4\\\"\"\ + ,\r\n \"etag\": \"W/\\\"82703d2a-3207-420d-9758-08b560784fcd\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -344,7 +344,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"3gxx14w4h05ebhr2ngon54ncfg.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"gkdxv1bi5i2etnjk0pfuvrjede.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -353,7 +353,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f5f26739-a76f-4533-8047-80aaeec4ca06?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fa24cef6-d681-48e4-8217-428060db9028?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -361,7 +361,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:07:00 GMT + - Tue, 26 Jan 2021 10:58:37 GMT expires: - '-1' pragma: @@ -374,9 +374,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 052e1e5c-5af0-4064-b838-2483dfc9d371 + - d7ae9b9e-a371-4770-9c4b-dc3f2d09bbce x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: code: 201 message: Created @@ -390,9 +390,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f5f26739-a76f-4533-8047-80aaeec4ca06?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/fa24cef6-d681-48e4-8217-428060db9028?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -404,7 +404,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:07:30 GMT + - Tue, 26 Jan 2021 10:59:08 GMT expires: - '-1' pragma: @@ -421,7 +421,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 416948d7-4241-458d-b76e-9b1a72261bd9 + - b0c7d129-c2d5-49a7-9d4a-0463ef0bbdfa status: code: 200 message: OK @@ -435,18 +435,18 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkInterfaces/interface7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"interface7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"8c2a7d73-bec4-4646-8672-242a420e3be4\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"82703d2a-3207-420d-9758-08b560784fcd\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"1bc027a9-2eed-47f4-8913-b400d70e9944\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"48de27bc-3f86-4dfb-9704-1fd340d2e4d1\"\ ,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"MyIpConfig\"\ ,\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0/ipConfigurations/MyIpConfig\"\ - ,\r\n \"etag\": \"W/\\\"8c2a7d73-bec4-4646-8672-242a420e3be4\\\"\"\ + ,\r\n \"etag\": \"W/\\\"82703d2a-3207-420d-9758-08b560784fcd\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/networkInterfaces/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAddress\": \"10.0.0.4\",\r\n \"privateIPAllocationMethod\"\ @@ -454,7 +454,7 @@ interactions: \r\n },\r\n \"primary\": true,\r\n \"privateIPAddressVersion\"\ : \"IPv4\"\r\n }\r\n }\r\n ],\r\n \"dnsSettings\": {\r\n\ \ \"dnsServers\": [],\r\n \"appliedDnsServers\": [],\r\n \"\ - internalDomainNameSuffix\": \"3gxx14w4h05ebhr2ngon54ncfg.bx.internal.cloudapp.net\"\ + internalDomainNameSuffix\": \"gkdxv1bi5i2etnjk0pfuvrjede.bx.internal.cloudapp.net\"\ \r\n },\r\n \"enableAcceleratedNetworking\": false,\r\n \"enableIPForwarding\"\ : false,\r\n \"hostedWorkloads\": [],\r\n \"tapConfigurations\": [],\r\ \n \"nicType\": \"Standard\"\r\n },\r\n \"type\": \"Microsoft.Network/networkInterfaces\"\ @@ -467,9 +467,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:07:31 GMT + - Tue, 26 Jan 2021 10:59:08 GMT etag: - - W/"8c2a7d73-bec4-4646-8672-242a420e3be4" + - W/"82703d2a-3207-420d-9758-08b560784fcd" expires: - '-1' pragma: @@ -486,7 +486,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5062a90e-01cf-4ff8-8112-e824d7262347 + - c2a4b3f4-ba18-47e2-bc8b-a622143628ab status: code: 200 message: OK @@ -514,21 +514,22 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachine7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"c201ead9-5a1f-4612-88d0-ed2878deb8cc\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"4d08f076-3f1c-4642-b4b3-182cb14d6be2\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ @@ -545,7 +546,8 @@ interactions: \ }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \"computerName\"\ : \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\n \"windowsConfiguration\"\ : {\r\n \"provisionVMAgent\": true,\r\n \"enableAutomaticUpdates\"\ - : true\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ + : true,\r\n \"patchSettings\": {\r\n \"patchMode\": \"AutomaticByOS\"\ + \r\n }\r\n },\r\n \"secrets\": [],\r\n \"allowExtensionOperations\"\ : true,\r\n \"requireGuestProvisionSignal\": true\r\n },\r\n \"\ networkProfile\": {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Creating\"\ @@ -554,15 +556,15 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f1dceeec-ed5c-403b-9b4e-9b2818b1b594?api-version=2020-06-01 cache-control: - no-cache content-length: - - '2234' + - '2421' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:07:39 GMT + - Tue, 26 Jan 2021 10:59:16 GMT expires: - '-1' pragma: @@ -575,9 +577,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1197 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1198 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 201 message: Created @@ -592,61 +594,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:07:37.3074505+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"1ba80a51-2239-43fa-9610-5f5c90046fca\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:07:50 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14997,Microsoft.Compute/GetOperation30Min;29979 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f1dceeec-ed5c-403b-9b4e-9b2818b1b594?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:07:37.3074505+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"1ba80a51-2239-43fa-9610-5f5c90046fca\"\ + string: "{\r\n \"startTime\": \"2021-01-26T10:59:14.9158011+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"f1dceeec-ed5c-403b-9b4e-9b2818b1b594\"\ \r\n}" headers: cache-control: @@ -656,7 +610,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:08:40 GMT + - Tue, 26 Jan 2021 10:59:27 GMT expires: - '-1' pragma: @@ -673,7 +627,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14996,Microsoft.Compute/GetOperation30Min;29978 + - Microsoft.Compute/GetOperation3Min;14997,Microsoft.Compute/GetOperation30Min;29978 status: code: 200 message: OK @@ -688,110 +642,14 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/f1dceeec-ed5c-403b-9b4e-9b2818b1b594?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:07:37.3074505+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"1ba80a51-2239-43fa-9610-5f5c90046fca\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:09:11 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14995,Microsoft.Compute/GetOperation30Min;29977 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:07:37.3074505+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"1ba80a51-2239-43fa-9610-5f5c90046fca\"\ - \r\n}" - headers: - cache-control: - - no-cache - content-length: - - '134' - content-type: - - application/json; charset=utf-8 - date: - - Mon, 30 Nov 2020 09:09:41 GMT - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-HTTPAPI/2.0 - - Microsoft-HTTPAPI/2.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29975 - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - 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-compute/10.0.0 Azure-SDK-For-Python - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/1ba80a51-2239-43fa-9610-5f5c90046fca?api-version=2019-07-01 - response: - body: - string: "{\r\n \"startTime\": \"2020-11-30T09:07:37.3074505+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:09:57.5880566+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"1ba80a51-2239-43fa-9610-5f5c90046fca\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T10:59:14.9158011+00:00\",\r\n \"\ + endTime\": \"2021-01-26T11:00:14.6348939+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"f1dceeec-ed5c-403b-9b4e-9b2818b1b594\"\r\n}" headers: cache-control: - no-cache @@ -800,7 +658,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:10:11 GMT + - Tue, 26 Jan 2021 11:00:17 GMT expires: - '-1' pragma: @@ -817,7 +675,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29973 + - Microsoft.Compute/GetOperation3Min;14996,Microsoft.Compute/GetOperation30Min;29977 status: code: 200 message: OK @@ -832,54 +690,56 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachine7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0\"\ ,\r\n \"type\": \"Microsoft.Compute/virtualMachines\",\r\n \"location\"\ - : \"eastus\",\r\n \"properties\": {\r\n \"vmId\": \"c201ead9-5a1f-4612-88d0-ed2878deb8cc\"\ + : \"eastus\",\r\n \"tags\": {\r\n \"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + : \"true\"\r\n },\r\n \"properties\": {\r\n \"vmId\": \"4d08f076-3f1c-4642-b4b3-182cb14d6be2\"\ ,\r\n \"hardwareProfile\": {\r\n \"vmSize\": \"Standard_D2_v2\"\r\n\ \ },\r\n \"storageProfile\": {\r\n \"imageReference\": {\r\n \ \ \"publisher\": \"MicrosoftWindowsServer\",\r\n \"offer\": \"\ WindowsServer\",\r\n \"sku\": \"2016-Datacenter\",\r\n \"version\"\ - : \"latest\",\r\n \"exactVersion\": \"14393.4048.2011170655\"\r\n \ + : \"latest\",\r\n \"exactVersion\": \"14393.4169.2101090332\"\r\n \ \ },\r\n \"osDisk\": {\r\n \"osType\": \"Windows\",\r\n \ \ \"name\": \"myVMosdisk\",\r\n \"createOption\": \"FromImage\"\ ,\r\n \"caching\": \"ReadWrite\",\r\n \"managedDisk\": {\r\n\ \ \"storageAccountType\": \"Standard_LRS\",\r\n \"id\":\ \ \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/myVMosdisk\"\ \r\n },\r\n \"diskSizeGB\": 127\r\n },\r\n \"dataDisks\"\ - : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine7a3b1af0_disk2_3585e8c4bae9448fae5e560a57ecfad5\"\ + : [\r\n {\r\n \"lun\": 0,\r\n \"name\": \"virtualmachine7a3b1af0_disk2_2b17923ae5704321b3c9e7a80446a665\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine7a3b1af0_disk2_3585e8c4bae9448fae5e560a57ecfad5\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine7a3b1af0_disk2_2b17923ae5704321b3c9e7a80446a665\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n },\r\n {\r\n \"lun\": 1,\r\n \"\ - name\": \"virtualmachine7a3b1af0_disk3_dc2a84598a394d7db3efe57d5c249ca5\"\ + name\": \"virtualmachine7a3b1af0_disk3_a6680cc6d3344d96887f663e4722571a\"\ ,\r\n \"createOption\": \"Empty\",\r\n \"caching\": \"None\"\ ,\r\n \"managedDisk\": {\r\n \"storageAccountType\": \"\ - Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine7a3b1af0_disk3_dc2a84598a394d7db3efe57d5c249ca5\"\ + Standard_LRS\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/disks/virtualmachine7a3b1af0_disk3_a6680cc6d3344d96887f663e4722571a\"\ \r\n },\r\n \"diskSizeGB\": 1023,\r\n \"toBeDetached\"\ : false\r\n }\r\n ]\r\n },\r\n \"osProfile\": {\r\n \ \ \"computerName\": \"myVM\",\r\n \"adminUsername\": \"testuser\",\r\ \n \"windowsConfiguration\": {\r\n \"provisionVMAgent\": true,\r\ - \n \"enableAutomaticUpdates\": true\r\n },\r\n \"secrets\"\ - : [],\r\n \"allowExtensionOperations\": true,\r\n \"requireGuestProvisionSignal\"\ - : true\r\n },\r\n \"networkProfile\": {\"networkInterfaces\":[{\"id\"\ - :\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0\"\ + \n \"enableAutomaticUpdates\": true,\r\n \"patchSettings\":\ + \ {\r\n \"patchMode\": \"AutomaticByOS\"\r\n }\r\n },\r\ + \n \"secrets\": [],\r\n \"allowExtensionOperations\": true,\r\n\ + \ \"requireGuestProvisionSignal\": true\r\n },\r\n \"networkProfile\"\ + : {\"networkInterfaces\":[{\"id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkInterfaces/interface7a3b1af0\"\ ,\"properties\":{\"primary\":true}}]},\r\n \"provisioningState\": \"Succeeded\"\ \r\n }\r\n}" headers: cache-control: - no-cache content-length: - - '3133' + - '3320' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:10:12 GMT + - Tue, 26 Jan 2021 11:00:17 GMT expires: - '-1' pragma: @@ -896,7 +756,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3994,Microsoft.Compute/LowCostGet30Min;31976 + - Microsoft.Compute/LowCostGet3Min;3994,Microsoft.Compute/LowCostGet30Min;31987 status: code: 200 message: OK @@ -917,11 +777,11 @@ interactions: - 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0/extensions/virtualmachineextension7a3b1af0?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0/extensions/virtualmachineextension7a3b1af0?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextension7a3b1af0\",\r\n \"id\":\ @@ -935,7 +795,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/420791e8-1a2e-4843-b597-8364ba219929?api-version=2019-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/28079cc4-bcf1-4613-b6e0-c84f8f6522e2?api-version=2020-06-01 cache-control: - no-cache content-length: @@ -943,7 +803,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:10:20 GMT + - Tue, 26 Jan 2021 11:00:24 GMT expires: - '-1' pragma: @@ -956,7 +816,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/UpdateVM3Min;239,Microsoft.Compute/UpdateVM30Min;1197 + - Microsoft.Compute/UpdateVM3Min;239,Microsoft.Compute/UpdateVM30Min;1198 x-ms-ratelimit-remaining-subscription-writes: - '1197' status: @@ -973,13 +833,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/420791e8-1a2e-4843-b597-8364ba219929?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/28079cc4-bcf1-4613-b6e0-c84f8f6522e2?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:10:19.3847788+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"420791e8-1a2e-4843-b597-8364ba219929\"\ + string: "{\r\n \"startTime\": \"2021-01-26T11:00:23.4005876+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"28079cc4-bcf1-4613-b6e0-c84f8f6522e2\"\ \r\n}" headers: cache-control: @@ -989,7 +849,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:10:51 GMT + - Tue, 26 Jan 2021 11:00:54 GMT expires: - '-1' pragma: @@ -1006,7 +866,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29972 + - Microsoft.Compute/GetOperation3Min;14993,Microsoft.Compute/GetOperation30Min;29974 status: code: 200 message: OK @@ -1021,13 +881,13 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/420791e8-1a2e-4843-b597-8364ba219929?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/28079cc4-bcf1-4613-b6e0-c84f8f6522e2?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:10:19.3847788+00:00\",\r\n \"\ - status\": \"InProgress\",\r\n \"name\": \"420791e8-1a2e-4843-b597-8364ba219929\"\ + string: "{\r\n \"startTime\": \"2021-01-26T11:00:23.4005876+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"28079cc4-bcf1-4613-b6e0-c84f8f6522e2\"\ \r\n}" headers: cache-control: @@ -1037,7 +897,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:11:21 GMT + - Tue, 26 Jan 2021 11:01:25 GMT expires: - '-1' pragma: @@ -1054,7 +914,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29971 + - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29973 status: code: 200 message: OK @@ -1069,23 +929,23 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/420791e8-1a2e-4843-b597-8364ba219929?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/28079cc4-bcf1-4613-b6e0-c84f8f6522e2?api-version=2020-06-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:10:19.3847788+00:00\",\r\n \"\ - endTime\": \"2020-11-30T09:11:44.384528+00:00\",\r\n \"status\": \"Succeeded\"\ - ,\r\n \"name\": \"420791e8-1a2e-4843-b597-8364ba219929\"\r\n}" + string: "{\r\n \"startTime\": \"2021-01-26T11:00:23.4005876+00:00\",\r\n \"\ + status\": \"InProgress\",\r\n \"name\": \"28079cc4-bcf1-4613-b6e0-c84f8f6522e2\"\ + \r\n}" headers: cache-control: - no-cache content-length: - - '183' + - '134' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:11:51 GMT + - Tue, 26 Jan 2021 11:01:56 GMT expires: - '-1' pragma: @@ -1102,7 +962,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/GetOperation3Min;14991,Microsoft.Compute/GetOperation30Min;29969 + - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29972 status: code: 200 message: OK @@ -1117,9 +977,57 @@ interactions: - keep-alive 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-compute/10.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-compute/14.0.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0/extensions/virtualmachineextension7a3b1af0?api-version=2019-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute/locations/eastus/operations/28079cc4-bcf1-4613-b6e0-c84f8f6522e2?api-version=2020-06-01 + response: + body: + string: "{\r\n \"startTime\": \"2021-01-26T11:00:23.4005876+00:00\",\r\n \"\ + endTime\": \"2021-01-26T11:02:09.1511503+00:00\",\r\n \"status\": \"Succeeded\"\ + ,\r\n \"name\": \"28079cc4-bcf1-4613-b6e0-c84f8f6522e2\"\r\n}" + headers: + cache-control: + - no-cache + content-length: + - '184' + content-type: + - application/json; charset=utf-8 + date: + - Tue, 26 Jan 2021 11:02:26 GMT + expires: + - '-1' + pragma: + - no-cache + server: + - Microsoft-HTTPAPI/2.0 + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding + x-content-type-options: + - nosniff + x-ms-ratelimit-remaining-resource: + - Microsoft.Compute/GetOperation3Min;14992,Microsoft.Compute/GetOperation30Min;29970 + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + 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-compute/14.0.0 Azure-SDK-For-Python + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0/extensions/virtualmachineextension7a3b1af0?api-version=2020-06-01 response: body: string: "{\r\n \"name\": \"virtualmachineextension7a3b1af0\",\r\n \"id\":\ @@ -1137,7 +1045,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:11:52 GMT + - Tue, 26 Jan 2021 11:02:26 GMT expires: - '-1' pragma: @@ -1154,7 +1062,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3991,Microsoft.Compute/LowCostGet30Min;31970 + - Microsoft.Compute/LowCostGet3Min;3995,Microsoft.Compute/LowCostGet30Min;31983 status: code: 200 message: OK @@ -1173,11 +1081,11 @@ interactions: - 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename7a3b1af0?api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename7a3b1af0?api-version=2019-06-01 response: body: string: '' @@ -1189,11 +1097,11 @@ interactions: content-type: - text/plain; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:00 GMT + - Tue, 26 Jan 2021 11:02:32 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/91bc7d51-598a-4192-8728-68dd21048e8d?monitor=true&api-version=2019-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/cf9475e2-63bc-415e-9854-28bec7eb330d?monitor=true&api-version=2019-06-01 pragma: - no-cache server: @@ -1203,7 +1111,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1183' status: code: 202 message: Accepted @@ -1218,21 +1126,21 @@ interactions: - keep-alive 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/91bc7d51-598a-4192-8728-68dd21048e8d?monitor=true&api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/cf9475e2-63bc-415e-9854-28bec7eb330d?monitor=true&api-version=2019-06-01 response: body: - string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename7a3b1af0","name":"storagename7a3b1af0","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"enabled":true,"lastEnabledTime":"2020-11-30T09:12:00.1764525Z"},"blob":{"enabled":true,"lastEnabledTime":"2020-11-30T09:12:00.1764525Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2020-11-30T09:12:00.0670827Z","primaryEndpoints":{"blob":"https://storagename7a3b1af0.blob.core.windows.net/","queue":"https://storagename7a3b1af0.queue.core.windows.net/","table":"https://storagename7a3b1af0.table.core.windows.net/","file":"https://storagename7a3b1af0.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' + string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename7a3b1af0","name":"storagename7a3b1af0","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"privateEndpointConnections":[],"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T11:02:32.8149538Z"},"blob":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T11:02:32.8149538Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2021-01-26T11:02:32.7055811Z","primaryEndpoints":{"blob":"https://storagename7a3b1af0.blob.core.windows.net/","queue":"https://storagename7a3b1af0.queue.core.windows.net/","table":"https://storagename7a3b1af0.table.core.windows.net/","file":"https://storagename7a3b1af0.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' headers: cache-control: - no-cache content-length: - - '1138' + - '1210' content-type: - application/json date: - - Mon, 30 Nov 2020 09:12:17 GMT + - Tue, 26 Jan 2021 11:02:50 GMT expires: - '-1' pragma: @@ -1264,13 +1172,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcher7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"a2f88c3b-d2fd-41e6-8565-58536c3d9f14\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"8d56bef2-59bb-4a92-9265-30299eccdefc\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1278,7 +1186,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/04ab6e0d-0eb0-477c-af33-7b2249ee163c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8743535c-d1cd-4b50-8734-f82d151008e9?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1286,7 +1194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:25 GMT + - Tue, 26 Jan 2021 11:02:58 GMT expires: - '-1' pragma: @@ -1299,9 +1207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cdba0efe-6495-4151-a8a2-7440a04ff6dc + - 9cf33b08-e3b8-4462-a5a8-f5aafbc34fd5 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1196' status: code: 201 message: Created @@ -1321,13 +1229,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"packetcapture7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"9b0c4131-158d-4579-9cf6-99fec6a4a92c\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"a2ef77db-256d-493f-acea-1d66e7e44df9\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ target\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0\"\ ,\r\n \"bytesToCapturePerPacket\": 0,\r\n \"totalBytesPerSession\":\ @@ -1339,7 +1247,7 @@ interactions: \r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/723c45f4-c3d5-43c1-8cdb-f6d3a06b6ff7?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8e2cebce-680e-4347-8a9a-80cd8e81a1b4?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1347,7 +1255,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:26 GMT + - Tue, 26 Jan 2021 11:02:59 GMT expires: - '-1' pragma: @@ -1360,9 +1268,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d1a3d7ac-1010-41f4-954d-935909236840 + - b384ed3b-ef3d-495e-a333-ff67b7098afe x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1195' status: code: 201 message: Created @@ -1376,9 +1284,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/723c45f4-c3d5-43c1-8cdb-f6d3a06b6ff7?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/8e2cebce-680e-4347-8a9a-80cd8e81a1b4?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1390,7 +1298,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:37 GMT + - Tue, 26 Jan 2021 11:03:10 GMT expires: - '-1' pragma: @@ -1407,7 +1315,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 431a8fd5-564b-46f3-bd78-7c0c95e59ac8 + - b5e44edf-21d9-4db7-be95-5dc9832c1275 status: code: 200 message: OK @@ -1421,13 +1329,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"packetcapture7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"d36a42f6-70c3-4598-bac1-1085133b8217\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3c983fa0-2ba5-49eb-8e69-ccbe435008d1\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ target\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0\"\ ,\r\n \"bytesToCapturePerPacket\": 0,\r\n \"totalBytesPerSession\":\ @@ -1445,9 +1353,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:37 GMT + - Tue, 26 Jan 2021 11:03:10 GMT etag: - - W/"d36a42f6-70c3-4598-bac1-1085133b8217" + - W/"3c983fa0-2ba5-49eb-8e69-ccbe435008d1" expires: - '-1' pragma: @@ -1464,7 +1372,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 10dfee1e-00a6-40ca-a5c4-5b03e2bcc334 + - ad03da3c-0c25-4f1e-acab-e73fa214b931 status: code: 200 message: OK @@ -1478,13 +1386,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"packetcapture7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0\"\ - ,\r\n \"etag\": \"W/\\\"d36a42f6-70c3-4598-bac1-1085133b8217\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"3c983fa0-2ba5-49eb-8e69-ccbe435008d1\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ target\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/virtualMachines/virtualmachine7a3b1af0\"\ ,\r\n \"bytesToCapturePerPacket\": 0,\r\n \"totalBytesPerSession\":\ @@ -1502,9 +1410,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:37 GMT + - Tue, 26 Jan 2021 11:03:10 GMT etag: - - W/"d36a42f6-70c3-4598-bac1-1085133b8217" + - W/"3c983fa0-2ba5-49eb-8e69-ccbe435008d1" expires: - '-1' pragma: @@ -1521,7 +1429,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 10ea25e8-6ac5-471f-9708-cddbd9fa2c0a + - bf8278ff-2d08-49db-8cd1-f84314ed45d0 status: code: 200 message: OK @@ -1537,13 +1445,13 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0/queryStatus?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0/queryStatus?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"packetcapture7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0\"\ - ,\r\n \"captureStartTime\": \"2020-11-30T09:12:27.5506972Z\",\r\n \"packetCaptureStatus\"\ + ,\r\n \"captureStartTime\": \"2021-01-26T11:03:00.1445506Z\",\r\n \"packetCaptureStatus\"\ : \"Running\",\r\n \"packetCaptureError\": []\r\n}" headers: cache-control: @@ -1553,11 +1461,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:38 GMT + - Tue, 26 Jan 2021 11:03:11 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/637ca4b0-837d-479e-92c0-3a9ba399f7e9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/706a6ec2-5a0d-459a-9a39-3977a1668fec?api-version=2020-08-01 pragma: - no-cache server: @@ -1568,7 +1476,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5a22a8ca-0f57-4cb0-996c-b3e8a68e4437 + - 38e1451f-ee08-481e-966a-6c8b147d02ea status: code: 202 message: Accepted @@ -1582,13 +1490,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/637ca4b0-837d-479e-92c0-3a9ba399f7e9?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/706a6ec2-5a0d-459a-9a39-3977a1668fec?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"packetcapture7a3b1af0\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0\"\ - ,\r\n \"captureStartTime\": \"2020-11-30T09:12:27.5506972Z\",\r\n \"packetCaptureStatus\"\ + ,\r\n \"captureStartTime\": \"2021-01-26T11:03:00.1445506Z\",\r\n \"packetCaptureStatus\"\ : \"Running\",\r\n \"packetCaptureError\": []\r\n}" headers: cache-control: @@ -1598,11 +1506,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:48 GMT + - Tue, 26 Jan 2021 11:03:21 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/637ca4b0-837d-479e-92c0-3a9ba399f7e9?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/706a6ec2-5a0d-459a-9a39-3977a1668fec?api-version=2020-08-01 pragma: - no-cache server: @@ -1617,7 +1525,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5a22a8ca-0f57-4cb0-996c-b3e8a68e4437 + - 38e1451f-ee08-481e-966a-6c8b147d02ea status: code: 200 message: OK @@ -1633,25 +1541,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0/stop?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0/stop?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:12:48 GMT + - Tue, 26 Jan 2021 11:03:21 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 pragma: - no-cache server: @@ -1662,7 +1570,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 66bf6eaa-885a-498e-b0d3-08eb50d4504f + - 74d126ba-d543-40b7-aaff-d49d69f047f0 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -1678,9 +1586,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\",\r\n \"properties\": {}\r\n}" @@ -1692,7 +1600,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:59 GMT + - Tue, 26 Jan 2021 11:03:32 GMT expires: - '-1' pragma: @@ -1709,7 +1617,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 23f22142-38e8-4379-aba9-35d80142b9d9 + - e55c7f9d-4a29-4ea6-9b1b-56c6cdba7a0e status: code: 200 message: OK @@ -1723,15 +1631,15 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 response: body: string: 'null' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1739,11 +1647,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:12:59 GMT + - Tue, 26 Jan 2021 11:03:32 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/360f9840-ab3f-4c93-beeb-95a85673847e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/64e194b3-2807-4ae0-99a0-7bb590117b7f?api-version=2020-08-01 pragma: - no-cache server: @@ -1758,7 +1666,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 66bf6eaa-885a-498e-b0d3-08eb50d4504f + - 74d126ba-d543-40b7-aaff-d49d69f047f0 status: code: 200 message: OK @@ -1774,25 +1682,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher7a3b1af0/packetCaptures/packetcapture7a3b1af0?api-version=2020-08-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/f8c37603-53ef-4790-96fe-f11f58fdd278?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca46db3e-1572-41d2-9ea3-b27f59127628?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:13:00 GMT + - Tue, 26 Jan 2021 11:03:32 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/f8c37603-53ef-4790-96fe-f11f58fdd278?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/ca46db3e-1572-41d2-9ea3-b27f59127628?api-version=2020-08-01 pragma: - no-cache server: @@ -1803,9 +1711,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 59cfdf18-acc7-4f7d-9e0c-2ea0d73d2cbb + - 93cb2f5a-673f-4654-b023-f848d3ef23e0 x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 202 message: Accepted @@ -1819,9 +1727,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/f8c37603-53ef-4790-96fe-f11f58fdd278?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/ca46db3e-1572-41d2-9ea3-b27f59127628?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1833,7 +1741,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:11 GMT + - Tue, 26 Jan 2021 11:03:43 GMT expires: - '-1' pragma: @@ -1850,7 +1758,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6f862472-cb34-4378-bb3a-848ef61b92ba + - 412ce844-bea7-4bbb-9297-f7a7e8937a95 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_troubleshoot.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_troubleshoot.yaml index b5633abbdd99..e6c73fdff063 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_troubleshoot.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_watcher.test_network_watcher_troubleshoot.yaml @@ -14,16 +14,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachine46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualmachine46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"ff8bf32d-554d-4eab-976e-09868c85a791\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"2ed28fed-b5f8-44a0-a0e5-f69de10cb7d4\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \ - \ \"resourceGuid\": \"bc726753-3039-4118-8344-0a58f8ff87ac\",\r\n \"\ + \ \"resourceGuid\": \"957c82ae-90d1-4266-b4bd-b1a826a7acb1\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -32,7 +32,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a60e6de3-ab8d-42d4-a248-36585c8c1333?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/eaa838e8-ad8f-4d85-93e2-24f8e33053a9?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -40,7 +40,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:31 GMT + - Tue, 26 Jan 2021 11:04:05 GMT expires: - '-1' pragma: @@ -53,9 +53,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cbb91425-0262-4531-863c-53546f791301 + - 1f7f4d67-99a5-4d4b-811f-3d83d57addf5 x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1195' status: code: 201 message: Created @@ -69,9 +69,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a60e6de3-ab8d-42d4-a248-36585c8c1333?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/eaa838e8-ad8f-4d85-93e2-24f8e33053a9?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -83,7 +83,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:34 GMT + - Tue, 26 Jan 2021 11:04:08 GMT expires: - '-1' pragma: @@ -100,7 +100,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 2a9c601d-6b2b-4f30-af18-920418bae52f + - 4a5e0121-2dbf-4b6a-8843-05d36e057ec8 status: code: 200 message: OK @@ -114,16 +114,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachine46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualmachine46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"5c3c71e0-ca21-4c08-a64a-5168e1de6c66\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"89eb9abc-f369-4e2e-9126-773674c5e685\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworks\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ - \ \"resourceGuid\": \"bc726753-3039-4118-8344-0a58f8ff87ac\",\r\n \"\ + \ \"resourceGuid\": \"957c82ae-90d1-4266-b4bd-b1a826a7acb1\",\r\n \"\ addressSpace\": {\r\n \"addressPrefixes\": [\r\n \"10.0.0.0/16\"\ \r\n ]\r\n },\r\n \"subnets\": [],\r\n \"virtualNetworkPeerings\"\ : [],\r\n \"enableDdosProtection\": false,\r\n \"enableVmProtection\"\ @@ -136,9 +136,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:35 GMT + - Tue, 26 Jan 2021 11:04:08 GMT etag: - - W/"5c3c71e0-ca21-4c08-a64a-5168e1de6c66" + - W/"89eb9abc-f369-4e2e-9126-773674c5e685" expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b77db375-ccbc-47cf-841d-435ca5bbd971 + - 3e5bdf82-2b12-4afe-b921-c26de401d02a status: code: 200 message: OK @@ -173,20 +173,20 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"66aecab3-7b19-473f-ba79-1bcffb5f4ee3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"4b7cb55f-ba42-47f2-ab18-17848ffb47b0\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Updating\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ \n },\r\n \"type\": \"Microsoft.Network/virtualNetworks/subnets\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/7d51a017-ba5a-4614-adb1-c79323c12d35?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/053d3fe5-035f-4388-beac-3f462700bdba?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -194,7 +194,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:35 GMT + - Tue, 26 Jan 2021 11:04:09 GMT expires: - '-1' pragma: @@ -207,9 +207,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6bf9e354-1b03-4c70-944f-91cf39c45b21 + - b4687068-6b79-45d7-893a-8e1f6e565d62 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1194' status: code: 201 message: Created @@ -223,9 +223,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/7d51a017-ba5a-4614-adb1-c79323c12d35?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/053d3fe5-035f-4388-beac-3f462700bdba?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -237,7 +237,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:39 GMT + - Tue, 26 Jan 2021 11:04:13 GMT expires: - '-1' pragma: @@ -254,7 +254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 3af4794d-5ddc-424a-bf95-de33d3d2692e + - 24b0c97c-5ea7-4faf-8990-f99e41764dc1 status: code: 200 message: OK @@ -268,13 +268,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"GatewaySubnet\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworks/virtualmachine46af1a4f/subnets/GatewaySubnet\"\ - ,\r\n \"etag\": \"W/\\\"3b60eda0-30d4-4dda-94d8-429a3c8764bd\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"9d796ea6-270b-4e4e-ba00-302597893685\\\"\",\r\n \ \ \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n \"\ addressPrefix\": \"10.0.0.0/24\",\r\n \"delegations\": [],\r\n \"privateEndpointNetworkPolicies\"\ : \"Enabled\",\r\n \"privateLinkServiceNetworkPolicies\": \"Enabled\"\r\ @@ -287,9 +287,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:39 GMT + - Tue, 26 Jan 2021 11:04:13 GMT etag: - - W/"3b60eda0-30d4-4dda-94d8-429a3c8764bd" + - W/"9d796ea6-270b-4e4e-ba00-302597893685" expires: - '-1' pragma: @@ -306,7 +306,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9d095c63-9ced-44e4-894f-dc573732a402 + - 6438fbb1-5122-4cbb-9c3c-ba28eb639dc0 status: code: 200 message: OK @@ -325,15 +325,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipaddress46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"351a9337-eb1a-40c8-93b9-ebaf747f2687\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"dda183e0-a772-45d2-8d84-2ce8c190179a\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Updating\",\r\n \"resourceGuid\": \"ae5adb96-db27-45a0-a5f0-b399eb64641d\"\ + : \"Updating\",\r\n \"resourceGuid\": \"0a6a7871-fcdc-4c3e-937b-3c09bae54470\"\ ,\r\n \"publicIPAddressVersion\": \"IPv4\",\r\n \"publicIPAllocationMethod\"\ : \"Static\",\r\n \"idleTimeoutInMinutes\": 10,\r\n \"ipTags\": []\r\ \n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\",\r\n \"sku\"\ @@ -343,7 +343,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/13848e3c-3a74-409b-b074-8deaa70f5235?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d6980ad1-c0f9-438a-84c2-019b3a500500?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -351,7 +351,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:45 GMT + - Tue, 26 Jan 2021 11:04:18 GMT expires: - '-1' pragma: @@ -364,9 +364,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - cd7b3817-4cbe-4a4a-a70d-58fcae9d0fb3 + - 08dd7211-7f8e-4d71-ae94-8de50ccca195 x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1193' status: code: 201 message: Created @@ -380,9 +380,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/13848e3c-3a74-409b-b074-8deaa70f5235?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d6980ad1-c0f9-438a-84c2-019b3a500500?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -394,7 +394,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:46 GMT + - Tue, 26 Jan 2021 11:04:20 GMT expires: - '-1' pragma: @@ -411,7 +411,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - acc18a82-581b-4aab-b54b-60cd7066559c + - c77ec718-a57a-407b-9365-1f39fcd3d566 status: code: 200 message: OK @@ -425,16 +425,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/publicIPAddresses/publicipaddress46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"publicipaddress46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/publicIPAddresses/publicipaddress46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"5b49b067-d6f3-4273-88ef-d52aca42ff84\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"fd44d98c-8c4a-4728-9856-8956b421a2aa\\\"\",\r\n \ \ \"location\": \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\"\ - : \"Succeeded\",\r\n \"resourceGuid\": \"ae5adb96-db27-45a0-a5f0-b399eb64641d\"\ - ,\r\n \"ipAddress\": \"52.188.129.173\",\r\n \"publicIPAddressVersion\"\ + : \"Succeeded\",\r\n \"resourceGuid\": \"0a6a7871-fcdc-4c3e-937b-3c09bae54470\"\ + ,\r\n \"ipAddress\": \"20.185.29.29\",\r\n \"publicIPAddressVersion\"\ : \"IPv4\",\r\n \"publicIPAllocationMethod\": \"Static\",\r\n \"idleTimeoutInMinutes\"\ : 10,\r\n \"ipTags\": []\r\n },\r\n \"type\": \"Microsoft.Network/publicIPAddresses\"\ ,\r\n \"sku\": {\r\n \"name\": \"Standard\",\r\n \"tier\": \"Regional\"\ @@ -443,13 +443,13 @@ interactions: cache-control: - no-cache content-length: - - '759' + - '757' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:46 GMT + - Tue, 26 Jan 2021 11:04:21 GMT etag: - - W/"5b49b067-d6f3-4273-88ef-d52aca42ff84" + - W/"fd44d98c-8c4a-4728-9856-8956b421a2aa" expires: - '-1' pragma: @@ -466,7 +466,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 807b67f3-850b-48f2-abd9-b2dcb73024bf + - 13ba962f-5c27-4411-b078-43ea07158232 status: code: 200 message: OK @@ -490,21 +490,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgateway46af1a4f\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"99f4f12b-b7ae-401c-96d3-8bf752e64f6b\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"439f8d26-187a-4871-8f72-16d11791f381\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ - ,\r\n \"resourceGuid\": \"15e581b7-d98c-4353-a38c-52528441f6dc\",\r\n \ + ,\r\n \"resourceGuid\": \"c4106aeb-52bb-4957-b1b6-9e5c88a8d78d\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f/ipConfigurations/ipconfig46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"99f4f12b-b7ae-401c-96d3-8bf752e64f6b\\\"\"\ + ,\r\n \"etag\": \"W/\\\"439f8d26-187a-4871-8f72-16d11791f381\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Updating\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -530,7 +530,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -538,7 +538,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:13:51 GMT + - Tue, 26 Jan 2021 11:04:25 GMT expires: - '-1' pragma: @@ -551,9 +551,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 5dc63284-e215-4e10-96ba-f21713e5708f + - 16a7b616-e672-4677-a038-f0fc90c2e517 x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1192' status: code: 201 message: Created @@ -567,9 +567,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -581,7 +581,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:14:01 GMT + - Tue, 26 Jan 2021 11:04:37 GMT expires: - '-1' pragma: @@ -598,7 +598,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 55520acf-d28b-4f3b-aac0-6f954b3bb525 + - d837b045-5890-4708-93cd-de650ba8536f status: code: 200 message: OK @@ -612,9 +612,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -626,7 +626,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:14:11 GMT + - Tue, 26 Jan 2021 11:04:48 GMT expires: - '-1' pragma: @@ -643,7 +643,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 56e5a288-4b4f-4c97-8dee-464166b2877c + - 29f83a56-f1b2-4cb0-b105-6d5810a6b71d status: code: 200 message: OK @@ -657,9 +657,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -671,7 +671,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:14:31 GMT + - Tue, 26 Jan 2021 11:05:08 GMT expires: - '-1' pragma: @@ -688,7 +688,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 589880b1-d10e-4e90-b33b-2ad5b437e9c0 + - acbdae18-ac06-42f2-8989-2ae79ea7addd status: code: 200 message: OK @@ -702,9 +702,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -716,7 +716,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:14:53 GMT + - Tue, 26 Jan 2021 11:05:28 GMT expires: - '-1' pragma: @@ -733,7 +733,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bb1ad958-cdd0-496a-b2f2-ff2c92f29234 + - 30dbfabd-e014-4356-abed-bb026ebd2678 status: code: 200 message: OK @@ -747,9 +747,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -761,7 +761,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:15:33 GMT + - Tue, 26 Jan 2021 11:06:09 GMT expires: - '-1' pragma: @@ -778,7 +778,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 97e3fce6-84a9-4d4d-9e40-09329362edd1 + - b8c3f620-0fbf-4644-a3f4-f0630714ed53 status: code: 200 message: OK @@ -792,9 +792,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -806,7 +806,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:16:13 GMT + - Tue, 26 Jan 2021 11:06:49 GMT expires: - '-1' pragma: @@ -823,7 +823,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 802c185a-089b-4de6-bb1b-b481221bf0df + - 83ad1cc5-9f15-4d21-8094-44ab54ab8d2d status: code: 200 message: OK @@ -837,9 +837,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -851,7 +851,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:17:33 GMT + - Tue, 26 Jan 2021 11:08:10 GMT expires: - '-1' pragma: @@ -868,7 +868,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - b17d935e-718f-46c3-be43-1b1130f0ff04 + - c6990ee0-609b-4bc9-8837-cad89e5469f2 status: code: 200 message: OK @@ -882,9 +882,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -896,7 +896,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:20:16 GMT + - Tue, 26 Jan 2021 11:10:50 GMT expires: - '-1' pragma: @@ -913,7 +913,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e5f8a553-fef2-4f67-ac4f-519e9c5b3b66 + - 5d71162a-7c30-41d4-90b0-7d24771b40ec status: code: 200 message: OK @@ -927,9 +927,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -941,7 +941,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:21:57 GMT + - Tue, 26 Jan 2021 11:12:32 GMT expires: - '-1' pragma: @@ -958,7 +958,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - ba9d3c4a-2979-45c3-a27e-1260f5dc2e4b + - 77943c7d-c8d6-4c65-ae49-f142ac181c32 status: code: 200 message: OK @@ -972,9 +972,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -986,7 +986,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:23:38 GMT + - Tue, 26 Jan 2021 11:14:11 GMT expires: - '-1' pragma: @@ -1003,7 +1003,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 28700ccd-ac06-43dc-bade-3256349bc198 + - 3de3c3ec-ebd8-4687-beb2-8ca75118e58c status: code: 200 message: OK @@ -1017,9 +1017,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1031,7 +1031,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:25:18 GMT + - Tue, 26 Jan 2021 11:15:53 GMT expires: - '-1' pragma: @@ -1048,7 +1048,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fd6088e4-e02d-4384-8d16-29d36b1d3222 + - 80886d9a-ea25-466b-a3fb-71a124c3e72f status: code: 200 message: OK @@ -1062,9 +1062,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1076,7 +1076,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:27:00 GMT + - Tue, 26 Jan 2021 11:17:34 GMT expires: - '-1' pragma: @@ -1093,7 +1093,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a78f8a85-4aa9-4097-8470-2a4081023a8b + - cbf6d071-a5e1-4573-b090-4d6d47bf3bfc status: code: 200 message: OK @@ -1107,9 +1107,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1121,7 +1121,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:28:40 GMT + - Tue, 26 Jan 2021 11:19:14 GMT expires: - '-1' pragma: @@ -1138,7 +1138,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e4267331-ac84-4242-9b20-bfde0c1de502 + - 10154958-8779-48c5-8e81-4bec9b9f5907 status: code: 200 message: OK @@ -1152,9 +1152,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1166,7 +1166,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:30:22 GMT + - Tue, 26 Jan 2021 11:20:54 GMT expires: - '-1' pragma: @@ -1183,7 +1183,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e98c1d18-4460-42ba-b40e-15f64504a211 + - a4e8ec0e-69f0-4177-8f44-c16911cfb1fc status: code: 200 message: OK @@ -1197,9 +1197,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1211,7 +1211,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:32:03 GMT + - Tue, 26 Jan 2021 11:22:35 GMT expires: - '-1' pragma: @@ -1228,7 +1228,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 35131bec-2d89-4fb1-92de-a9232cd3b8b3 + - 33bbe746-362a-45ae-80bb-d6f58fdf453b status: code: 200 message: OK @@ -1242,9 +1242,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1256,7 +1256,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:33:44 GMT + - Tue, 26 Jan 2021 11:24:16 GMT expires: - '-1' pragma: @@ -1273,7 +1273,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - e37afa66-8ed6-4db6-8596-6bf7caf7888e + - b4846543-607b-4a98-afdb-eae8a8a7a700 status: code: 200 message: OK @@ -1287,9 +1287,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"InProgress\"\r\n}" @@ -1301,7 +1301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:35:25 GMT + - Tue, 26 Jan 2021 11:25:56 GMT expires: - '-1' pragma: @@ -1318,7 +1318,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 541bdc9d-554b-429f-9cd8-ac42f41b66f3 + - f1342a43-18b9-4835-a43a-f9018622282c status: code: 200 message: OK @@ -1332,9 +1332,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/a944ed2f-04e4-4c19-b047-3d01d78e483c?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/58687427-5e8e-44c5-8f1c-36373ce9f353?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -1346,7 +1346,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:06 GMT + - Tue, 26 Jan 2021 11:27:37 GMT expires: - '-1' pragma: @@ -1363,7 +1363,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 9498274f-bbfb-45dd-841c-6ada92c4835d + - 223db8ca-28f0-4223-b340-d94027c1185a status: code: 200 message: OK @@ -1377,21 +1377,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"virtualnetworkgateway46af1a4f\",\r\n \"id\": \"\ /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"8fee0fa0-ba37-4c6a-ab10-47e8f0ca6079\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"c3a47735-52e7-4a0d-b791-8e58c0c61dae\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/virtualNetworkGateways\",\r\n \"location\"\ : \"eastus\",\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ - ,\r\n \"resourceGuid\": \"15e581b7-d98c-4353-a38c-52528441f6dc\",\r\n \ + ,\r\n \"resourceGuid\": \"c4106aeb-52bb-4957-b1b6-9e5c88a8d78d\",\r\n \ \ \"packetCaptureDiagnosticState\": \"None\",\r\n \"enablePrivateIpAddress\"\ : false,\r\n \"ipConfigurations\": [\r\n {\r\n \"name\": \"\ ipconfig46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f/ipConfigurations/ipconfig46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"8fee0fa0-ba37-4c6a-ab10-47e8f0ca6079\\\"\"\ + ,\r\n \"etag\": \"W/\\\"c3a47735-52e7-4a0d-b791-8e58c0c61dae\\\"\"\ ,\r\n \"type\": \"Microsoft.Network/virtualNetworkGateways/ipConfigurations\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\"\ ,\r\n \"privateIPAllocationMethod\": \"Dynamic\",\r\n \"\ @@ -1406,7 +1406,7 @@ interactions: \ {\r\n \"ipconfigurationId\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/virtualNetworkGateways/virtualnetworkgateway46af1a4f/ipConfigurations/ipconfig46af1a4f\"\ ,\r\n \"defaultBgpIpAddresses\": [\r\n \"10.0.1.30\"\r\ \n ],\r\n \"customBgpIpAddresses\": [],\r\n \"\ - tunnelIpAddresses\": [\r\n \"52.188.129.173\"\r\n ]\r\n\ + tunnelIpAddresses\": [\r\n \"20.185.29.29\"\r\n ]\r\n\ \ }\r\n ]\r\n },\r\n \"customRoutes\": {\r\n \"addressPrefixes\"\ : [\r\n \"101.168.0.6/32\"\r\n ]\r\n },\r\n \"vpnGatewayGeneration\"\ : \"Generation1\",\r\n \"enableDnsForwarding\": false\r\n }\r\n}" @@ -1414,11 +1414,11 @@ interactions: cache-control: - no-cache content-length: - - '2876' + - '2874' content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:06 GMT + - Tue, 26 Jan 2021 11:27:37 GMT expires: - '-1' pragma: @@ -1435,7 +1435,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 6ae9d43b-1078-46f8-b28e-37a1c8c4ea62 + - dde46e11-d40c-489d-b56b-6725ba6e7800 status: code: 200 message: OK @@ -1454,11 +1454,11 @@ interactions: - 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python accept-language: - en-US method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename46af1a4f?api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename46af1a4f?api-version=2019-06-01 response: body: string: '' @@ -1470,11 +1470,11 @@ interactions: content-type: - text/plain; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:13 GMT + - Tue, 26 Jan 2021 11:27:43 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/1a09c41c-cf8b-41a7-88ce-1912acb34e84?monitor=true&api-version=2019-04-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/215e7a71-294a-4673-ab78-ab4f479fc675?monitor=true&api-version=2019-06-01 pragma: - no-cache server: @@ -1499,21 +1499,21 @@ interactions: - keep-alive 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-storage/5.0.0 Azure-SDK-For-Python + msrest_azure/0.6.2 azure-mgmt-storage/11.2.0 Azure-SDK-For-Python method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/1a09c41c-cf8b-41a7-88ce-1912acb34e84?monitor=true&api-version=2019-04-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage/locations/eastus/asyncoperations/215e7a71-294a-4673-ab78-ab4f479fc675?monitor=true&api-version=2019-06-01 response: body: - string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename46af1a4f","name":"storagename46af1a4f","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"enabled":true,"lastEnabledTime":"2020-11-30T09:37:13.3995105Z"},"blob":{"enabled":true,"lastEnabledTime":"2020-11-30T09:37:13.3995105Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2020-11-30T09:37:13.2901542Z","primaryEndpoints":{"blob":"https://storagename46af1a4f.blob.core.windows.net/","queue":"https://storagename46af1a4f.queue.core.windows.net/","table":"https://storagename46af1a4f.table.core.windows.net/","file":"https://storagename46af1a4f.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' + string: '{"sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Storage/storageAccounts/storagename46af1a4f","name":"storagename46af1a4f","type":"Microsoft.Storage/storageAccounts","location":"eastus","tags":{},"properties":{"privateEndpointConnections":[],"networkAcls":{"bypass":"AzureServices","virtualNetworkRules":[],"ipRules":[],"defaultAction":"Allow"},"supportsHttpsTrafficOnly":true,"encryption":{"services":{"file":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T11:27:43.4441501Z"},"blob":{"keyType":"Account","enabled":true,"lastEnabledTime":"2021-01-26T11:27:43.4441501Z"}},"keySource":"Microsoft.Storage"},"provisioningState":"Succeeded","creationTime":"2021-01-26T11:27:43.3347779Z","primaryEndpoints":{"blob":"https://storagename46af1a4f.blob.core.windows.net/","queue":"https://storagename46af1a4f.queue.core.windows.net/","table":"https://storagename46af1a4f.table.core.windows.net/","file":"https://storagename46af1a4f.file.core.windows.net/"},"primaryLocation":"eastus","statusOfPrimary":"available"}}' headers: cache-control: - no-cache content-length: - - '1138' + - '1210' content-type: - application/json date: - - Mon, 30 Nov 2020 09:37:31 GMT + - Tue, 26 Jan 2021 11:28:01 GMT expires: - '-1' pragma: @@ -1545,13 +1545,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher46af1a4f?api-version=2020-08-01 response: body: string: "{\r\n \"name\": \"networkwatcher46af1a4f\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher46af1a4f\"\ - ,\r\n \"etag\": \"W/\\\"463e60df-db99-408c-afb5-bfd3de6103a3\\\"\",\r\n \ + ,\r\n \"etag\": \"W/\\\"116459c2-29c7-44b7-b649-b6185ab57322\\\"\",\r\n \ \ \"type\": \"Microsoft.Network/networkWatchers\",\r\n \"location\": \"eastus\"\ ,\r\n \"properties\": {\r\n \"provisioningState\": \"Succeeded\",\r\n\ \ \"runningOperationIds\": []\r\n }\r\n}" @@ -1559,7 +1559,7 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/d54dbb0c-a14e-45d8-9f42-1d05cff4d631?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/1f42081d-7a54-46fe-ada5-f6e2202ed630?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -1567,7 +1567,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:39 GMT + - Tue, 26 Jan 2021 11:28:07 GMT expires: - '-1' pragma: @@ -1580,9 +1580,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 85cd5bd6-d208-47d5-abb3-70e4ac613ea6 + - b38d9700-73fa-45e8-87d3-a5dd6a9dcde7 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1199' status: code: 201 message: Created @@ -1602,9 +1602,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher46af1a4f/troubleshoot?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher46af1a4f/troubleshoot?api-version=2020-08-01 response: body: string: 'null' @@ -1616,11 +1616,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:40 GMT + - Tue, 26 Jan 2021 11:28:08 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1631,9 +1631,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 202 message: Accepted @@ -1647,9 +1647,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1661,11 +1661,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:37:50 GMT + - Tue, 26 Jan 2021 11:28:18 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1676,7 +1676,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1690,9 +1690,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1704,11 +1704,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:00 GMT + - Tue, 26 Jan 2021 11:28:28 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1719,7 +1719,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1733,9 +1733,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1747,11 +1747,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:10 GMT + - Tue, 26 Jan 2021 11:28:39 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1762,7 +1762,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1776,9 +1776,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1790,11 +1790,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:21 GMT + - Tue, 26 Jan 2021 11:28:50 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1805,7 +1805,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1819,9 +1819,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1833,11 +1833,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:31 GMT + - Tue, 26 Jan 2021 11:29:01 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1848,7 +1848,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1862,9 +1862,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1876,11 +1876,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:41 GMT + - Tue, 26 Jan 2021 11:29:11 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1891,7 +1891,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1905,9 +1905,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1919,11 +1919,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:38:52 GMT + - Tue, 26 Jan 2021 11:29:21 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1934,7 +1934,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1948,9 +1948,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -1962,11 +1962,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:02 GMT + - Tue, 26 Jan 2021 11:29:31 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -1977,7 +1977,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -1991,9 +1991,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -2005,11 +2005,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:12 GMT + - Tue, 26 Jan 2021 11:29:42 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2020,7 +2020,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -2034,9 +2034,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -2048,11 +2048,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:22 GMT + - Tue, 26 Jan 2021 11:29:52 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2063,7 +2063,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -2077,9 +2077,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -2091,11 +2091,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:33 GMT + - Tue, 26 Jan 2021 11:30:03 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2106,7 +2106,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -2120,9 +2120,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -2134,11 +2134,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:43 GMT + - Tue, 26 Jan 2021 11:30:13 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2149,7 +2149,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -2163,9 +2163,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: string: 'null' @@ -2177,11 +2177,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:39:53 GMT + - Tue, 26 Jan 2021 11:30:23 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2192,7 +2192,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 202 message: Accepted @@ -2206,13 +2206,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:37:39.7773442Z\",\r\n \"endTime\"\ - : \"2020-11-30T09:37:43.498Z\",\r\n \"code\": \"UnHealthy\",\r\n \"results\"\ + string: "{\r\n \"startTime\": \"2021-01-26T11:28:08.6482686Z\",\r\n \"endTime\"\ + : \"2021-01-26T11:28:12.075Z\",\r\n \"code\": \"UnHealthy\",\r\n \"results\"\ : [\r\n {\r\n \"id\": \"NoConnectionsFoundForGateway\",\r\n \"\ summary\": \"No connections have been created on the gateway\",\r\n \"\ detail\": \"A cross-premises or VNet-to-VNet connection needs to be created\ @@ -2235,11 +2235,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:40:05 GMT + - Tue, 26 Jan 2021 11:30:34 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/bd87229f-a275-4e64-9ace-0cdd713ff15e?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/04f5b98a-85c4-41bc-ad3c-017fcd551dae?api-version=2020-08-01 pragma: - no-cache server: @@ -2254,7 +2254,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - d5b09d49-0d43-45ab-b25f-ab57d31f7508 + - 0d5c625a-8e5f-4948-bbaa-697c162d7aa3 status: code: 200 message: OK @@ -2272,13 +2272,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher46af1a4f/queryTroubleshootResult?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher46af1a4f/queryTroubleshootResult?api-version=2020-08-01 response: body: - string: "{\r\n \"startTime\": \"2020-11-30T09:37:39.7773442Z\",\r\n \"endTime\"\ - : \"2020-11-30T09:37:43.498Z\",\r\n \"code\": \"UnHealthy\",\r\n \"results\"\ + string: "{\r\n \"startTime\": \"2021-01-26T11:28:08.6482686Z\",\r\n \"endTime\"\ + : \"2021-01-26T11:28:12.075Z\",\r\n \"code\": \"UnHealthy\",\r\n \"results\"\ : [\r\n {\r\n \"id\": \"NoConnectionsFoundForGateway\",\r\n \"\ summary\": \"No connections have been created on the gateway\",\r\n \"\ detail\": \"A cross-premises or VNet-to-VNet connection needs to be created\ @@ -2301,7 +2301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:40:05 GMT + - Tue, 26 Jan 2021 11:30:35 GMT expires: - '-1' pragma: @@ -2318,7 +2318,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - fc0ef47d-3e20-4abb-9557-e1eb2486eabd + - ae880d13-e8a0-48e5-9707-0c8b0e7dbf87 status: code: 200 message: OK @@ -2334,9 +2334,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/networkWatchers/networkwatcher46af1a4f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/networkWatchers/networkwatcher46af1a4f?api-version=2020-08-01 response: body: string: '' @@ -2344,17 +2344,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/3a62f4e3-8c97-44dc-bdcd-a77cbfe1f950?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b178eca6-25f4-41bb-a926-dc197596b1e5?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 30 Nov 2020 09:40:06 GMT + - Tue, 26 Jan 2021 11:30:36 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/3a62f4e3-8c97-44dc-bdcd-a77cbfe1f950?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operationResults/b178eca6-25f4-41bb-a926-dc197596b1e5?api-version=2020-08-01 pragma: - no-cache server: @@ -2365,9 +2365,9 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 26d62563-09d8-4e6a-af7f-708242c8728c + - 67af55a4-84fd-4a3f-8b18-e9681f8069fa x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14998' status: code: 202 message: Accepted @@ -2381,9 +2381,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/eastus/operations/3a62f4e3-8c97-44dc-bdcd-a77cbfe1f950?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/eastus/operations/b178eca6-25f4-41bb-a926-dc197596b1e5?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -2395,7 +2395,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Mon, 30 Nov 2020 09:40:16 GMT + - Tue, 26 Jan 2021 11:30:48 GMT expires: - '-1' pragma: @@ -2412,7 +2412,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 311c2adf-7d33-46c8-8ed3-870831b4518c + - f3f63640-045a-4b97-ae56-109673f2dd89 status: code: 200 message: OK diff --git a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_web_application_firewall_policy.test_network.yaml b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_web_application_firewall_policy.test_network.yaml index af3fa950598e..db1ef96f3ec0 100644 --- a/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_web_application_firewall_policy.test_network.yaml +++ b/sdk/network/azure-mgmt-network/tests/recordings/test_cli_mgmt_network_web_application_firewall_policy.test_network.yaml @@ -14,27 +14,28 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy\",\r\n - \ \"etag\": \"W/\\\"78b15572-8800-4302-b143-dccdf8c97ec4\\\"\",\r\n \"type\": - \"Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies\",\r\n - \ \"location\": \"westus\",\r\n \"properties\": {\r\n \"provisioningState\": - \"Updating\",\r\n \"customRules\": [],\r\n \"policySettings\": {\r\n - \ \"requestBodyCheck\": true,\r\n \"maxRequestBodySizeInKb\": 128,\r\n - \ \"fileUploadLimitInMb\": 100,\r\n \"state\": \"Disabled\",\r\n - \ \"mode\": \"Detection\"\r\n },\r\n \"managedRules\": {\r\n \"managedRuleSets\": - [\r\n {\r\n \"ruleSetType\": \"OWASP\",\r\n \"ruleSetVersion\": - \"3.0\",\r\n \"ruleGroupOverrides\": []\r\n }\r\n ],\r\n - \ \"exclusions\": []\r\n }\r\n }\r\n}" + string: "{\r\n \"name\": \"myPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy\"\ + ,\r\n \"etag\": \"W/\\\"6e83be29-e638-4482-a62d-4652f82c5756\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies\"\ + ,\r\n \"location\": \"westus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Updating\",\r\n \"customRules\": [],\r\n \"policySettings\": {\r\ + \n \"requestBodyCheck\": true,\r\n \"maxRequestBodySizeInKb\": 128,\r\ + \n \"fileUploadLimitInMb\": 100,\r\n \"state\": \"Disabled\",\r\n\ + \ \"mode\": \"Detection\"\r\n },\r\n \"managedRules\": {\r\n \ + \ \"managedRuleSets\": [\r\n {\r\n \"ruleSetType\": \"\ + OWASP\",\r\n \"ruleSetVersion\": \"3.0\",\r\n \"ruleGroupOverrides\"\ + : []\r\n }\r\n ],\r\n \"exclusions\": []\r\n }\r\n }\r\ + \n}" headers: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/a3e4b9f5-e2db-44a8-afae-14ec01728f46?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/4594eaac-cc05-4023-975f-64e39dd315b4?api-version=2020-08-01 cache-control: - no-cache content-length: @@ -42,7 +43,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 11:10:07 GMT + - Tue, 26 Jan 2021 11:31:04 GMT expires: - '-1' pragma: @@ -55,7 +56,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - a361b6ec-b728-4368-b4ab-eb1347640b09 + - 501727e1-c96f-4b9a-8d28-ab004252acd1 x-ms-ratelimit-remaining-subscription-writes: - '1199' status: @@ -71,22 +72,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-08-01 response: body: - string: "{\r\n \"name\": \"myPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy\",\r\n - \ \"etag\": \"W/\\\"ad6a6abc-7491-4e93-b280-79a9925c4ebd\\\"\",\r\n \"type\": - \"Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies\",\r\n - \ \"location\": \"westus\",\r\n \"properties\": {\r\n \"provisioningState\": - \"Succeeded\",\r\n \"customRules\": [],\r\n \"policySettings\": {\r\n - \ \"requestBodyCheck\": true,\r\n \"maxRequestBodySizeInKb\": 128,\r\n - \ \"fileUploadLimitInMb\": 100,\r\n \"state\": \"Disabled\",\r\n - \ \"mode\": \"Detection\"\r\n },\r\n \"managedRules\": {\r\n \"managedRuleSets\": - [\r\n {\r\n \"ruleSetType\": \"OWASP\",\r\n \"ruleSetVersion\": - \"3.0\",\r\n \"ruleGroupOverrides\": []\r\n }\r\n ],\r\n - \ \"exclusions\": []\r\n }\r\n }\r\n}" + string: "{\r\n \"name\": \"myPolicy\",\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy\"\ + ,\r\n \"etag\": \"W/\\\"f7be993b-60c3-48ec-8dc6-efd554e152e7\\\"\",\r\n \ + \ \"type\": \"Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies\"\ + ,\r\n \"location\": \"westus\",\r\n \"properties\": {\r\n \"provisioningState\"\ + : \"Succeeded\",\r\n \"customRules\": [],\r\n \"policySettings\": {\r\ + \n \"requestBodyCheck\": true,\r\n \"maxRequestBodySizeInKb\": 128,\r\ + \n \"fileUploadLimitInMb\": 100,\r\n \"state\": \"Disabled\",\r\n\ + \ \"mode\": \"Detection\"\r\n },\r\n \"managedRules\": {\r\n \ + \ \"managedRuleSets\": [\r\n {\r\n \"ruleSetType\": \"\ + OWASP\",\r\n \"ruleSetVersion\": \"3.0\",\r\n \"ruleGroupOverrides\"\ + : []\r\n }\r\n ],\r\n \"exclusions\": []\r\n }\r\n }\r\ + \n}" headers: cache-control: - no-cache @@ -95,9 +97,9 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 11:10:08 GMT + - Tue, 26 Jan 2021 11:31:05 GMT etag: - - W/"ad6a6abc-7491-4e93-b280-79a9925c4ebd" + - W/"f7be993b-60c3-48ec-8dc6-efd554e152e7" expires: - '-1' pragma: @@ -114,7 +116,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - bda12f3c-44df-4ec7-a282-d274ec75f892 + - a9e6265a-b5e2-4ad9-b421-54f3c8b6f6d6 status: code: 200 message: OK @@ -130,9 +132,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Network/ApplicationGatewayWebApplicationFirewallPolicies/myPolicy?api-version=2020-08-01 response: body: string: '' @@ -140,17 +142,17 @@ interactions: azure-asyncnotification: - Enabled azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/e95a7d89-8f62-44de-a01e-823468ed289f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/5cc02cd3-af14-470c-96ef-53b3531cc519?api-version=2020-08-01 cache-control: - no-cache content-length: - '0' date: - - Wed, 25 Nov 2020 11:10:09 GMT + - Tue, 26 Jan 2021 11:31:06 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/e95a7d89-8f62-44de-a01e-823468ed289f?api-version=2020-07-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operationResults/5cc02cd3-af14-470c-96ef-53b3531cc519?api-version=2020-08-01 pragma: - no-cache server: @@ -161,7 +163,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - f82c538b-07e0-48a7-af6a-e668ed57cfab + - 289bd150-7923-4374-94dd-40d9cd07f5eb x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -177,9 +179,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-network/17.0.0 Python/3.7.3 (Windows-10-10.0.19041-SP0) + - azsdk-python-azure-mgmt-network/0.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.Network/locations/westus/operations/e95a7d89-8f62-44de-a01e-823468ed289f?api-version=2020-07-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network/locations/westus/operations/5cc02cd3-af14-470c-96ef-53b3531cc519?api-version=2020-08-01 response: body: string: "{\r\n \"status\": \"Succeeded\"\r\n}" @@ -191,7 +193,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Wed, 25 Nov 2020 11:10:19 GMT + - Tue, 26 Jan 2021 11:31:16 GMT expires: - '-1' pragma: @@ -208,7 +210,7 @@ interactions: x-content-type-options: - nosniff x-ms-arm-service-request-id: - - 561ceb5b-0f20-448b-b543-a1a05a2ab001 + - 8630b926-1fc4-4ebd-97fe-fb085dc9bed5 status: code: 200 message: OK