From 79f9fc415d9d7b3096a9f5f5b10c5e8a3d9aa340 Mon Sep 17 00:00:00 2001 From: Yunge Zhu <37337818+yungezz@users.noreply.github.com> Date: Tue, 19 Feb 2019 12:43:23 +0800 Subject: [PATCH] add redis cache facts (#48652) --- .../cloud/azure/azure_rm_rediscache_facts.py | 333 ++++++++++++++++++ .../targets/azure_rm_rediscache/aliases | 1 + .../azure_rm_rediscache/tasks/main.yml | 33 +- 3 files changed, 366 insertions(+), 1 deletion(-) create mode 100644 lib/ansible/modules/cloud/azure/azure_rm_rediscache_facts.py diff --git a/lib/ansible/modules/cloud/azure/azure_rm_rediscache_facts.py b/lib/ansible/modules/cloud/azure/azure_rm_rediscache_facts.py new file mode 100644 index 0000000000..089e87efd5 --- /dev/null +++ b/lib/ansible/modules/cloud/azure/azure_rm_rediscache_facts.py @@ -0,0 +1,333 @@ +#!/usr/bin/python +# +# Copyright (c) 2018 Yunge Zhu +# +# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) + +from __future__ import absolute_import, division, print_function +__metaclass__ = type + + +ANSIBLE_METADATA = {'metadata_version': '1.1', + 'status': ['preview'], + 'supported_by': 'community'} + +DOCUMENTATION = ''' +--- +module: azure_rm_rediscache_facts + +version_added: "2.8" + +short_description: Get Azure Redis Cache instance facts + +description: + - Get facts for Azure Redis Cache instance. + +options: + resource_group: + description: + - The resource group to search for the desired Azure Redis Cache + required: True + name: + description: + - Limit results to a specific Azure Redis Cache. + return_access_keys: + description: + - Indicate weather to return access keys of the Redis Cache. + default: False + type: bool + tags: + description: + - Limit results by providing a list of tags. Format tags as 'key' or 'key:value'. + +extends_documentation_fragment: + - azure + +author: + - "Yunge Zhu (@yungezz)" +''' + +EXAMPLES = ''' + - name: Get Redis Cache by name + azure_rm_rediscache_facts: + resource_group: myResourceGroup + name: myRedis + + - name: Get Redis Cache with access keys by name + azure_rm_rediscache_facts: + resource_group: myResourceGroup + name: myRedis + return_access_keys: true + + - name: Get Redis Cache in specific resource group + azure_rm_rediscache_facts: + resource_group: myResourceGroup +''' + +RETURN = ''' +rediscaches: + description: List of Azure Redis Cache instances. + returned: always + type: complex + contains: + resource_group: + description: + - Name of a resource group where the Azure Redis Cache belongs to. + returned: always + type: str + sample: testGroup + name: + description: + - Name of the Azure Redis Cache. + returned: always + type: str + sample: testRedis + id: + description: + - Id of the Azure Redis Cache. + returned: always + type: str + sample: /subscriptions//resourceGroups/myResourceGroup/providers/Microsoft.Cache/Redis/myRedis + provisioning_state: + description: + - Provisioning state of the redis cahe + returned: always + type: str + sample: Creating + location: + description: + - Location of the Azure Redis Cache. + type: str + sample: WestUS + enable_non_ssl_port: + description: + - Specifies whether the non-ssl Redis server port (6379) is enabled. + type: bool + sample: false + sku: + description: + - Dict of sku information. + type: dict + contains: + name: + description: Name of the sku. + returned: always + type: str + sample: standard + size: + description: Size of the Redis Cache. + returned: always + type: str + sample: C1 + static_ip: + description: + - Static IP address. + type: str + sample: 10.75.0.11 + subnet: + description: + - The full resource ID of a subnet in a virtual network to deploy the Redis cache in. + type: str + sample: + - /subscriptions//resourceGroups/myResourceGroup/Microsoft.Network|ClassicNetwork/VirtualNetworks/vnet1/subnets/subnet1 + configuration: + description: + - Dict of redis configuration. + type: dict + sample: maxmeory_reserved + host_name: + description: + - Redis host name. + type: str + sample: testRedis.redis.cache.windows.net + shard_count: + description: + - The number of shards on a Premium Cluster Cache. + type: int + sample: 1 + tenant_settings: + description: + - Dict of tenant settings. + type: dict + tags: + description: + - List of tags. + type: list + sample: + - foo + access_keys: + description: + - Redis cache access keys. + type: dict + returned: when C(return_access_keys) is true. + contains: + primary: + description: The current primary key that clients can use to authenticate the redis cahce. + type: str + sample: X2xXXxx7xxxxxx5xxxx0xxxxx75xxxxxxxxXXXxxxxx= + secondary: + description: The current secondary key that clients can use to authenticate the redis cahce. + type: str + sample: X2xXXxx7xxxxxx5xxxx0xxxxx75xxxxxxxxXXXxxxxx= +''' + +from ansible.module_utils.azure_rm_common import AzureRMModuleBase + +try: + from azure.common import AzureHttpError + from azure.mgmt.redis import RedisManagementClient + from msrestazure.azure_exceptions import CloudError +except ImportError: + # handled in azure_rm_common + pass + +import re + + +class AzureRMRedisCacheFacts(AzureRMModuleBase): + """Utility class to get Azure Azure Redis cache facts""" + + def __init__(self): + + self.module_args = dict( + name=dict(type='str'), + resource_group=dict( + type='str', + required=True + ), + return_access_keys=dict( + type='bool', + default=False + ), + tags=dict(type='list') + ) + + self.results = dict( + changed=False, + rediscaches=[] + ) + + self.name = None + self.resource_group = None + self.profile_name = None + self.tags = None + + self._client = None + + super(AzureRMRedisCacheFacts, self).__init__( + derived_arg_spec=self.module_args, + supports_tags=False, + facts_module=True + ) + + def exec_module(self, **kwargs): + + for key in self.module_args: + setattr(self, key, kwargs[key]) + + # get management client + self._client = self.get_mgmt_svc_client(RedisManagementClient, + base_url=self._cloud_environment.endpoints.resource_manager, + api_version='2018-03-01') + + if self.name: + self.results['rediscaches'] = self.get_item() + else: + self.results['rediscaches'] = self.list_by_resourcegroup() + + return self.results + + def get_item(self): + """Get a single Azure Redis Cache""" + + self.log('Get properties for {0}'.format(self.name)) + + item = None + result = [] + + try: + item = self._client.redis.get(resource_group_name=self.resource_group, name=self.name) + except CloudError: + pass + + if item and self.has_tags(item.tags, self.tags): + result = [self.serialize_rediscache(item)] + + return result + + def list_by_resourcegroup(self): + """Get all Azure Azure Redis Cache within a resource group""" + + self.log('List all Azure Redis Cache within a resource group') + + try: + response = self._client.redis.list_by_resource_group(self.resource_group) + except CloudError as exc: + self.fail('Failed to list all items - {0}'.format(str(exc))) + + results = [] + for item in response: + if self.has_tags(item.tags, self.tags): + results.append(self.serialize_rediscache(item)) + + return results + + def list_keys(self): + """List Azure Redis Cache keys""" + + self.log('List keys for {0}'.format(self.name)) + + item = None + + try: + item = self._client.redis.list_keys(resource_group_name=self.resource_group, name=self.name) + except CloudError as exc: + self.fail("Failed to list redis keys of {0} - {1}".format(self.name, str(exc))) + + return item + + def serialize_rediscache(self, rediscache): + ''' + Convert a Azure Redis Cache object to dict. + :param cdn: Azure Redis Cache object + :return: dict + ''' + new_result = dict( + id=rediscache.id, + resource_group=re.sub('\\/.*', '', re.sub('.*resourceGroups\\/', '', rediscache.id)), + name=rediscache.name, + location=rediscache.location, + provisioning_state=rediscache.provisioning_state, + configuration=rediscache.redis_configuration, + tenant_settings=rediscache.tenant_settings, + shard_count=rediscache.shard_count, + enable_non_ssl_port=rediscache.enable_non_ssl_port, + static_ip=rediscache.static_ip, + subnet=rediscache.subnet_id, + host_name=rediscache.host_name, + tags=rediscache.tags + ) + + if rediscache.sku: + new_result['sku'] = dict( + name=rediscache.sku.name.lower(), + size=rediscache.sku.family + str(rediscache.sku.capacity) + ) + if self.return_access_keys: + access_keys = self.list_keys() + if access_keys: + new_result['access_keys'] = dict( + primary=access_keys.primary_key, + secondary=access_keys.secondary_key + ) + return new_result + + +def main(): + """Main module execution code path""" + + AzureRMRedisCacheFacts() + + +if __name__ == '__main__': + main() diff --git a/test/integration/targets/azure_rm_rediscache/aliases b/test/integration/targets/azure_rm_rediscache/aliases index 8f7a9a2e56..fee20e3d09 100644 --- a/test/integration/targets/azure_rm_rediscache/aliases +++ b/test/integration/targets/azure_rm_rediscache/aliases @@ -1,3 +1,4 @@ cloud/azure shippable/azure/group1 destructive +azure_rm_rediscache_facts \ No newline at end of file diff --git a/test/integration/targets/azure_rm_rediscache/tasks/main.yml b/test/integration/targets/azure_rm_rediscache/tasks/main.yml index 01cb1969ac..5081a17333 100644 --- a/test/integration/targets/azure_rm_rediscache/tasks/main.yml +++ b/test/integration/targets/azure_rm_rediscache/tasks/main.yml @@ -29,12 +29,29 @@ size: C1 register: output -- name: Assert creating redis cache check mode +- name: Assert creating redis cache assert: that: - output.changed - output.id +- name: Get facts + azure_rm_rediscache_facts: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}" + register: facts + +- name: Assert facts + assert: + that: + - facts.rediscaches | length == 1 + - facts.rediscaches[0].id != None + - facts.rediscaches[0].host_name != None + - facts.rediscaches[0].provisioning_state != None + - facts.rediscaches[0].sku.name == 'basic' + - facts.rediscaches[0].sku.size == 'C1' + + - name: Update the redis cache (idempotent) azure_rm_rediscache: resource_group: "{{ resource_group }}" @@ -159,6 +176,20 @@ - output.changed - output.id +- name: Get facts + azure_rm_rediscache_facts: + resource_group: "{{ resource_group }}" + name: "{{ redis_name }}2" + return_access_keys: True + register: facts + +- name: Assert facts + assert: + that: + - facts.rediscaches | length == 1 + - facts.rediscaches[0].subnet != None + - facts.rediscaches[0].access_keys.primary != None + # - name: Delete the redis cache # azure_rm_rediscache: # resource_group: "{{ resource_group }}"