1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
# (c) 2019 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 = """
---
author: Ansible Security Team (@ansible-security)
name: qradar
short_description: HttpApi Plugin for IBM QRadar
description:
- This HttpApi plugin provides methods to connect to IBM QRadar over a
HTTP(S)-based api.
version_added: "1.0.0"
"""
import json
from ansible.module_utils.basic import to_text
from ansible.module_utils.six.moves.urllib.error import HTTPError
from ansible_collections.ansible.netcommon.plugins.plugin_utils.httpapi_base import (
HttpApiBase,
)
from ansible.module_utils.connection import ConnectionError
from ansible_collections.ibm.qradar.plugins.module_utils.qradar import (
BASE_HEADERS,
)
class HttpApi(HttpApiBase):
def send_request(self, request_method, path, payload=None, headers=None):
headers = headers if headers else BASE_HEADERS
try:
self._display_request(request_method)
response, response_data = self.connection.send(
path, payload, method=request_method, headers=headers
)
value = self._get_response_value(response_data)
return response.getcode(), self._response_to_json(value)
except HTTPError as e:
error = json.loads(e.read())
return e.code, error
def _display_request(self, request_method):
self.connection.queue_message(
"vvvv",
"Web Services: %s %s" % (request_method, self.connection._url),
)
def _get_response_value(self, response_data):
return to_text(response_data.getvalue())
def _response_to_json(self, response_text):
try:
return json.loads(response_text) if response_text else {}
# JSONDecodeError only available on Python 3.5+
except ValueError:
raise ConnectionError("Invalid JSON response: %s" % response_text)
def update_auth(self, response, response_text):
cookie = response.info().get("Set-Cookie")
# Set the 'SEC' header
if "SEC" in cookie:
return {"SEC": cookie.split(";")[0].split("=")[-1]}
return None
def logout(self):
self.send_request("POST", "/auth/logout")
# Clean up tokens
self.connection._auth = None
|