mirror of
https://github.com/drwetter/testssl.sh.git
synced 2024-12-29 12:59:44 +01:00
Extend TLS/SSL port detection
As mentioned in #1931 the port detection for nmap greppable files leaves space for improvements. Ths PR adds a pattern detection of ssl and https in the forth or fifth parameter of an open port, so those ports will be added to a scan when a nmap greppable output file is as input to testssl.sh . Also it does minor code adjustments to utils/gmap2testssl.sh .
This commit is contained in:
parent
18dfa26e48
commit
defed8705b
16
testssl.sh
16
testssl.sh
@ -21353,7 +21353,7 @@ nmap_to_plain_file() {
|
||||
local target_fname=""
|
||||
local oneline=""
|
||||
local ip hostdontcare round_brackets ports_specs starttls
|
||||
local tmp port host_spec protocol dontcare dontcare1
|
||||
local tmp port host_spec protocol ssl_hint dontcare dontcare1
|
||||
#FIXME: IPv6 is missing here
|
||||
|
||||
# Ok, since we are here we are sure to have an nmap file. To avoid questions we make sure it's the right format too
|
||||
@ -21394,11 +21394,15 @@ nmap_to_plain_file() {
|
||||
while read -r oneline; do
|
||||
# 25/open/tcp//smtp//<banner>/,
|
||||
[[ "$oneline" =~ '/open/tcp/' ]] || continue # no open tcp for this port on this IP --> move on
|
||||
IFS=/ read -r port dontcare protocol dontcare1 <<< "$oneline"
|
||||
starttls="$(ports2starttls $port)"
|
||||
[[ $? -eq 1 ]] && continue # nmap got a port but we don't know how to speak to
|
||||
[[ "$DEBUG" -ge 1 ]] && echo "${starttls}$host_spec:$port"
|
||||
echo "${starttls}${host_spec}:${port}" >>"$target_fname"
|
||||
IFS=/ read -r port dontcare protocol ssl_hint dontcare1 <<< "$oneline"
|
||||
if [[ "$ssl_hint" =~ ^(ssl|https) ]] || [[ "$dontcare1" =~ ^(ssl|https) ]]; then
|
||||
echo "${host_spec}:${port}" >>"$target_fname"
|
||||
else
|
||||
starttls="$(ports2starttls $port)"
|
||||
[[ $? -eq 1 ]] && continue # nmap got a port but we don't know how to speak to
|
||||
[[ "$DEBUG" -ge 1 ]] && echo "${starttls}$host_spec:$port"
|
||||
echo "${starttls}${host_spec}:${port}" >>"$target_fname"
|
||||
fi
|
||||
done < <(tr ',' '\n' <<< "$ports_specs")
|
||||
done < "$FNAME"
|
||||
[[ "$DEBUG" -ge 1 ]] && echo
|
||||
|
Loading…
Reference in New Issue
Block a user