-
Notifications
You must be signed in to change notification settings - Fork 90
/
combine-reports.gmp.py
111 lines (85 loc) · 3.36 KB
/
combine-reports.gmp.py
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# SPDX-FileCopyrightText: 2017-2021 Greenbone AG
#
# SPDX-License-Identifier: GPL-3.0-or-later
# ruff: noqa: E501
import sys
import time
from argparse import Namespace
from gvm.protocols.gmp import Gmp
from gvmtools.helper import generate_uuid
from lxml import etree as e
def check_args(args: Namespace) -> None:
len_args = len(args.script) - 1
if len_args < 2:
message = """
This script will combine desired reports into a single report. \
The combined report will then be sent to a desired container task. \
This script will create a container task for the combined report to\
be sent to, however, if you would like the report to be sent to an \
existing task, place the report of the desired task first and add \
the argument 'first_task'.
1. <report_1_uuid> --uuid of report to be combined
2. <report_2_uuid> --uuid of report to be combined
...
n. <report_n_uuid> --uuid of report to be combined
Example for starting up the routine:
$ gvm-script --gmp-username=namessh --gmp-password=pass ssh --hostname=hostname \
scripts/combine-reports.gmp.py \
"d15a337c-56f3-4208-a462-afeb79eb03b7" \
"303fa0a6-aa9b-43c4-bac0-66ae0b2d1698" 'first_task'
"""
print(message)
sys.exit()
def combine_reports(gmp: Gmp, args: Namespace) -> e.Element:
new_uuid = generate_uuid()
combined_report = e.Element(
"report",
{
"id": new_uuid,
"format_id": "d5da9f67-8551-4e51-807b-b6a873d70e34",
"extension": "xml",
"content_type": "text/xml",
},
)
report_elem = e.Element("report", {"id": new_uuid})
ports_elem = e.Element("ports", {"start": "1", "max": "-1"})
results_elem = e.Element("results", {"start": "1", "max": "-1"})
combined_report.append(report_elem)
report_elem.append(results_elem)
if "first_task" in args.script:
arg_len = args.script[1:-1]
else:
arg_len = args.script[1:]
for argument in arg_len:
current_report = gmp.get_report(
argument, details=True, ignore_pagination=True
)[0]
for port in current_report.xpath("report/ports/port"):
ports_elem.append(port)
for result in current_report.xpath("report/results/result"):
results_elem.append(result)
for host in current_report.xpath("report/host"):
report_elem.append(host)
return combined_report
def send_report(gmp: Gmp, args: Namespace, combined_report: e.Element) -> str:
if "first_task" in args.script:
main_report = gmp.get_report(args.script[1])[0]
task_id = main_report.xpath("//task/@id")[0]
else:
the_time = time.strftime("%Y/%m/%d-%H:%M:%S")
task_id = ""
task_name = f"Combined_Report_{the_time}"
res = gmp.create_container_task(
name=task_name, comment="Created with gvm-tools."
)
task_id = res.xpath("//@id")[0]
combined_report = e.tostring(combined_report)
res = gmp.import_report(combined_report, task_id=task_id, in_assets=True)
return res.xpath("//@id")[0]
def main(gmp: Gmp, args: Namespace) -> None:
# pylint: disable=undefined-variable
check_args(args)
combined_report = combine_reports(gmp, args)
send_report(gmp, args, combined_report)
if __name__ == "__gmp__":
main(gmp, args)