mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-07 17:20:57 +01:00
Logic for POODLE && TLS_FALLBACK_SCSV
If vulnernable to POODLE and has no TLS_FALLBACK_SCSV ==> HIGH. If only run the fallback check and it has none, still label it as MEDIUM but issue a clear warning that test under this circumstances is incomplete.
This commit is contained in:
parent
615a93e69e
commit
3adb5ac71f
16
testssl.sh
16
testssl.sh
@ -262,6 +262,7 @@ SOCK_REPLY_FILE=""
|
|||||||
NW_STR=""
|
NW_STR=""
|
||||||
LEN_STR=""
|
LEN_STR=""
|
||||||
SNI=""
|
SNI=""
|
||||||
|
POODLE="" # keep vulnerability status for TLS_FALLBACK_SCSV
|
||||||
OSSL_VER="" # openssl version, will be auto-determined
|
OSSL_VER="" # openssl version, will be auto-determined
|
||||||
OSSL_VER_MAJOR=0
|
OSSL_VER_MAJOR=0
|
||||||
OSSL_VER_MINOR=0
|
OSSL_VER_MINOR=0
|
||||||
@ -9859,9 +9860,11 @@ run_ssl_poodle() {
|
|||||||
[[ "$DEBUG" -eq 2 ]] && egrep -q "error|failure" $ERRFILE | egrep -av "unable to get local|verify error"
|
[[ "$DEBUG" -eq 2 ]] && egrep -q "error|failure" $ERRFILE | egrep -av "unable to get local|verify error"
|
||||||
fi
|
fi
|
||||||
if [[ $sclient_success -eq 0 ]]; then
|
if [[ $sclient_success -eq 0 ]]; then
|
||||||
|
POODLE=0
|
||||||
pr_svrty_high "VULNERABLE (NOT ok)"; out ", uses SSLv3+CBC (check TLS_FALLBACK_SCSV mitigation below)"
|
pr_svrty_high "VULNERABLE (NOT ok)"; out ", uses SSLv3+CBC (check TLS_FALLBACK_SCSV mitigation below)"
|
||||||
fileout "poodle_ssl" "HIGH" "POODLE, SSL: VULNERABLE, uses SSLv3+CBC" "$cve" "$cwe" "$hint"
|
fileout "poodle_ssl" "HIGH" "POODLE, SSL: VULNERABLE, uses SSLv3+CBC" "$cve" "$cwe" "$hint"
|
||||||
else
|
else
|
||||||
|
POODLE=1
|
||||||
pr_done_best "not vulnerable (OK)";
|
pr_done_best "not vulnerable (OK)";
|
||||||
if "$using_sockets"; then
|
if "$using_sockets"; then
|
||||||
fileout "poodle_ssl" "OK" "POODLE, SSL: not vulnerable" "$cve" "$cwe"
|
fileout "poodle_ssl" "OK" "POODLE, SSL: not vulnerable" "$cve" "$cwe"
|
||||||
@ -9925,9 +9928,20 @@ run_tls_fallback_scsv() {
|
|||||||
$OPENSSL s_client $STARTTLS $BUGS -connect $NODEIP:$PORT $PROXY $SNI -no_tls1_2 -fallback_scsv &>$TMPFILE </dev/null
|
$OPENSSL s_client $STARTTLS $BUGS -connect $NODEIP:$PORT $PROXY $SNI -no_tls1_2 -fallback_scsv &>$TMPFILE </dev/null
|
||||||
if grep -q "CONNECTED(00" "$TMPFILE"; then
|
if grep -q "CONNECTED(00" "$TMPFILE"; then
|
||||||
if grep -qa "BEGIN CERTIFICATE" "$TMPFILE"; then
|
if grep -qa "BEGIN CERTIFICATE" "$TMPFILE"; then
|
||||||
|
if [[ -z "$POODLE" ]]; then
|
||||||
|
pr_warning "Rerun including POODLE SSL check. "
|
||||||
pr_svrty_medium "Downgrade attack prevention NOT supported"
|
pr_svrty_medium "Downgrade attack prevention NOT supported"
|
||||||
fileout "fallback_scsv" "MEDIUM" "TLS_FALLBACK_SCSV (RFC 7507) (experimental) : Downgrade attack prevention NOT supported"
|
fileout "fallback_scsv" "WARNING" "TLS_FALLBACK_SCSV (RFC 7507): Downgrade attack prevention NOT supported. Pls rerun wity POODLE SSL check"
|
||||||
ret=1
|
ret=1
|
||||||
|
elif [[ "$POODLE" -eq 0 ]]; then
|
||||||
|
pr_svrty_high "Downgrade attack prevention NOT supported and vulnerable to POODLE SSL"
|
||||||
|
fileout "fallback_scsv" "HIGH" "TLS_FALLBACK_SCSV (RFC 7507): Downgrade attack prevention NOT supported and vulnerable to POODLE SSL"
|
||||||
|
ret=0
|
||||||
|
else
|
||||||
|
pr_svrty_medium "Downgrade attack prevention NOT supported"
|
||||||
|
fileout "fallback_scsv" "MEDIUM" "TLS_FALLBACK_SCSV (RFC 7507): Downgrade attack prevention NOT supported"
|
||||||
|
ret=1
|
||||||
|
fi
|
||||||
elif grep -qa "alert inappropriate fallback" "$TMPFILE"; then
|
elif grep -qa "alert inappropriate fallback" "$TMPFILE"; then
|
||||||
pr_done_good "Downgrade attack prevention supported (OK)"
|
pr_done_good "Downgrade attack prevention supported (OK)"
|
||||||
fileout "fallback_scsv" "OK" "TLS_FALLBACK_SCSV (RFC 7507) (experimental) : Downgrade attack prevention supported"
|
fileout "fallback_scsv" "OK" "TLS_FALLBACK_SCSV (RFC 7507) (experimental) : Downgrade attack prevention supported"
|
||||||
|
Loading…
Reference in New Issue
Block a user