mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 21:44:00 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #
 | |
| # Copyright (c) 2019, Sandeep Kasargod <sandeep@vexata.com>
 | |
| # Simplified BSD License (see LICENSES/BSD-2-Clause.txt or https://opensource.org/licenses/BSD-2-Clause)
 | |
| # SPDX-License-Identifier: BSD-2-Clause
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| 
 | |
| HAS_VEXATAPI = True
 | |
| try:
 | |
|     from vexatapi.vexata_api_proxy import VexataAPIProxy
 | |
| except ImportError:
 | |
|     HAS_VEXATAPI = False
 | |
| 
 | |
| from ansible.module_utils.basic import env_fallback
 | |
| 
 | |
| VXOS_VERSION = None
 | |
| 
 | |
| 
 | |
| def get_version(iocs_json):
 | |
|     if not iocs_json:
 | |
|         raise Exception('Invalid IOC json')
 | |
|     active = [x for x in iocs_json if x['mgmtRole']]
 | |
|     if not active:
 | |
|         raise Exception('Unable to detect active IOC')
 | |
|     active = active[0]
 | |
|     ver = active['swVersion']
 | |
|     if ver[0] != 'v':
 | |
|         raise Exception('Illegal version string')
 | |
|     ver = ver[1:ver.find('-')]
 | |
|     ver = map(int, ver.split('.'))
 | |
|     return tuple(ver)
 | |
| 
 | |
| 
 | |
| def get_array(module):
 | |
|     """Return storage array object or fail"""
 | |
|     global VXOS_VERSION
 | |
|     array = module.params['array']
 | |
|     user = module.params.get('user', None)
 | |
|     password = module.params.get('password', None)
 | |
|     validate = module.params.get('validate_certs')
 | |
| 
 | |
|     if not HAS_VEXATAPI:
 | |
|         module.fail_json(msg='vexatapi library is required for this module. '
 | |
|                              'To install, use `pip install vexatapi`')
 | |
| 
 | |
|     if user and password:
 | |
|         system = VexataAPIProxy(array, user, password, verify_cert=validate)
 | |
|     else:
 | |
|         module.fail_json(msg='The user/password are required to be passed in to '
 | |
|                              'the module as arguments or by setting the '
 | |
|                              'VEXATA_USER and VEXATA_PASSWORD environment variables.')
 | |
|     try:
 | |
|         if system.test_connection():
 | |
|             VXOS_VERSION = get_version(system.iocs())
 | |
|             return system
 | |
|         else:
 | |
|             module.fail_json(msg='Test connection to array failed.')
 | |
|     except Exception as e:
 | |
|         module.fail_json(msg=f'Vexata API access failed: {e}')
 | |
| 
 | |
| 
 | |
| def argument_spec():
 | |
|     """Return standard base dictionary used for the argument_spec argument in AnsibleModule"""
 | |
|     return dict(
 | |
|         array=dict(type='str',
 | |
|                    required=True),
 | |
|         user=dict(type='str',
 | |
|                   fallback=(env_fallback, ['VEXATA_USER'])),
 | |
|         password=dict(type='str',
 | |
|                       no_log=True,
 | |
|                       fallback=(env_fallback, ['VEXATA_PASSWORD'])),
 | |
|         validate_certs=dict(type='bool',
 | |
|                             required=False,
 | |
|                             default=False),
 | |
|     )
 | |
| 
 | |
| 
 | |
| def required_together():
 | |
|     """Return the default list used for the required_together argument to AnsibleModule"""
 | |
|     return [['user', 'password']]
 | |
| 
 | |
| 
 | |
| def size_to_MiB(size):
 | |
|     """Convert a '<integer>[MGT]' string to MiB, return -1 on error."""
 | |
|     quant = size[:-1]
 | |
|     exponent = size[-1]
 | |
|     if not quant.isdigit() or exponent not in 'MGT':
 | |
|         return -1
 | |
|     quant = int(quant)
 | |
|     if exponent == 'G':
 | |
|         quant <<= 10
 | |
|     elif exponent == 'T':
 | |
|         quant <<= 20
 | |
|     return quant
 |