From 8ec69e4464ee270b319af821aadacfc587a11f0c Mon Sep 17 00:00:00 2001 From: Ricardo Carrillo Cruz Date: Fri, 11 Jan 2019 11:36:09 +0100 Subject: [PATCH] Checkpoint host facts (#49935) * Add checkpoint_host_facts module * Rebase with devel and add docstrings --- .../checkpoint/checkpoint_host_facts.py | 102 ++++++++++++++++++ 1 file changed, 102 insertions(+) create mode 100644 lib/ansible/modules/network/checkpoint/checkpoint_host_facts.py diff --git a/lib/ansible/modules/network/checkpoint/checkpoint_host_facts.py b/lib/ansible/modules/network/checkpoint/checkpoint_host_facts.py new file mode 100644 index 0000000000..85a63fcb4d --- /dev/null +++ b/lib/ansible/modules/network/checkpoint/checkpoint_host_facts.py @@ -0,0 +1,102 @@ +#!/usr/bin/python +# +# This file is part of Ansible +# +# Ansible is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Ansible is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Ansible. If not, see . +# + + +from __future__ import (absolute_import, division, print_function) +__metaclass__ = type + + +ANSIBLE_METADATA = {'metadata_version': '1.1', + 'status': ['preview'], + 'supported_by': 'network'} + + +DOCUMENTATION = """ +--- +module: checkpoint_host_facts +short_description: Get host objects facts on Checkpoint over Web Services API +description: + - Get host objects facts on Checkpoint devices. + All operations are performed over Web Services API. +version_added: "2.8" +author: "Ansible by Red Hat (@rcarrillocruz)" +options: + name: + description: + - Name of the host object. If name is not provided, UID is required. + type: str + uid: + description: + - UID of the host object. If UID is not provided, name is required. + type: str +""" + +EXAMPLES = """ +- name: Get host object facts + checkpoint_host_facts: + name: attacker +""" + +RETURN = """ +ansible_hosts: + description: The checkpoint host object facts. + returned: always. + type: list +""" + + +from ansible.module_utils.basic import AnsibleModule +from ansible.module_utils.connection import Connection +from ansible.module_utils.six.moves.urllib.error import HTTPError +import json + + +def get_host(module, connection): + name = module.params['name'] + uid = module.params['uid'] + + if uid: + payload = {'uid': uid} + elif name: + payload = {'name': name} + + code, result = connection.send_request('/web_api/show-host', payload) + + return code, result + + +def main(): + argument_spec = dict( + name=dict(type='str'), + uid=dict(type='str'), + ) + + required_one_of = [('name', 'uid')] + module = AnsibleModule(argument_spec=argument_spec, required_one_of=required_one_of) + connection = Connection(module._socket_path) + + code, response = get_host(module, connection) + + if code == 200: + module.exit_json(ansible_facts=dict(checkpoint_hosts=response)) + else: + module.fail_json(msg='Checkpoint device returned error {0} with message {1}'.format(code, response)) + + +if __name__ == '__main__': + main()