mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 13:56:09 -07:00 
			
		
		
		
	* Fix to error if validate_cert is True and python doesn't support it. * Only globally disable certificate checking if really needed. Use bigip verify parameter if available instead. * Remove public disable certificate function to make it less likely people will attempt to reuse that
		
			
				
	
	
		
			96 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| # This code is part of Ansible, but is an independent component.
 | |
| # This particular file snippet, and this file snippet only, is BSD licensed.
 | |
| # Modules you write using this snippet, which is embedded dynamically by Ansible
 | |
| # still belong to the author of the module, and may assign their own license
 | |
| # to the complete work.
 | |
| #
 | |
| # Copyright (c), Etienne Carrière <etienne.carriere@gmail.com>,2015
 | |
| # All rights reserved.
 | |
| #
 | |
| # Redistribution and use in source and binary forms, with or without modification,
 | |
| # are permitted provided that the following conditions are met:
 | |
| #
 | |
| #    * Redistributions of source code must retain the above copyright
 | |
| #      notice, this list of conditions and the following disclaimer.
 | |
| #    * Redistributions in binary form must reproduce the above copyright notice,
 | |
| #      this list of conditions and the following disclaimer in the documentation
 | |
| #      and/or other materials provided with the distribution.
 | |
| #
 | |
| # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 | |
| # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 | |
| # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 | |
| # IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 | |
| # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 | |
| # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 | |
| # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 | |
| # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
 | |
| # USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
| 
 | |
| try:
 | |
|     import bigsuds
 | |
| except ImportError:
 | |
|     bigsuds_found = False
 | |
| else:
 | |
|     bigsuds_found = True
 | |
| 
 | |
| 
 | |
| def f5_argument_spec():
 | |
|     return dict(
 | |
|         server=dict(type='str', required=True),
 | |
|         user=dict(type='str', required=True),
 | |
|         password=dict(type='str', aliases=['pass', 'pwd'], required=True, no_log=True),
 | |
|         validate_certs = dict(default='yes', type='bool'),
 | |
|         state = dict(type='str', default='present', choices=['present', 'absent']),
 | |
|         partition = dict(type='str', default='Common')
 | |
|     )
 | |
| 
 | |
| 
 | |
| def f5_parse_arguments(module):
 | |
|     if not bigsuds_found:
 | |
|         module.fail_json(msg="the python bigsuds module is required")
 | |
| 
 | |
|     if module.params['validate_certs']:
 | |
|         import ssl
 | |
|         if not hasattr(ssl, 'SSLContext'):
 | |
|             module.fail_json(msg='bigsuds does not support verifying certificates with python < 2.7.9.  Either update python or set validate_certs=False on the task')
 | |
| 
 | |
|     return (module.params['server'],module.params['user'],module.params['password'],module.params['state'],module.params['partition'],module.params['validate_certs'])
 | |
| 
 | |
| def bigip_api(bigip, user, password, validate_certs):
 | |
|     try:
 | |
|         # bigsuds >= 1.0.3
 | |
|         api = bigsuds.BIGIP(hostname=bigip, username=user, password=password, verify=validate_certs)
 | |
|     except TypeError:
 | |
|         # bigsuds < 1.0.3, no verify param
 | |
|         if validate_certs:
 | |
|             # Note: verified we have SSLContext when we parsed params
 | |
|             api = bigsuds.BIGIP(hostname=bigip, username=user, password=password)
 | |
|         else:
 | |
|             import ssl
 | |
|             if hasattr(ssl, 'SSLContext'):
 | |
|                 # Really, you should never do this.  It disables certificate
 | |
|                 # verification *globally*.  But since older bigip libraries
 | |
|                 # don't give us a way to toggle verification we need to
 | |
|                 # disable it at the global level.
 | |
|                 # From https://www.python.org/dev/peps/pep-0476/#id29
 | |
|                 ssl._create_default_https_context = ssl._create_unverified_context
 | |
|             api = bigsuds.BIGIP(hostname=bigip, username=user, password=password)
 | |
| 
 | |
|     return api
 | |
| 
 | |
| # Fully Qualified name (with the partition)
 | |
| def fq_name(partition,name):
 | |
|     if name is not None and not name.startswith('/'):
 | |
|         return '/%s/%s' % (partition,name)
 | |
|     return name
 | |
| 
 | |
| # Fully Qualified name (with partition) for a list 
 | |
| def fq_list_names(partition,list_names):
 | |
|     if list_names is None:
 | |
|         return None
 | |
|     return map(lambda x: fq_name(partition,x),list_names)
 | |
| 
 | |
| 
 |