NEW: HPKP

This commit is contained in:
Dirk 2014-10-29 21:24:43 +01:00
parent b49b1451c4
commit f56f81090a

View File

@ -1,5 +1,6 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# bash is needed for some distros which use dash as /bin/sh and for the heartbleed check! # bash is needed for some distros which use dash as /bin/sh and for tcp sockets which
# this program uses a couple of times
# Program for spotting weak SSL encryption, ciphers, version and some vulnerablities or features # Program for spotting weak SSL encryption, ciphers, version and some vulnerablities or features
@ -64,6 +65,7 @@ DEBUG=${DEBUG:-0} # if 1 the temp file won't be erased. Currently only keeps t
VERBOSE=${VERBOSE:-0} # if 1 it shows what's going on. Currently only used for heartbleed and ccs injection VERBOSE=${VERBOSE:-0} # if 1 it shows what's going on. Currently only used for heartbleed and ccs injection
VERB_CLIST="" # ... and if so, "-V" shows them row by row cipher, SSL-version, KX, Au, Enc and Mac VERB_CLIST="" # ... and if so, "-V" shows them row by row cipher, SSL-version, KX, Au, Enc and Mac
HSTS_MIN=180 #>180 days is ok for HSTS HSTS_MIN=180 #>180 days is ok for HSTS
HPKP_MIN=9 #>9 days should be ok for HPKP_MIN, practical hiints?
NPN_PROTOs="spdy/4a2,spdy/3,spdy/3.1,spdy/2,spdy/1,http/1.1" NPN_PROTOs="spdy/4a2,spdy/3,spdy/3.1,spdy/2,spdy/1,http/1.1"
#global vars: #global vars:
@ -304,13 +306,21 @@ EOF
return $ret return $ret
} }
includeSubDomains() {
if grep -q includeSubDomains "$1"; then
litegreen ", includeSubDomains"
else
litecyan ", just this domain"
fi
}
#FIXME: it doesn't follow a 30x. At least a path should be possible to provide #FIXME: it doesn't follow a 30x. At least a path should be possible to provide
hsts() { hsts() {
[ -s $HEADERFILE ] || http_header [ -s $HEADERFILE ] || http_header
bold " HSTS " bold " HSTS "
grep -i '^Strict-Transport-Security' $HEADERFILE >$TMPFILE grep -iw '^Strict-Transport-Security' $HEADERFILE >$TMPFILE
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
grep -c '^Strict-Transport-Security' $HEADERFILE | egrep -wq "1" || out "(two HSTS header, using 1st one) " grep -ciw '^Strict-Transport-Security' $HEADERFILE | egrep -wq "1" || out "(two HSTS header, using 1st one) "
AGE_SEC=`sed -e 's/[^0-9]*//g' $TMPFILE | head -1` AGE_SEC=`sed -e 's/[^0-9]*//g' $TMPFILE | head -1`
AGE_DAYS=`expr $AGE_SEC \/ 86400` AGE_DAYS=`expr $AGE_SEC \/ 86400`
if [ $AGE_DAYS -gt $HSTS_MIN ]; then if [ $AGE_DAYS -gt $HSTS_MIN ]; then
@ -318,8 +328,9 @@ hsts() {
else else
brown "$AGE_DAYS days (<$HSTS_MIN is not good enough)" brown "$AGE_DAYS days (<$HSTS_MIN is not good enough)"
fi fi
includeSubDomains "$TMPFILE"
else else
litecyan "no" out "no"
fi fi
outln outln
@ -327,6 +338,32 @@ hsts() {
return $? return $?
} }
hpkp() {
[ -s $HEADERFILE ] || http_header
bold " HPKP "
egrep -iw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE >$TMPFILE
if [ $? -eq 0 ]; then
egrep -ciw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE | egrep -wq "1" || out "(two HPKP header, using 1st one) "
AGE_SEC=`sed -e 's/\r//g' -e 's/^.*max-age=//' -e 's/;.*//' $TMPFILE`
AGE_DAYS=`expr $AGE_SEC \/ 86400`
if [ $AGE_DAYS -gt $HPKP_MIN ]; then
litegreen "$AGE_DAYS days \c" ; out "($AGE_SEC s)"
else
brown "$AGE_DAYS days (<$HPKP_MIN is not good enough)"
fi
includeSubDomains "$TMPFILE"
out ", fingerprints not checked"
else
out "no"
fi
outln
rm $TMPFILE
return $?
}
#FIXME: report-uri
#FIXME: once checkcert.sh is here: fingerprints!
serverbanner() { serverbanner() {
[ -s $HEADERFILE ] || http_header [ -s $HEADERFILE ] || http_header
bold " Server " bold " Server "
@ -462,7 +499,7 @@ std_cipherlists() {
fi fi
rm $TMPFILE rm $TMPFILE
else else
singlespaces=`echo "$2" | sed -e 's/ \+/ /g' -e 's/^ //' -e 's/ $//g' -e 's/ //g'`` singlespaces=`echo "$2" | sed -e 's/ \+/ /g' -e 's/^ //' -e 's/ $//g' -e 's/ //g'`
magentaln "Local problem: No $singlespaces configured in $OPENSSL" magentaln "Local problem: No $singlespaces configured in $OPENSSL"
fi fi
# we need lf in those cases: # we need lf in those cases:
@ -1879,6 +1916,7 @@ case "$1" in
maketempf maketempf
outln; blue "--> Testing HTTP Header response"; outln "\n" outln; blue "--> Testing HTTP Header response"; outln "\n"
hsts hsts
hpkp
ret=$? ret=$?
serverbanner serverbanner
ret=`expr $? + $ret` ret=`expr $? + $ret`
@ -1904,6 +1942,7 @@ case "$1" in
outln; blue "--> Testing HTTP Header response"; outln "\n" outln; blue "--> Testing HTTP Header response"; outln "\n"
hsts ; ret=`expr $? + $ret` hsts ; ret=`expr $? + $ret`
hpkp ; ret=`expr $? + $ret`
serverbanner ; ret=`expr $? + $ret` serverbanner ; ret=`expr $? + $ret`
rc4 ; ret=`expr $? + $ret` rc4 ; ret=`expr $? + $ret`
@ -1913,7 +1952,7 @@ case "$1" in
exit $ret ;; exit $ret ;;
esac esac
# $Id: testssl.sh,v 1.129 2014/10/23 13:52:05 dirkw Exp $ # $Id: testssl.sh,v 1.130 2014/10/29 20:24:42 dirkw Exp $
# vim:ts=5:sw=5 # vim:ts=5:sw=5