Source code for idem_azure.exec.azure.compute.virtual_machines

"""Exec module for managing Compute Virtual Machines."""
from collections import OrderedDict
from typing import Any
from typing import Dict

__func_alias__ = {"list_": "list"}


RESOURCE_TYPE = "compute.virtual_machines"


[docs]async def get( hub, ctx, resource_id: str, name: str = None, raw: bool = False ) -> Dict[str, Any]: """Get compute virtual machines resource from resource_id. Args: resource_id(str): The resource_id of virtual machine name(str, Optional): The name of the resource raw(bool, Optional): Returns raw response if True. Defaults to False Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.get resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.get - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ result = dict(comment=[], result=True, ret=None) uri_parameters = OrderedDict( { "subscriptions": "subscription_id", "resourceGroups": "resource_group_name", "virtualMachines": "virtual_machine_name", } ) api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) response_get = await hub.exec.request.json.get( ctx, url=f"{ctx.acct.endpoint_url}{resource_id}?api-version={api_version}&$expand=instanceView", success_codes=[200], ) if not response_get["result"]: if response_get["status"] != 404: result["result"] = False result["comment"].extend( hub.tool.azure.result_utils.extract_error_comments(response_get) ) return result elif response_get["result"] and response_get["ret"]: if raw: result["ret"] = response_get["ret"] else: uri_parameter_values = hub.tool.azure.uri.get_parameter_value_in_dict( resource_id, uri_parameters ) result[ "ret" ] = hub.tool.azure.compute.virtual_machines.convert_raw_virtual_machine_to_present( resource=response_get["ret"], idem_resource_name=resource_id, resource_id=resource_id, **uri_parameter_values, ) return result
[docs]async def list_(hub, ctx) -> Dict: """List of compute virtual machines Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.list Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.list """ result = dict(comment=[], result=True, ret=[]) subscription_id = ctx.acct.subscription_id uri_parameters = OrderedDict( { "resourceGroups": "resource_group_name", "virtualMachines": "virtual_machine_name", } ) api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) async for page_result in hub.tool.azure.request.paginate( ctx, url=f"{ctx.acct.endpoint_url}/subscriptions/{subscription_id}" f"/providers/Microsoft.Compute/virtualMachines?api-version={api_version}", success_codes=[200], ): resource_list = page_result.get("value") if resource_list: for resource in resource_list: resource_id = resource["id"] uri_parameter_values = hub.tool.azure.uri.get_parameter_value_in_dict( resource_id, uri_parameters ) result["ret"].append( hub.tool.azure.compute.virtual_machines.convert_raw_virtual_machine_to_present( resource=resource, idem_resource_name=resource_id, subscription_id=subscription_id, resource_id=resource_id, **uri_parameter_values, ) ) return result
[docs]async def power_off( hub, ctx, resource_id: str, skip_shutdown: bool = False ) -> Dict[str, Any]: """The operation to power off (stop) a virtual machine. The virtual machine can be restarted with the same provisioned resources. You are still charged for this virtual machine. Args: resource_id(str): The resource_id of virtual machine skip_shutdown(bool, Optional): The parameter to request non-graceful VM shutdown. True value for this flag indicates non-graceful shutdown whereas false indicates otherwise. Default value for this flag is false if not specified Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.power_off resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.power_off - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) result = await hub.tool.azure.generic.exec_request( ctx, resource_id=resource_id, request_method="post", api_method="powerOff", query_params={"skipShutdown": skip_shutdown}, api_version=api_version, resource_idem_path=f"azure.{RESOURCE_TYPE}", ) return result
[docs]async def start(hub, ctx, resource_id: str) -> Dict[str, Any]: """The operation to start a virtual machine. Args: resource_id(str): The resource_id of virtual machine Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.start resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.start - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) result = await hub.tool.azure.generic.exec_request( ctx, resource_id=resource_id, request_method="post", api_method="start", api_version=api_version, resource_idem_path=f"azure.{RESOURCE_TYPE}", ) return result
[docs]async def restart(hub, ctx, resource_id: str) -> Dict[str, Any]: """The operation to restart a virtual machine. Args: resource_id(str): The resource_id of virtual machine Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.restart resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.restart - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) result = await hub.tool.azure.generic.exec_request( ctx, resource_id=resource_id, request_method="post", api_method="restart", api_version=api_version, resource_idem_path=f"azure.{RESOURCE_TYPE}", ) return result
[docs]async def deallocate( hub, ctx, resource_id: str, hibernate: bool = None ) -> Dict[str, Any]: """Shuts down the virtual machine and releases the compute resources. You are not billed for the compute resources that this virtual machine uses. Args: resource_id(str): The resource_id of virtual machine hibernate(bool, Optional): Optional parameter to hibernate a virtual machine. (Feature in Preview) Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.deallocate resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.deallocate - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) result = await hub.tool.azure.generic.exec_request( ctx, resource_id=resource_id, request_method="post", api_method="deallocate", query_params={"hibernate": hibernate}, api_version=api_version, resource_idem_path=f"azure.{RESOURCE_TYPE}", ) return result
[docs]async def perform_maintenance(hub, ctx, resource_id: str) -> Dict[str, Any]: """The operation to perform maintenance on a virtual machine. Args: resource_id(str): The resource_id of virtual machine Returns: Dict[str, Any] Examples: Calling this exec module function from the cli with resource_id: .. code-block:: bash idem exec azure.compute.virtual_machines.perform_maintenance resource_id="value" Using in a state: .. code-block:: yaml my_unmanaged_resource: exec.run: - path: azure.compute.virtual_machines.perform_maintenance - kwargs: resource_id: "/subscriptions/{subscription_id}/resourceGroups/{resource_group_name}/providers/Microsoft.Compute/virtualMachines/{virtual_machine_name}" """ api_version = hub.tool.azure.api_versions.get_api_version(RESOURCE_TYPE) result = await hub.tool.azure.generic.exec_request( ctx, resource_id=resource_id, request_method="post", api_method="performMaintenance", api_version=api_version, resource_idem_path=f"azure.{RESOURCE_TYPE}", ) return result