docker_node_facts: Query may cover single or multiple nodes (#51701)

* docker_node_facts: Query may contain single or multiple nodes, additional option to query about the docker manager itself
docker_node_facts: Code update to use the module_utils/docker_swarm.py AnsibleDockerSwarmClient class methods

* docker_node_facts: Minor documentation update and error handling

* docker_node_facts: Minor documentation and code updates

* docker_node_facts: Minor documentation adjustments
This commit is contained in:
Piotr Wojciechowski 2019-02-12 06:58:07 +01:00 committed by ansibot
parent 179cbb9891
commit ea72f7001c

View file

@ -11,7 +11,6 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
'status': ['preview'], 'status': ['preview'],
'supported_by': 'community'} 'supported_by': 'community'}
DOCUMENTATION = ''' DOCUMENTATION = '''
--- ---
module: docker_node_facts module: docker_node_facts
@ -29,8 +28,20 @@ options:
name: name:
description: description:
- The name of the node to inspect. - The name of the node to inspect.
- When identifying an existing node name may either the hostname of the node (as registered in Swarm) or node ID. - The list of nodes names to inspect.
required: true - If empty then return information of all nodes in Swarm cluster.
- When identifying the node use either the hostname of the node (as registered in Swarm) or node ID.
- If I(self) is C(true) then this parameter is ignored.
required: false
type: list
self:
description:
- If C(true), queries the node (i.e. the docker daemon) the module communicates with.
- If C(true) then I(name) is ignored.
- If C(false) then query depends on I(name) presence and value.
required: false
type: bool
default: false
extends_documentation_fragment: extends_documentation_fragment:
- docker - docker
- docker.docker_py_1_documentation - docker.docker_py_1_documentation
@ -44,31 +55,40 @@ requirements:
''' '''
EXAMPLES = ''' EXAMPLES = '''
- name: Get info on all nodes
docker_node_facts:
register: result
- name: Get info on node - name: Get info on node
docker_node_facts: docker_node_facts:
name: mynode name: mynode
register: result register: result
- name: Get info on list of nodes
docker_node_facts:
name:
- mynode1
- mynode2
register: result
- name: Get info on host if it is Swarm Manager
docker_node_facts:
self: true
register: result
''' '''
RETURN = ''' RETURN = '''
exists: nodes_facts:
description: description:
- Returns whether the node exists in docker swarm cluster. - Facts representing the current state of the nodes. Matches the C(docker node inspect) output.
type: bool - Can contain multiple entries if more than one node provided in I(name), or I(name) is not provided.
- If I(name) contains a list of nodes, the output will provide information on all nodes registered
at the swarm, including nodes that left the swarm but haven't been removed from the cluster on swarm
managers and nodes that are unreachable.
returned: always returned: always
sample: true type: list
node_facts:
description:
- Facts representing the current state of the node. Matches the C(docker node inspect) output.
- Will be C(None) if node does not exist.
returned: always
type: dict
''' '''
from ansible.module_utils._text import to_native
from ansible.module_utils.docker.swarm import AnsibleDockerSwarmClient from ansible.module_utils.docker.swarm import AnsibleDockerSwarmClient
try: try:
@ -78,22 +98,35 @@ except ImportError:
pass pass
def get_node_facts(client, name): def get_node_facts(client):
try:
return client.inspect_node(name) results = []
except NotFound:
return None if client.module.params['self'] is True:
except APIError as exc: self_node_id = client.get_swarm_node_id()
if exc.status_code == 503: node_info = client.get_node_inspect(node_id=self_node_id)
client.fail(msg="Cannot inspect node: To inspect node execute module on Swarm Manager") results.append(node_info)
client.fail(msg="Error while reading from Swarm manager: %s" % to_native(exc)) return results
except Exception as exc:
client.module.fail_json(msg="Error inspecting swarm node: %s" % exc) if client.module.params['name'] is None:
node_info = client.get_all_nodes_inspect()
return node_info
nodes = client.module.params['name']
if not isinstance(nodes, list):
nodes = [nodes]
for next_node_name in nodes:
next_node_info = client.get_node_inspect(node_id=next_node_name, skip_missing=True)
if next_node_info:
results.append(next_node_info)
return results
def main(): def main():
argument_spec = dict( argument_spec = dict(
name=dict(type='str', required=True), name=dict(type='list', elements='str'),
self=dict(type='bool', default='False'),
) )
client = AnsibleDockerSwarmClient( client = AnsibleDockerSwarmClient(
@ -103,12 +136,13 @@ def main():
min_docker_api_version='1.24', min_docker_api_version='1.24',
) )
node = get_node_facts(client, client.module.params['name']) client.fail_task_if_not_swarm_manager()
node = get_node_facts(client)
client.module.exit_json( client.module.exit_json(
changed=False, changed=False,
exists=(True if node else False), nodes_facts=node,
node_facts=node,
) )