Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Code generation from magic-module-specs#88 for Ansible #98

Open
wants to merge 4 commits into
base: devel
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 21 additions & 13 deletions lib/ansible/modules/cloud/azure/azure_rm_batchaccount.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@
# This file is automatically generated by Magic Modules and manual
# changes will be clobbered when the file is regenerated.
#
# Please read more about how to change this file at
# https://github.com/Azure/magic-module-specs
#
# ----------------------------------------------------------------------------

Expand All @@ -37,31 +39,37 @@
description:
- The name of the resource group in which to create the Batch Account.
required: true
type: str
name:
description:
- The name of the Batch Account.
required: true
type: str
location:
description:
- Specifies the supported Azure location where the resource exists.
type: str
auto_storage_account:
description:
- Existing storage account with which to associate the Batch Account.
- It can be the storage account name which is in the same resource group.
- "It can be the storage account ID. e.g.,
/subscriptions/{subscription_id}/resourceGroups/{resource_group}/providers/Microsoft.Storage/storageAccounts/{name}."
/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Storage/storageAccounts/mystorageaccount."
- It can be a dict which contains C(name) and C(resource_group) of the storage account.
type: raw
key_vault:
description:
- Existing key vault with which to associate the Batch Account.
- It can be the key vault name which is in the same resource group.
- "It can be the key vault ID. e.g.,
/subscriptions/{subscription_id}/resourceGroups/{resource_group}/providers/Microsoft.KeyVault/vaults/{name}."
/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.KeyVault/vaults/myKeyVault."
- It can be a dict which contains C(name) and C(resource_group) of the key vault.
type: raw
pool_allocation_mode:
description:
- The pool acclocation mode of the Batch Account.
default: batch_service
type: str
choices:
- batch_service
- user_subscription
Expand All @@ -79,13 +87,13 @@
- azure_tags

author:
- "Junyi Yi (@JunyiYi)"
- Junyi Yi (@JunyiYi)
'''

EXAMPLES = '''
- name: Create Batch Account
azure_rm_batchaccount:
resource_group: MyResGroup
resource_group: MyResourceGroup
name: mybatchaccount
location: eastus
auto_storage_account:
Expand All @@ -99,7 +107,7 @@
- The ID of the Batch account.
returned: always
type: str
sample: "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Batch/batchAccounts/sampleacct"
sample: "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Batch/batchAccounts/mybatchaccount"
account_endpoint:
description:
- The account endpoint used to interact with the Batch service.
Expand Down Expand Up @@ -200,14 +208,14 @@ def exec_module(self, **kwargs):
self.batch_account.pop('auto_storage_account'),
'/subscriptions/{subscription_id}/resourceGroups/{resource_group}/providers/Microsoft.Storage/storageAccounts/{name}')
}
if self.batch_account.get('key_vault') is not None:
id = self.normalize_resource_id(
self.batch_account.pop('key_vault'),
'/subscriptions/{subscription_id}/resourceGroups/{resource_group}/providers/Microsoft.KeyVault/vaults/{name}')
url = 'https://' + id.split('/').pop() + '.vault.azure.net/'
self.batch_account['key_vault_reference'] = {
'id': id,
'url': url
if self.batch_account.get('key_vault') is not None:
id = self.normalize_resource_id(
self.batch_account.pop('key_vault'),
'/subscriptions/{subscription_id}/resourceGroups/{resource_group}/providers/Microsoft.KeyVault/vaults/{name}')
url = 'https://' + id.split('/').pop() + '.vault.azure.net/'
self.batch_account['key_vault_reference'] = {
'id': id,
'url': url
}
self.batch_account['pool_allocation_mode'] = _snake_to_camel(self.batch_account['pool_allocation_mode'], True)

Expand Down
253 changes: 253 additions & 0 deletions lib/ansible/modules/cloud/azure/azure_rm_batchaccount_info.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,253 @@
#!/usr/bin/python
#
# Copyright (C) 2019 Junyi Yi (@JunyiYi)
#
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)

# ----------------------------------------------------------------------------
#
# *** AUTO GENERATED CODE *** AUTO GENERATED CODE ***
#
# ----------------------------------------------------------------------------
#
# This file is automatically generated by Magic Modules and manual
# changes will be clobbered when the file is regenerated.
#
# Please read more about how to change this file at
# https://github.com/Azure/magic-module-specs
#
# ----------------------------------------------------------------------------

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_batchaccount_info
version_added: "2.9"
short_description: Gather info for Azure Batch Account
description:
- Gather info for Azure Batch Account.

options:
resource_group:
description:
- The name of the resource group in which to create the Batch Account.
required: true
type: str
name:
description:
- The name of the Batch Account.
type: str
tags:
description:
- Limit results by providing a list of tags. Format tags as 'key' or 'key:value'.
type: list

