From 10ea361b9c45d18baa13ccb8d113be7b3b405f4f Mon Sep 17 00:00:00 2001 From: Dirk Date: Tue, 20 Jan 2015 21:51:49 +0100 Subject: [PATCH] first prototype BEAST | FIX: maketempf in initialize_engine | FIX: exit statements in main w/ more meaning/shorter --- testssl.sh | 83 +++++++++++++++++++++++++++++++++--------------------- 1 file changed, 51 insertions(+), 32 deletions(-) diff --git a/testssl.sh b/testssl.sh index cb67e4a..120c15c 100755 --- a/testssl.sh +++ b/testssl.sh @@ -913,7 +913,7 @@ server_preference() { out " Has server cipher order? " if [[ "$cipher1" != "$cipher2" ]]; then - red "nope (NOT ok)" + litered "nope (NOT ok)" remark4default_cipher=" (limited sense as client will pick)" else green "yes (OK)" @@ -1683,11 +1683,40 @@ crime() { return $ret } +# Browser Exploit Against SSL/TLS beast(){ - #FIXME: to do -#in a nutshell: don't use CBC Ciphers in TLSv1.0 -# need to provide a list with bad ciphers. Not sure though whether -# it can be fixed in the OpenSSL/NSS/whatsover stack + local cbc_ciphers + local detected_proto + local detected_cbc + local higher_proto_supported="" + #in a nutshell: don't use CBC Ciphers in SSLv3 TLSv1.0 + # + bold " BEAST"; out " (CVE-2011-3389) " + + # 1) support for TLS 1.1+1.2? + for proto in tls1_1 tls1_2; do + $OPENSSL s_client -state -"$proto" $STARTTLS -connect $NODEIP:$PORT $SNI 2>/dev/null >$TMPFILE $TMPFILE 2>/dev/null $OPENSSL_CONF << EOF @@ -2118,26 +2148,22 @@ case "$1" in maketempf parse_hn_port "$3" test_just_one $2 - ret=$? - exit $ret ;; + exit $? ;; -t|--starttls) maketempf parse_hn_port "$3" "$2" # here comes protocol to signal starttls and hostname:port starttls "$2" # protocol - ret=$? - exit $ret ;; + exit $? ;; -e|--each-cipher) maketempf parse_hn_port "$2" allciphers - ret=$? - exit $ret ;; + exit $? ;; -E|-ee|--cipher-per-proto) maketempf parse_hn_port "$2" cipher_per_proto - ret=$? - exit $ret ;; + exit $? ;; -p|--protocols) maketempf parse_hn_port "$2" @@ -2148,54 +2174,46 @@ case "$1" in maketempf parse_hn_port "$2" run_std_cipherlists - ret=$? - exit $ret ;; + exit $? ;; -S|--server_defaults) maketempf parse_hn_port "$2" server_defaults - ret=$? - exit $ret ;; + exit $? ;; -P|--server_preference) maketempf parse_hn_port "$2" server_preference - ret=$? - exit $ret ;; + exit $? ;; -y|--spdy|--google) maketempf parse_hn_port "$2" spdy - ret=$? exit $? ;; -B|--heartbleet) maketempf parse_hn_port "$2" outln; blue "--> Testing for heartbleed vulnerability"; outln "\n" heartbleed - ret=$? exit $? ;; -I|--ccs|--ccs_injection) maketempf parse_hn_port "$2" outln; blue "--> Testing for CCS injection vulnerability"; outln "\n" ccs_injection - ret=$? exit $? ;; -R|--renegotiation) maketempf parse_hn_port "$2" outln; blue "--> Testing for Renegotiation vulnerability"; outln "\n" renego - ret=$? exit $? ;; -C|--compression|--crime) maketempf parse_hn_port "$2" outln; blue "--> Testing for CRIME vulnerability"; outln "\n" crime - ret=$? - exit $? ;; + exit $? ;; -T|--breach) maketempf parse_hn_port "$2" @@ -2214,21 +2232,22 @@ case "$1" in parse_hn_port "$2" outln; blue "--> Testing for POODLE (Padding Oracle On Downgraded Legacy Encryption) vulnerability"; outln "\n" poodle - ret=$? - ret=`expr $? + $ret` - exit $ret ;; + exit $? ;; -4|--rc4|--appelbaum) maketempf parse_hn_port "$2" rc4 - ret=$? - exit $? ;; + exit $? ;; -s|--pfs|--fs|--nsa) maketempf parse_hn_port "$2" pfs - ret=$? - exit $ret ;; + exit $? ;; + -q|--beast) + maketempf + parse_hn_port "$2" + beast + exit $? ;; -H|--header|--headers) maketempf parse_hn_port "$2"