mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2024-09-14 20:13:21 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			140 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # Copyright (c) 2018 Red Hat, Inc.
 | |
| # 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
 | |
| 
 | |
| DOCUMENTATION = '''
 | |
| ---
 | |
| module: nios_dns_view
 | |
| author: "Peter Sprygada (@privateip)"
 | |
| short_description: Configure Infoblox NIOS DNS views
 | |
| description:
 | |
|   - Adds and/or removes instances of DNS view objects from
 | |
|     Infoblox NIOS servers.  This module manages NIOS C(view) objects
 | |
|     using the Infoblox WAPI interface over REST.
 | |
|   - Updates instances of DNS view object from Infoblox NIOS servers.
 | |
| requirements:
 | |
|   - infoblox-client
 | |
| extends_documentation_fragment:
 | |
| - community.general.nios
 | |
| 
 | |
| options:
 | |
|   name:
 | |
|     description:
 | |
|       - Specifies the fully qualified hostname to add or remove from
 | |
|         the system. User can also update the hostname as it is possible
 | |
|         to pass a dict containing I(new_name), I(old_name). See examples.
 | |
|     required: true
 | |
|     aliases:
 | |
|       - view
 | |
|   network_view:
 | |
|     description:
 | |
|       - Specifies the name of the network view to assign the configured
 | |
|         DNS view to.  The network view must already be configured on the
 | |
|         target system.
 | |
|     required: true
 | |
|     default: default
 | |
|   extattrs:
 | |
|     description:
 | |
|       - Allows for the configuration of Extensible Attributes on the
 | |
|         instance of the object.  This argument accepts a set of key / value
 | |
|         pairs for configuration.
 | |
|     required: false
 | |
|   comment:
 | |
|     description:
 | |
|       - Configures a text string comment to be associated with the instance
 | |
|         of this object.  The provided text string will be configured on the
 | |
|         object instance.
 | |
|     required: false
 | |
|   state:
 | |
|     description:
 | |
|       - Configures the intended state of the instance of the object on
 | |
|         the NIOS server.  When this value is set to C(present), the object
 | |
|         is configured on the device and when this value is set to C(absent)
 | |
|         the value is removed (if necessary) from the device.
 | |
|     required: false
 | |
|     default: present
 | |
|     choices:
 | |
|       - present
 | |
|       - absent
 | |
| '''
 | |
| 
 | |
| EXAMPLES = '''
 | |
| - name: Configure a new dns view instance
 | |
|   nios_dns_view:
 | |
|     name: ansible-dns
 | |
|     state: present
 | |
|     provider:
 | |
|       host: "{{ inventory_hostname_short }}"
 | |
|       username: admin
 | |
|       password: admin
 | |
|   connection: local
 | |
| - name: Update the comment for dns view
 | |
|   nios_dns_view:
 | |
|     name: ansible-dns
 | |
|     comment: this is an example comment
 | |
|     state: present
 | |
|     provider:
 | |
|       host: "{{ inventory_hostname_short }}"
 | |
|       username: admin
 | |
|       password: admin
 | |
|   connection: local
 | |
| - name: Remove the dns view instance
 | |
|   nios_dns_view:
 | |
|     name: ansible-dns
 | |
|     state: absent
 | |
|     provider:
 | |
|       host: "{{ inventory_hostname_short }}"
 | |
|       username: admin
 | |
|       password: admin
 | |
|   connection: local
 | |
| - name: Update the dns view instance
 | |
|   nios_dns_view:
 | |
|     name: {new_name: ansible-dns-new, old_name: ansible-dns}
 | |
|     state: present
 | |
|     provider:
 | |
|       host: "{{ inventory_hostname_short }}"
 | |
|       username: admin
 | |
|       password: admin
 | |
|   connection: local
 | |
| '''
 | |
| 
 | |
| RETURN = ''' # '''
 | |
| 
 | |
| from ansible.module_utils.basic import AnsibleModule
 | |
| from ansible_collections.community.general.plugins.module_utils.net_tools.nios.api import WapiModule
 | |
| from ansible_collections.community.general.plugins.module_utils.net_tools.nios.api import NIOS_DNS_VIEW
 | |
| 
 | |
| 
 | |
| def main():
 | |
|     ''' Main entry point for module execution
 | |
|     '''
 | |
|     ib_spec = dict(
 | |
|         name=dict(required=True, aliases=['view'], ib_req=True),
 | |
|         network_view=dict(default='default', ib_req=True),
 | |
| 
 | |
|         extattrs=dict(type='dict'),
 | |
|         comment=dict()
 | |
|     )
 | |
| 
 | |
|     argument_spec = dict(
 | |
|         provider=dict(required=True),
 | |
|         state=dict(default='present', choices=['present', 'absent'])
 | |
|     )
 | |
| 
 | |
|     argument_spec.update(ib_spec)
 | |
|     argument_spec.update(WapiModule.provider_spec)
 | |
| 
 | |
|     module = AnsibleModule(argument_spec=argument_spec,
 | |
|                            supports_check_mode=True)
 | |
| 
 | |
|     wapi = WapiModule(module)
 | |
|     result = wapi.run(NIOS_DNS_VIEW, ib_spec)
 | |
| 
 | |
|     module.exit_json(**result)
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     main()
 |