extends_documentation_fragment:
- azure

author:
- Junyi Yi (@JunyiYi)
'''

EXAMPLES = '''
- name: Get instance of Batch Account
azure_rm_batchaccount_info:
resource_group: MyResourceGroup
name: mybatchaccount

- name: List instances of Batch Account
azure_rm_batchaccount_info:
resource_group: MyResourceGroup
'''

RETURN = '''
items:
description:
- List of items.
returned: always
type: complex
contains:
id:
description:
- The ID of the Batch account.
returned: always
type: str
sample: "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Batch/batchAccounts/mybatchaccount"
resource_group:
description:
- The name of the resource group in which to create the Batch Account.
returned: always
type: str
sample: myResourceGroup
name:
description:
- The name of the Batch Account.
returned: always
type: str
sample: mybatchaccount
location:
description:
- Specifies the supported Azure location where the resource exists.
returned: always
type: str
sample: eastus
account_endpoint:
description:
- The account endpoint used to interact with the Batch service.
returned: always
type: str
sample: sampleacct.westus.batch.azure.com
auto_storage_account:
description:
- Existing storage account with which to associate the Batch Account.
returned: always
type: str
sample:
"/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.Storage/storageAccounts/mystorageaccount"
key_vault:
description:
- Existing key vault with which to associate the Batch Account.
returned: always
type: str
sample: "/subscriptions/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/resourceGroups/myResourceGroup/providers/Microsoft.KeyVault/vaults/myKeyVault"
pool_allocation_mode:
description:
- The pool acclocation mode of the Batch Account.
returned: always
type: str
sample: batch_service
tags:
description:
- Resource tags.
returned: always
type: dict
sample: "{ 'key1': 'value1', 'key2': 'value2' }"
'''

from ansible.module_utils.azure_rm_common import AzureRMModuleBase
from ansible.module_utils.common.dict_transformations import _camel_to_snake

try:
from msrestazure.azure_exceptions import CloudError
from azure.mgmt.batch import BatchManagementClient
from msrest.serialization import Model
except ImportError:
# This is handled in azure_rm_common
pass


class AzureRMBatchAccountInfo(AzureRMModuleBase):
def __init__(self):
# define user inputs into argument
self.module_arg_spec = dict(
resource_group=dict(
required=True,
type='str'
),
name=dict(
type='str'
),
tags=dict(
type='list'
)
)
# store the results of the module operation
self.results = dict(
changed=False
)
self.mgmt_client = None
self.resource_group = None
self.name = None
self.tags = None
super(AzureRMBatchAccountInfo, self).__init__(self.module_arg_spec, supports_tags=False)

def exec_module(self, **kwargs):
for key in self.module_arg_spec:
setattr(self, key, kwargs[key])
self.mgmt_client = self.get_mgmt_svc_client(BatchManagementClient,
base_url=self._cloud_environment.endpoints.resource_manager)

if self.resource_group is not None and self.name is not None:
self.results['items'] = self.get()
elif self.resource_group is not None:
self.results['items'] = self.list_by_resource_group()
else:
self.results['items'] = self.list_by_subscription()
return self.results

def get(self):
response = None
results = []
try:
response = self.mgmt_client.batch_account.get(resource_group_name=self.resource_group,
account_name=self.name)
self.log("Response : {0}".format(response))
except CloudError as e:
self.log('Could not get info for Batch Account.')

if response and self.has_tags(response.tags, self.tags):
results.append(self.format_response(response))

return results

def list_by_resource_group(self):
response = None
results = []
try:
response = self.mgmt_client.batch_account.list_by_resource_group(resource_group_name=self.resource_group)
self.log("Response : {0}".format(response))
except CloudError as e:
self.log('Could not get info for Batch Account.')

if response is not None:
for item in response:
if self.has_tags(item.tags, self.tags):
results.append(self.format_response(item))

return results

def list_by_subscription(self):
response = None
results = []
try:
response = self.mgmt_client.batch_account.list()
self.log("Response : {0}".format(response))
except CloudError as e:
self.log('Could not get info for Batch Account.')

if response is not None:
for item in response:
if self.has_tags(item.tags, self.tags):
results.append(self.format_response(item))

return results

def format_response(self, item):
d = item.as_dict()
d = {
'id': d.get('id'),
'resource_group': self.resource_group,
'name': d.get('name'),
'location': d.get('location'),
'account_endpoint': d.get('account_endpoint'),
'auto_storage_account': d.get('auto_storage', {}).get('storage_account_id'),
'key_vault': d.get('key_vault_reference', {}).get('id'),
'pool_allocation_mode': _camel_to_snake(d.get('pool_allocation_mode')),
'tags': d.get('tags'),
}
return d


def main():
AzureRMBatchAccountInfo()


if __name__ == "__main__":
main()
Loading