mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-07 17:20:57 +01:00
Added support of multiple servers to json-pretty format; added fileout for smtp
This commit is contained in:
parent
ae6462fe65
commit
29d6cbc125
68
testssl.sh
68
testssl.sh
@ -270,6 +270,8 @@ HEX_CIPHER=""
|
|||||||
HEXDUMP=(hexdump -ve '16/1 "%02x " " \n"') # This is used to analyze the reply
|
HEXDUMP=(hexdump -ve '16/1 "%02x " " \n"') # This is used to analyze the reply
|
||||||
HEXDUMPPLAIN=(hexdump -ve '1/1 "%.2x"') # Replaces both xxd -p and tr -cd '[:print:]'
|
HEXDUMPPLAIN=(hexdump -ve '1/1 "%.2x"') # Replaces both xxd -p and tr -cd '[:print:]'
|
||||||
|
|
||||||
|
SERVER_COUNTER=0 # Counter for multiple servers
|
||||||
|
|
||||||
#################### SEVERITY ####################
|
#################### SEVERITY ####################
|
||||||
INFO=0
|
INFO=0
|
||||||
OK=0
|
OK=0
|
||||||
@ -712,14 +714,12 @@ fileout_pretty_json_header() {
|
|||||||
\"target host\" : \"$NODE\",
|
\"target host\" : \"$NODE\",
|
||||||
\"port\" : \"$PORT\",
|
\"port\" : \"$PORT\",
|
||||||
\"startTime\" : \"$START_TIME\",
|
\"startTime\" : \"$START_TIME\",
|
||||||
\"scanResult\" : {
|
\"scanResult\" : ["
|
||||||
"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fileout_pretty_json_footer() {
|
fileout_pretty_json_footer() {
|
||||||
local scan_time=$((END_TIME - START_TIME))
|
local scan_time=$((END_TIME - START_TIME))
|
||||||
echo -e " },
|
echo -e " ],
|
||||||
\"ip\" : \"$NODEIP\",
|
|
||||||
\"scanTime\" : \"$scan_time\"\n}"
|
\"scanTime\" : \"$scan_time\"\n}"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -730,39 +730,36 @@ fileout_json_header() {
|
|||||||
|
|
||||||
fileout_json_footer() {
|
fileout_json_footer() {
|
||||||
"$do_json" && printf "]\n" >> "$JSONFILE"
|
"$do_json" && printf "]\n" >> "$JSONFILE"
|
||||||
"$do_pretty_json" && (printf "\n%s" "$(fileout_pretty_json_footer)") >> "$JSONFILE"
|
"$do_pretty_json" && (printf "$(fileout_pretty_json_footer)") >> "$JSONFILE"
|
||||||
}
|
}
|
||||||
|
|
||||||
fileout_json_section() {
|
fileout_json_section() {
|
||||||
case $1 in
|
case $1 in
|
||||||
1)
|
1)
|
||||||
echo -e " \"service\" : ["
|
echo -e " \"protocols\" : ["
|
||||||
;;
|
;;
|
||||||
2)
|
2)
|
||||||
echo -e ",\n \"protocols\" : ["
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
echo -e ",\n \"ciphers\" : ["
|
echo -e ",\n \"ciphers\" : ["
|
||||||
;;
|
;;
|
||||||
4)
|
3)
|
||||||
echo -e ",\n \"pfs\" : ["
|
echo -e ",\n \"pfs\" : ["
|
||||||
;;
|
;;
|
||||||
5)
|
4)
|
||||||
echo -e ",\n \"serverPreferences\" : ["
|
echo -e ",\n \"serverPreferences\" : ["
|
||||||
;;
|
;;
|
||||||
6)
|
5)
|
||||||
echo -e ",\n \"serverDefaults\" : ["
|
echo -e ",\n \"serverDefaults\" : ["
|
||||||
;;
|
;;
|
||||||
7)
|
6)
|
||||||
echo -e ",\n \"headerResponse\" : ["
|
echo -e ",\n \"headerResponse\" : ["
|
||||||
;;
|
;;
|
||||||
8)
|
7)
|
||||||
echo -e ",\n \"vulnerabilities\" : ["
|
echo -e ",\n \"vulnerabilities\" : ["
|
||||||
;;
|
;;
|
||||||
9)
|
8)
|
||||||
echo -e ",\n \"cipherTests\" : ["
|
echo -e ",\n \"cipherTests\" : ["
|
||||||
;;
|
;;
|
||||||
10)
|
9)
|
||||||
echo -e ",\n \"browserSimulations\": ["
|
echo -e ",\n \"browserSimulations\": ["
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
@ -773,12 +770,13 @@ fileout_json_section() {
|
|||||||
|
|
||||||
fileout_section_header(){
|
fileout_section_header(){
|
||||||
local str=""
|
local str=""
|
||||||
$2 && str="$(fileout_section_footer)"
|
$2 && str="$(fileout_section_footer false)"
|
||||||
"$do_pretty_json" && FIRST_FINDING=true && (printf "%s%s\n" "$str" "$(fileout_json_section "$1")") >> "$JSONFILE"
|
"$do_pretty_json" && FIRST_FINDING=true && (printf "%s%s\n" "$str" "$(fileout_json_section "$1")") >> "$JSONFILE"
|
||||||
}
|
}
|
||||||
|
|
||||||
fileout_section_footer() {
|
fileout_section_footer() { # IS_THE_LAST_ONE
|
||||||
"$do_pretty_json" && printf "\n ]" >> "$JSONFILE"
|
"$do_pretty_json" && printf "\n ]" >> "$JSONFILE"
|
||||||
|
"$do_pretty_json" && $1 && echo -e "\n }" >> "$JSONFILE"
|
||||||
}
|
}
|
||||||
|
|
||||||
fileout_json_print_parameter() {
|
fileout_json_print_parameter() {
|
||||||
@ -816,15 +814,24 @@ fileout_json_finding() {
|
|||||||
echo -e "\n }" >> "$JSONFILE"
|
echo -e "\n }" >> "$JSONFILE"
|
||||||
fi
|
fi
|
||||||
if "$do_pretty_json"; then
|
if "$do_pretty_json"; then
|
||||||
("$FIRST_FINDING" && echo -n " {" >> "$JSONFILE") || echo -n ",{" >> "$JSONFILE"
|
if [[ "$1" == "service" ]]; then
|
||||||
echo -e -n "\n" >> "$JSONFILE"
|
if [[ $SERVER_COUNTER -gt 1 ]]; then
|
||||||
fileout_json_print_parameter "id" " " "$1" true
|
echo " ," >> "$JSONFILE"
|
||||||
fileout_json_print_parameter "severity" " " "$2" true
|
fi
|
||||||
fileout_json_print_parameter "cve" " " "$cve" true
|
echo -e " {
|
||||||
fileout_json_print_parameter "cwe" " " "$cwe" true
|
\"service\" : \"$finding\",
|
||||||
"$GIVE_HINTS" && fileout_json_print_parameter "hint" " " "$hint" true
|
\"ip\" : \"$NODEIP\"," >> "$JSONFILE"
|
||||||
fileout_json_print_parameter "finding" " " "$finding" false
|
else
|
||||||
echo -e -n "\n }" >> "$JSONFILE"
|
("$FIRST_FINDING" && echo -n " {" >> "$JSONFILE") || echo -n ",{" >> "$JSONFILE"
|
||||||
|
echo -e -n "\n" >> "$JSONFILE"
|
||||||
|
fileout_json_print_parameter "id" " " "$1" true
|
||||||
|
fileout_json_print_parameter "severity" " " "$2" true
|
||||||
|
fileout_json_print_parameter "cve" " " "$cve" true
|
||||||
|
fileout_json_print_parameter "cwe" " " "$cwe" true
|
||||||
|
"$GIVE_HINTS" && fileout_json_print_parameter "hint" " " "$hint" true
|
||||||
|
fileout_json_print_parameter "finding" " " "$finding" false
|
||||||
|
echo -e -n "\n }" >> "$JSONFILE"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -11653,6 +11660,7 @@ determine_service() {
|
|||||||
fi
|
fi
|
||||||
grep -q '^Server Temp Key' $TMPFILE && HAS_DH_BITS=true # FIX #190
|
grep -q '^Server Temp Key' $TMPFILE && HAS_DH_BITS=true # FIX #190
|
||||||
out " Service set:$CORRECT_SPACES STARTTLS via "
|
out " Service set:$CORRECT_SPACES STARTTLS via "
|
||||||
|
fileout "service" "INFO" "Service detected: $protocol"
|
||||||
toupper "$protocol"
|
toupper "$protocol"
|
||||||
[[ -n "$XMPP_HOST" ]] && echo -n " (XMPP domain=\'$XMPP_HOST\')"
|
[[ -n "$XMPP_HOST" ]] && echo -n " (XMPP domain=\'$XMPP_HOST\')"
|
||||||
outln
|
outln
|
||||||
@ -12292,7 +12300,7 @@ lets_roll() {
|
|||||||
|
|
||||||
START_TIME=$(date +%s)
|
START_TIME=$(date +%s)
|
||||||
|
|
||||||
fileout_section_header $section_number false && ((section_number++))
|
((SERVER_COUNTER++))
|
||||||
determine_service "$1" # any starttls service goes here
|
determine_service "$1" # any starttls service goes here
|
||||||
|
|
||||||
$do_tls_sockets && [[ $TLS_LOW_BYTE -eq 22 ]] && { sslv2_sockets "" "true"; echo "$?" ; exit 0; }
|
$do_tls_sockets && [[ $TLS_LOW_BYTE -eq 22 ]] && { sslv2_sockets "" "true"; echo "$?" ; exit 0; }
|
||||||
@ -12300,7 +12308,7 @@ lets_roll() {
|
|||||||
$do_test_just_one && test_just_one ${single_cipher}
|
$do_test_just_one && test_just_one ${single_cipher}
|
||||||
|
|
||||||
# all top level functions now following have the prefix "run_"
|
# all top level functions now following have the prefix "run_"
|
||||||
fileout_section_header $section_number true && ((section_number++))
|
fileout_section_header $section_number false && ((section_number++))
|
||||||
$do_protocols && { run_protocols; ret=$(($? + ret)); }
|
$do_protocols && { run_protocols; ret=$(($? + ret)); }
|
||||||
$do_spdy && { run_spdy; ret=$(($? + ret)); }
|
$do_spdy && { run_spdy; ret=$(($? + ret)); }
|
||||||
$do_http2 && { run_http2; ret=$(($? + ret)); }
|
$do_http2 && { run_http2; ret=$(($? + ret)); }
|
||||||
@ -12362,7 +12370,7 @@ lets_roll() {
|
|||||||
fileout_section_header $section_number true && ((section_number++))
|
fileout_section_header $section_number true && ((section_number++))
|
||||||
$do_client_simulation && { run_client_simulation; ret=$(($? + ret)); }
|
$do_client_simulation && { run_client_simulation; ret=$(($? + ret)); }
|
||||||
|
|
||||||
fileout_section_footer
|
fileout_section_footer true
|
||||||
|
|
||||||
outln
|
outln
|
||||||
END_TIME=$(date +%s)
|
END_TIME=$(date +%s)
|
||||||
|
Loading…
Reference in New Issue
Block a user