-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlist-operatingsystems.gmp.py
122 lines (98 loc) · 3.25 KB
/
list-operatingsystems.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
112
113
114
115
116
117
118
119
120
121
122
# SPDX-FileCopyrightText: 2025 Martin Boller
#
# SPDX-License-Identifier: GPL-3.0-or-later
#
# Loosely based on other greenbone scripts
#
# Run with: gvm-script --gmp-username admin-user --gmp-password password socket list-operating_systems.gmp.py <days>
# example: gvm-script --gmp-username admin --gmp-password top$ecret socket list-operating_systems.gmp.py 2
from argparse import ArgumentParser, Namespace, RawTextHelpFormatter
from datetime import date, datetime, time, timedelta
from gvm.protocols.gmp import Gmp
from gvmtools.helper import Table
HELP_TEXT = (
"This script generates a table of operating_systems (assets) "
"from Greenbone Vulnerability Manager.\n\n"
"table will contain:\n"
"operating_systemname, IP Address, MAC Address, Operating System, last seen, and severity\n"
)
def parse_args(args: Namespace) -> Namespace: # pylint: disable=unused-argument
"""Parsing args ..."""
parser = ArgumentParser(
prefix_chars="+",
add_help=False,
formatter_class=RawTextHelpFormatter,
)
parser.add_argument(
"+h",
"++help",
action="help",
help="Show this help message and exit.",
)
parser.add_argument(
"delta_days",
nargs="?",
default="1",
type=int,
help=(
"Number of days in the past to pull operating_systems information"
),
)
script_args, _ = parser.parse_known_args(args)
return script_args
def list_operating_systems(gmp: Gmp, from_date: date, to_date: date) -> None:
operating_system_filter = (
f"rows=-1 "
f"and modified>{from_date.isoformat()} "
f"and modified<{to_date.isoformat()}"
)
operating_systems_xml = gmp.get_operating_systems(
filter_string=operating_system_filter
)
heading = [
"#",
"OS CPE",
"Latest Severity",
"Count",
]
rows = []
numberRows = 0
print(
"Listing operating_systems.\n"
f"From: {from_date}\n"
f"To: {to_date}\n"
)
for operating_system in operating_systems_xml.xpath("asset"):
# title will always be there
os_title = operating_system.xpath("name/text()")[0]
os_latest_severity = operating_system.xpath(
"os/latest_severity/value/text()"
)[0]
os_host_count = operating_system.xpath("os/installs/text()")[0]
# Count number of operating_systems
numberRows = numberRows + 1
# Cast/convert to text to show in list
rowNumber = str(numberRows)
rows.append(
[
rowNumber,
os_title,
os_latest_severity,
os_host_count,
]
)
print(Table(heading=heading, rows=rows))
def main(gmp: Gmp, args: Namespace) -> None:
# pylint: disable=undefined-variable
args = args.script[1:]
parsed_args = parse_args(args=args)
delta_days = parsed_args.delta_days
# simply getting yesterday from midnight to today (now)
from_date = datetime.combine(datetime.today(), time.min) - timedelta(
days=delta_days
)
to_date = datetime.now()
# print(from_date, to_date)
list_operating_systems(gmp, from_date, to_date)
if __name__ == "__gmp__":
main(gmp, args)