mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
VMware: Add esxi_hostname option to vmware_host_facts (#47062)
Signed-off-by: Adam Robinson <adarobin@umich.edu>
This commit is contained in:
parent
80e866fc67
commit
b62ba2e424
1 changed files with 35 additions and 5 deletions
|
@ -15,14 +15,15 @@ ANSIBLE_METADATA = {
|
|||
'supported_by': 'community'
|
||||
}
|
||||
|
||||
DOCUMENTATION = '''
|
||||
DOCUMENTATION = r'''
|
||||
---
|
||||
module: vmware_host_facts
|
||||
short_description: Gathers facts about remote ESXi hostsystem
|
||||
description:
|
||||
- This module can be used to gathers facts like CPU, memory, datastore, network and system etc. about ESXi host system.
|
||||
- Please specify hostname or IP address of ESXi host system as C(hostname).
|
||||
- If hostname or IP address of vCenter is provided as C(hostname), then information about first ESXi hostsystem is returned.
|
||||
- If hostname or IP address of vCenter is provided as C(hostname) and C(esxi_hostname) is not specified, then the
|
||||
module will throw an error.
|
||||
- VSAN facts added in 2.7 version.
|
||||
version_added: 2.5
|
||||
author:
|
||||
|
@ -30,10 +31,17 @@ author:
|
|||
requirements:
|
||||
- python >= 2.6
|
||||
- PyVmomi
|
||||
options:
|
||||
esxi_hostname:
|
||||
description:
|
||||
- ESXi hostname.
|
||||
- Host facts about the specified ESXi server will be returned.
|
||||
- By specifying this option, you can select which ESXi hostsystem is returned if connecting to a vCenter.
|
||||
version_added: 2.8
|
||||
extends_documentation_fragment: vmware.documentation
|
||||
'''
|
||||
|
||||
EXAMPLES = '''
|
||||
EXAMPLES = r'''
|
||||
- name: Gather vmware host facts
|
||||
vmware_host_facts:
|
||||
hostname: "{{ esxi_server }}"
|
||||
|
@ -42,6 +50,15 @@ EXAMPLES = '''
|
|||
register: host_facts
|
||||
delegate_to: localhost
|
||||
|
||||
- name: Gather vmware host facts from vCenter
|
||||
vmware_host_facts:
|
||||
hostname: "{{ vcenter_server }}"
|
||||
username: "{{ vcenter_user }}"
|
||||
password: "{{ vcenter_pass }}"
|
||||
esxi_hostname: "{{ esxi_hostname }}"
|
||||
register: host_facts
|
||||
delegate_to: localhost
|
||||
|
||||
- name: Get VSAN Cluster UUID from host facts
|
||||
vmware_host_facts:
|
||||
hostname: "{{ esxi_server }}"
|
||||
|
@ -52,7 +69,7 @@ EXAMPLES = '''
|
|||
cluster_uuid: "{{ host_facts['ansible_facts']['vsan_cluster_uuid'] }}"
|
||||
'''
|
||||
|
||||
RETURN = '''
|
||||
RETURN = r'''
|
||||
ansible_facts:
|
||||
description: system info about the host machine
|
||||
returned: always
|
||||
|
@ -115,7 +132,17 @@ except ImportError:
|
|||
class VMwareHostFactManager(PyVmomi):
|
||||
def __init__(self, module):
|
||||
super(VMwareHostFactManager, self).__init__(module)
|
||||
self.host = find_obj(self.content, [vim.HostSystem], None)
|
||||
esxi_host_name = self.params.get('esxi_hostname', None)
|
||||
if self.is_vcenter():
|
||||
if esxi_host_name is None:
|
||||
self.module.fail_json(msg="Connected to a vCenter system without specifying esxi_hostname")
|
||||
self.host = self.get_all_host_objs(esxi_host_name=esxi_host_name)
|
||||
if len(self.host) > 1:
|
||||
self.module.fail_json(msg="esxi_hostname matched multiple hosts")
|
||||
self.host = self.host[0]
|
||||
else:
|
||||
self.host = find_obj(self.content, [vim.HostSystem], None)
|
||||
|
||||
if self.host is None:
|
||||
self.module.fail_json(msg="Failed to find host system.")
|
||||
|
||||
|
@ -213,6 +240,9 @@ class VMwareHostFactManager(PyVmomi):
|
|||
|
||||
def main():
|
||||
argument_spec = vmware_argument_spec()
|
||||
argument_spec.update(
|
||||
esxi_hostname=dict(type='str', required=False),
|
||||
)
|
||||
module = AnsibleModule(argument_spec=argument_spec,
|
||||
supports_check_mode=True)
|
||||
|
||||
|
|
Loading…
Reference in a new issue