Skip to content

Commit

Permalink
Fixes for VPN Client Generate (Azure#7962)
Browse files Browse the repository at this point in the history
* Remove mock dependency.

* Fix linter issues.
  • Loading branch information
tjprescott authored and williexu committed Dec 4, 2018
1 parent 5b4706d commit 98c506b
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 87 deletions.
2 changes: 2 additions & 0 deletions azure-cli2017.pyproj
Original file line number Diff line number Diff line change
Expand Up @@ -997,6 +997,8 @@
<Folder Include="command_modules\azure-cli-botservice\azure\cli\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\bot\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\bot\templates\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\tests\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\tests\latest\" />
<Folder Include="command_modules\azure-cli-botservice\azure\cli\command_modules\botservice\tests\latest\recordings\" />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
from __future__ import print_function

from collections import Counter, OrderedDict
import mock

from knack.log import get_logger

Expand Down Expand Up @@ -3497,45 +3496,17 @@ def update_vnet_gateway(cmd, instance, sku=None, vpn_type=None, tags=None,
return instance


# region VPN CLIENT WORKAROUND
# This is needed due to NRP doing exactly the opposite of what the specification says they should do.
# TODO: Remove workaround when Swagger is fixed
# region LegacyVpnClient Workaround
# pylint: disable=line-too-long, protected-access, mixed-line-endings
def _poll(self, update_cmd):
from msrestazure.azure_operation import finished, failed, BadResponse, OperationFailed
initial_url = self._response.request.url

while not finished(self.status()):
self._delay()
headers = self._polling_cookie()

if self._operation.location_url:
self._response = update_cmd(
self._operation.location_url, headers)
self._operation.set_async_url_if_present(self._response)
self._operation.get_status_from_location(
self._response)
elif self._operation.method == "PUT":
self._response = update_cmd(initial_url, headers)
self._operation.set_async_url_if_present(self._response)
self._operation.get_status_from_resource(
self._response)
else:
raise BadResponse(
'Location header is missing from long-running operation.')

if failed(self._operation.status):
raise OperationFailed("Operation failed or cancelled")
elif self._operation.should_do_final_get():
self._response = update_cmd(initial_url)
self._operation.get_status_from_resource(
self._response)


# This is needed due to a bug in autorest code generation. It adds 202 as a valid status code.
def _vpn_client_core(self, url, resource_group_name, virtual_network_gateway_name, parameters, custom_headers=None, raw=False, **operation_config):
def _legacy_generate_vpn_client_initial(
self, resource_group_name, virtual_network_gateway_name, parameters, custom_headers=None,
raw=False, **operation_config):
import uuid
from msrest.pipeline import ClientRawResponse
from msrestazure.azure_operation import AzureOperationPoller

# Construct URL
url = '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'
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'),
Expand All @@ -3549,6 +3520,7 @@ def _vpn_client_core(self, url, resource_group_name, virtual_network_gateway_nam

# Construct headers
header_parameters = {}
header_parameters['Accept'] = 'application/json'
header_parameters['Content-Type'] = 'application/json; charset=utf-8'
if self.config.generate_client_request_id:
header_parameters['x-ms-client-request-id'] = str(uuid.uuid1())
Expand All @@ -3561,71 +3533,69 @@ def _vpn_client_core(self, url, resource_group_name, virtual_network_gateway_nam
body_content = self._serialize.body(parameters, 'VpnClientParameters')

# Construct and send request
def long_running_send():
request = self._client.post(url, query_parameters, header_parameters, body_content)
response = self._client.send(request, stream=False, **operation_config)

request = self._client.post(url, query_parameters)
return self._client.send(
request, header_parameters, body_content, **operation_config)
if response.status_code not in [200, 202]:
exp = CloudError(response)
exp.request_id = response.headers.get('x-ms-request-id')
raise exp

def get_long_running_status(status_link, headers=None):
deserialized = None

request = self._client.get(status_link)
if headers:
request.headers.update(headers)
return self._client.send(
request, header_parameters, **operation_config)
if response.status_code == 200:
deserialized = self._deserialize('str', response)

def get_long_running_output(response):
if raw:
client_raw_response = ClientRawResponse(deserialized, response)
return client_raw_response

return deserialized

if response.status_code not in [200, 202]:
exp = CloudError(response)
exp.request_id = response.headers.get('x-ms-request-id')
raise exp

deserialized = None
# pylint: disable=line-too-long, protected-access, mixed-line-endings
def _legacy_generate_vpn_client(
self, resource_group_name, virtual_network_gateway_name, parameters, custom_headers=None, raw=False,
polling=True, **operation_config):
from msrest.pipeline import ClientRawResponse
from msrest.polling import LROPoller, NoPolling
from msrestazure.polling.arm_polling import ARMPolling

raw_result = _legacy_generate_vpn_client_initial(
self,
resource_group_name=resource_group_name,
virtual_network_gateway_name=virtual_network_gateway_name,
parameters=parameters,
custom_headers=custom_headers,
raw=True,
**operation_config
)

if response.status_code in [200, 202]:
deserialized = self._deserialize('str', response)
def get_long_running_output(response):
deserialized = self._deserialize('str', response)

if raw:
client_raw_response = ClientRawResponse(deserialized, response)
return client_raw_response

return deserialized

if raw:
response = long_running_send()
return get_long_running_output(response)

long_running_operation_timeout = operation_config.get(
lro_delay = operation_config.get(
'long_running_operation_timeout',
self.config.long_running_operation_timeout)
return AzureOperationPoller(
long_running_send, get_long_running_output,
get_long_running_status, long_running_operation_timeout)


@mock.patch('msrestazure.azure_operation.AzureOperationPoller._poll', _poll)
def _generate_vpn_profile(
self, resource_group_name, virtual_network_gateway_name, parameters, custom_headers=None, raw=False, **operation_config):
# Construct URL
url = '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnprofile'
return _vpn_client_core(self, url, resource_group_name, virtual_network_gateway_name, parameters, custom_headers, raw, **operation_config)


@mock.patch('msrestazure.azure_operation.AzureOperationPoller._poll', _poll)
def _generatevpnclientpackage(
self, resource_group_name, virtual_network_gateway_name, parameters, custom_headers=None, raw=False, **operation_config):
# Construct URL
url = '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/virtualNetworkGateways/{virtualNetworkGatewayName}/generatevpnclientpackage'
return _vpn_client_core(self, url, resource_group_name, virtual_network_gateway_name, parameters, custom_headers, raw, **operation_config)

# endregion VPN CLIENT WORKAROUND`
if polling is True:
polling_method = ARMPolling(lro_delay, **operation_config)
elif polling is False:
polling_method = NoPolling()
else:
polling_method = polling
return LROPoller(self._client, raw_result, get_long_running_output, polling_method)
# endregion LegacyVpnClient Workaround


def generate_vpn_client(cmd, client, resource_group_name, virtual_network_gateway_name, processor_architecture=None,
authentication_method=None, radius_server_auth_certificate=None, client_root_certificates=None,
use_legacy=False):
from msrestazure.polling.arm_polling import ARMPolling
params = cmd.get_models('VpnClientParameters')(
processor_architecture=processor_architecture
)
Expand All @@ -3634,11 +3604,9 @@ def generate_vpn_client(cmd, client, resource_group_name, virtual_network_gatewa
params.authentication_method = authentication_method
params.radius_server_auth_certificate = radius_server_auth_certificate
params.client_root_certificates = client_root_certificates
return _generate_vpn_profile(client, resource_group_name, virtual_network_gateway_name, params)

return client.generate_vpn_profile(resource_group_name, virtual_network_gateway_name, params, polling=ARMPolling(lro_options={'final-state-via': 'location'}))
# legacy implementation
return _generatevpnclientpackage(client, resource_group_name, virtual_network_gateway_name, params)

return _legacy_generate_vpn_client(client, resource_group_name, virtual_network_gateway_name, params, polling=ARMPolling(lro_options={'final-state-via': 'location'}))
# endregion


Expand Down
Binary file not shown.
1 change: 0 additions & 1 deletion src/command_modules/azure-cli-network/setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@
'azure-mgmt-trafficmanager==0.50.0',
'azure-mgmt-dns==2.1.0',
'azure-cli-core',
'mock'
]

with open('README.rst', 'r', encoding='utf-8') as f:
Expand Down

0 comments on commit 98c506b

Please sign in to comment.