From 4e7c3f65aea19f598c73c460b38d949896f0473f Mon Sep 17 00:00:00 2001 From: JeffreyShran <10995361+JeffreyShran@users.noreply.github.com> Date: Mon, 22 May 2023 16:16:06 +0100 Subject: [PATCH] nuclei plugin added. --- autorecon/default-plugins/nuclei.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 autorecon/default-plugins/nuclei.py diff --git a/autorecon/default-plugins/nuclei.py b/autorecon/default-plugins/nuclei.py new file mode 100644 index 0000000..1c5a956 --- /dev/null +++ b/autorecon/default-plugins/nuclei.py @@ -0,0 +1,20 @@ +from autorecon.plugins import ServiceScan + +class Nikto(ServiceScan): + + def __init__(self): + super().__init__() + self.name = 'nuclei' + self.tags = ['default', 'safe', 'long', 'http'] + + def configure(self): + self.match_service_name('^http') + self.match_service_name('^nacn_http$', negative_match=True) + + async def run(self, service): + if service.target.ipversion == 'IPv4': + await service.execute('nuclei -target {http_scheme}://{address}:{port} -scan-all-ips -automatic-scan 2>&1 | tee "{scandir}/{protocol}_{port}_{http_scheme}_nuclei.txt"') + + def manual(self, service, plugin_was_run): + if service.target.ipversion == 'IPv4' and not plugin_was_run: + service.add_manual_command('(nuclei) powerful & highly configurable web server enumeration tool from projectdiscovery.io:', 'nuclei -target {http_scheme}://{address}:{port} -scan-all-ips -automatic-scan 2>&1 | tee "{scandir}/{protocol}_{port}_{http_scheme}_nuclei.txt"')