forked from greenbone/gvm-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
application-detection.gmp.py
78 lines (56 loc) · 1.89 KB
/
application-detection.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
# SPDX-FileCopyrightText: 2017-2021 Greenbone AG
#
# SPDX-License-Identifier: GPL-3.0-or-later
import sys
from argparse import Namespace
from gvm.protocols.gmp import Gmp
def check_args(args):
len_args = len(args.script) - 1
if len_args != 1:
message = """
This script will display all hosts with the searched applications!
1. <application> -- Name of the application
Example:
$ gvm-script --gmp-username name --gmp-password pass \
ssh --hostname <gsm> scripts/application-detection.gmp.py <application>
"""
print(message)
sys.exit()
def print_assets(gmp, appname):
res = gmp.get_reports(details=False)
reports = res.xpath("/get_reports_response/report")
for report in reports:
report_id = report.attrib["id"]
print_assets_for_host(gmp, appname, report_id)
def print_assets_for_host(gmp, appname, report_id):
res = gmp.get_report(
report_id, details=True, filter_string="rows=1 result_hosts_only=0"
)
hosts = res.xpath("/get_reports_response/report/report/host")
for host in hosts:
ip = host.xpath("ip/text()")
if len(ip) == 0:
continue
else:
ip = ip[0]
hostname = host.xpath('detail/name[text()="hostname"]/../value/text()')
if len(hostname) == 0:
hostname = ""
else:
hostname = hostname[0]
apps = host.xpath(
'detail/name[text() = "App"]/../value['
f'contains(text(), "{appname}")]/text()'
)
if len(apps) == 0:
continue
print(f"{ip} ({hostname})")
for app in apps:
print("\t" + app)
print("\n")
def main(gmp: Gmp, args: Namespace) -> None:
# pylint: disable=undefined-variable
check_args(args)
print_assets(gmp, args.script[1])
if __name__ == "__gmp__":
main(gmp, args)