mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-22 08:29:31 +01:00
More run_protocol() fixes
This PR fixes a few issues with run_protocol(): * In the case that the call to `tls_sockets "03" "$TLS12_CIPHER"` had a return value of 2, the code determining what results to print was looking at `$DETECTED_TLS_VERSION`. However, the value of this variable was set by the later call to `tls_sockets "04" "$tls13_ciphers_to_test"`. This caused incorrect results in the case of a server that supports TLSv1.3 and TLS1.1 (or earlier), but not TLSv1.2. This PR saves the value of `$DETECTED_TLS_VERSION` in `$tls12_detected_version` and then uses this variable later rather than `$DETECTED_TLS_VERSION`. * When running in debug mode with a server that does not support TLSv1.3, testssl.sh was printing TLS 1.3 -- downgradednot offered and downgraded to a weaker protocol" This PR fixes the output by not printing the "--downgraded" * As noted in #1329, run_protocols() was treating a downgrade from TLSv1.2 as less bad if the server supports TLSv1.3. This PR changes this code back to treat any downgrade from TLSv1.2 as equally bad. * In order to be consistent with the TLSv1.3 test, this PR changes the TLS1.2 test output to say "not offered and downgraded to a weaker protocol" if a TLSv1.2 ClientHello results in a downgraded connection.
This commit is contained in:
parent
9e3bcfb2ef
commit
25d68544ed
32
testssl.sh
32
testssl.sh
@ -4866,6 +4866,7 @@ run_protocols() {
|
|||||||
local lines nr_ciphers_detected
|
local lines nr_ciphers_detected
|
||||||
local tls13_ciphers_to_test=""
|
local tls13_ciphers_to_test=""
|
||||||
local i drafts_offered="" drafts_offered_str="" supported_versions debug_recomm=""
|
local i drafts_offered="" drafts_offered_str="" supported_versions debug_recomm=""
|
||||||
|
local tls12_detected_version
|
||||||
local -i ret=0 ret_val_tls12=0 ret_val_tls13=0
|
local -i ret=0 ret_val_tls12=0 ret_val_tls13=0
|
||||||
local offers_tls13=false
|
local offers_tls13=false
|
||||||
local jsonID="SSLv2"
|
local jsonID="SSLv2"
|
||||||
@ -5182,6 +5183,7 @@ run_protocols() {
|
|||||||
[[ $? -eq 0 ]] && ret_val_tls12=0
|
[[ $? -eq 0 ]] && ret_val_tls12=0
|
||||||
# see #807 and #806
|
# see #807 and #806
|
||||||
fi
|
fi
|
||||||
|
tls12_detected_version="$DETECTED_TLS_VERSION"
|
||||||
# Need to ensure that at most 128 ciphers are included in ClientHello.
|
# Need to ensure that at most 128 ciphers are included in ClientHello.
|
||||||
# If the TLSv1.2 test was successful, then use the 5 TLSv1.3 ciphers
|
# If the TLSv1.2 test was successful, then use the 5 TLSv1.3 ciphers
|
||||||
# plus the cipher selected in the TLSv1.2 test. If the TLSv1.2 test was
|
# plus the cipher selected in the TLSv1.2 test. If the TLSv1.2 test was
|
||||||
@ -5240,33 +5242,28 @@ run_protocols() {
|
|||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
2) add_tls_offered tls1_2 no
|
2) add_tls_offered tls1_2 no
|
||||||
if "$offers_tls13"; then
|
pr_svrty_medium "not offered and downgraded to a weaker protocol"
|
||||||
out "not offered"
|
if [[ "$tls12_detected_version" == 0300 ]]; then
|
||||||
else
|
|
||||||
pr_svrty_medium "not offered"
|
|
||||||
fi
|
|
||||||
if [[ "$DETECTED_TLS_VERSION" == 0300 ]]; then
|
|
||||||
detected_version_string="SSLv3"
|
detected_version_string="SSLv3"
|
||||||
elif [[ "$DETECTED_TLS_VERSION" == 03* ]]; then
|
elif [[ "$tls12_detected_version" == 03* ]]; then
|
||||||
detected_version_string="TLSv1.$((0x$DETECTED_TLS_VERSION-0x0301))"
|
detected_version_string="TLSv1.$((0x$tls12_detected_version-0x0301))"
|
||||||
fi
|
fi
|
||||||
if [[ "$DETECTED_TLS_VERSION" == "$latest_supported" ]]; then
|
if [[ "$tls12_detected_version" == "$latest_supported" ]]; then
|
||||||
[[ $DEBUG -ge 1 ]] && tm_out " -- downgraded"
|
|
||||||
outln
|
outln
|
||||||
fileout "$jsonID" "MEDIUM" "not offered and downgraded to a weaker protocol"
|
fileout "$jsonID" "MEDIUM" "not offered and downgraded to a weaker protocol"
|
||||||
elif [[ "$DETECTED_TLS_VERSION" == 03* ]] && [[ 0x$DETECTED_TLS_VERSION -lt 0x$latest_supported ]]; then
|
elif [[ "$tls12_detected_version" == 03* ]] && [[ 0x$tls12_detected_version -lt 0x$latest_supported ]]; then
|
||||||
prln_svrty_critical " -- server supports $latest_supported_string, but downgraded to $detected_version_string"
|
prln_svrty_critical " -- server supports $latest_supported_string, but downgraded to $detected_version_string"
|
||||||
fileout "$jsonID" "CRITICAL" "not offered, and downgraded to $detected_version_string rather than $latest_supported_string"
|
fileout "$jsonID" "CRITICAL" "not offered, and downgraded to $detected_version_string rather than $latest_supported_string"
|
||||||
elif [[ "$DETECTED_TLS_VERSION" == 03* ]] && [[ 0x$DETECTED_TLS_VERSION -gt 0x0303 ]]; then
|
elif [[ "$tls12_detected_version" == 03* ]] && [[ 0x$tls12_detected_version -gt 0x0303 ]]; then
|
||||||
prln_svrty_critical " -- server responded with higher version number ($detected_version_string) than requested by client"
|
prln_svrty_critical " -- server responded with higher version number ($detected_version_string) than requested by client"
|
||||||
fileout "$jsonID" "CRITICAL" "not offered, server responded with higher version number ($detected_version_string) than requested by client"
|
fileout "$jsonID" "CRITICAL" "not offered, server responded with higher version number ($detected_version_string) than requested by client"
|
||||||
else
|
else
|
||||||
if [[ ${#DETECTED_TLS_VERSION} -eq 4 ]]; then
|
if [[ ${#tls12_detected_version} -eq 4 ]]; then
|
||||||
prln_svrty_critical "server responded with version number ${DETECTED_TLS_VERSION:0:2}.${DETECTED_TLS_VERSION:2:2} (NOT ok)"
|
prln_svrty_critical "server responded with version number ${tls12_detected_version:0:2}.${tls12_detected_version:2:2} (NOT ok)"
|
||||||
fileout "$jsonID" "CRITICAL" "server responded with version number ${DETECTED_TLS_VERSION:0:2}.${DETECTED_TLS_VERSION:2:2}"
|
fileout "$jsonID" "CRITICAL" "server responded with version number ${tls12_detected_version:0:2}.${tls12_detected_version:2:2}"
|
||||||
else
|
else
|
||||||
prln_svrty_medium " -- strange, server ${DETECTED_TLS_VERSION}"
|
prln_svrty_medium " -- strange, server ${tls12_detected_version}"
|
||||||
fileout "$jsonID" "MEDIUM" "strange, server ${DETECTED_TLS_VERSION}"
|
fileout "$jsonID" "MEDIUM" "strange, server ${tls12_detected_version}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
@ -5410,7 +5407,6 @@ run_protocols() {
|
|||||||
detected_version_string="TLSv1.$((0x$DETECTED_TLS_VERSION-0x0301))"
|
detected_version_string="TLSv1.$((0x$DETECTED_TLS_VERSION-0x0301))"
|
||||||
fi
|
fi
|
||||||
if [[ "$DETECTED_TLS_VERSION" == "$latest_supported" ]]; then
|
if [[ "$DETECTED_TLS_VERSION" == "$latest_supported" ]]; then
|
||||||
[[ $DEBUG -ge 1 ]] && tm_out " -- downgraded"
|
|
||||||
outln "not offered and downgraded to a weaker protocol"
|
outln "not offered and downgraded to a weaker protocol"
|
||||||
fileout "$jsonID" "INFO" "not offered + downgraded to weaker protocol"
|
fileout "$jsonID" "INFO" "not offered + downgraded to weaker protocol"
|
||||||
elif [[ "$DETECTED_TLS_VERSION" == 03* ]] && [[ 0x$DETECTED_TLS_VERSION -lt 0x$latest_supported ]]; then
|
elif [[ "$DETECTED_TLS_VERSION" == 03* ]] && [[ 0x$DETECTED_TLS_VERSION -lt 0x$latest_supported ]]; then
|
||||||
|
Loading…
Reference in New Issue
Block a user